Jak blokovat stránky v IE
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Jak blokovat stránky v IEJak blokovat stránky v IE

 

Jak blokovat stránky v IE

Google       Google       25. 8. 2006       14 350×

S Internet Explorerem jsme si v mých článcích hráli už mnohokrát. Tentokrát si vytvoříme skutečně užitečnou aplikaci, nebo alespoň její základ. Naučíme se blokovat „závadné“ stránky.

Reklama
Reklama

Hned na začátku si stanovíme náš dnešní cíl. Nebudeme vytvářet žádný složitý plug-in, naše aplikace bude pouze kontrolovat ve spuštěných instancích IE adresu načtené stránky, a pokud se bude nacházet na „black listu“, jednoduše dané okno IE uzavře.

Budeme tedy potřebovat jen dvě hlavní funkce. Tou první zjistíme seznam spuštěných oken IE, resp. seznam otevřených stránek. V druhé fázi pak seznam prohledáme a okna s „vadným“ obsahem uzavřeme. Nejprve tedy na prázdný formulář umístíme ListBox. Právě do něj si zapíšeme seznam nalezených oken IE, resp. adres. Dále přidáme na formulář tlačítko, které danou funkci spustí a naplní ListBox.

function GetUrlFromIE (Handle: THandle; List: TStringList): boolean; stdcall;
var
  hWndIE, hWndIEChild: HWND;
  Buffer: array[0..255] of Char;
begin
  SendMessage(Handle, WM_GETTEXT, 255, integer(@Buffer[0]));
  hWndIE := FindWindow('IEFrame', Buffer);
  if hWndIE > 0 then
  begin
    hWndIEChild := FindWindowEx(hWndIE, 0, 'WorkerW', nil);
    if hWndIEChild > 0 then
    begin
      hWndIEChild := FindWindowEx(hWndIEChild, 0, 'ReBarWindow32', nil);
      if hWndIEChild > 0 then
      begin
        hWndIEChild := FindWindowEx(hWndIEChild, 0, 'ComboBoxEx32', nil);
        if hWndIEChild > 0 then
        begin
          SendMessage(hWndIEChild, WM_GETTEXT, 255, integer(@Buffer));
          List.AddObject(Buffer,TObject(hWndIE));
        end;
      end;
    end;
  end;
  Result := True;
end;

Funkci tedy máme připravenou, zbývá nám s její pomocí naplnit náš ListBox:

procedure TForm1.Button1Click(Sender: TObject);
begin
  ListBox1.Clear;
  EnumWindows(@GetUrlFromIE, LParam(ListBox1.Items));
end;

Nakonec nám zbývá jen příslušné okno zavřít. To už je velmi snadné a využijeme k tomu zpráv systému Windows. Prostřednictvím identifikátoru jednotlivého okna, jeho Handle, dokážeme příslušnou zprávou dané okno uzavřít.

procedure TForm1.Button2Click(Sender: TObject);
var
  Handle : THandle;
begin
  if ListBox1.ItemIndex = -1 then Exit;
  Handle := THandle(ListBox1.Items.Objects[ListBox1.ItemIndex]);
  PostMessage(Handle, WM_CLOSE, 0, 0);
end;

A to je vlastně vše. To nejhlavnější máme hotovo. Nyní by bylo potřeba vypracovat nějaký „bezpečnostní model“ pro automatické filtrování stránek. Prostě se okno nebude zavírat na základě stisknutého tlačítka, ale naše aplikace bude „číhat“ na pozadí a kontrolovat otevřené stránky, které pak bude zavírat. Může mít v sobě integrován přímo konkrétní seznam nevhodných stránek. Můžeme však jít ještě o krok dále a třeba si vypracovat složitější filtr, který bude odchytávat i jednotlivé „nevhodné“ výrazy z textu adresy, neboť ji máme uloženu jako text. Fantazii se meze nekladou, v každém případě pak metoda pro uzavření okna zůstane stejná.

Tentokrát si můžete jednoduchý ukázkový projekt s popsanými funkcemi stáhnout zde.

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

1 názor  —  1 nový  
Hlasování bylo ukončeno    
0 hlasů
Google
Autor je náruživý programátor v Delphi, učí se v prologu a rád čte, sportuje a ze všeho nejradši lyžuje.

Nové články

Reklama
Reklama
Obrázek ke článku Blockchain & Bitcoin konference

Blockchain & Bitcoin konference

V pátek 19. 5. 2017 se v pražském konferenčním centru Andel’s konala Blockchain & Bitcoin konference. Řada odborníků a podnikatelů v oboru blockchainu a kryptoměn představila možnosti budoucího směřování tohoto oboru. Speakeři většinou rusky mluvící provenience prezentovali řešení svých firem založená na technologii blockchainu.

Obrázek ke článku Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Bezpečnostní tým Cisco Talos odhalil celkem 4 kampaně dosud neobjeveného malwaru, který dostal jméno KONNI. Ten se dokázal úspěšně maskovat od roku 2014. Zpočátku se malware zaměřoval pouze na krádeže citlivých dat. Za 3 roky se ale několikrát vyvinul, přičemž jeho současná verze umožňuje útočníkovi z infikovaného počítače nejenom krást data, ale i mapovat stisky na klávesnici, pořizovat screenshoty obrazovky či v zařízení spustit libovolný kód. Pro odvedení pozornosti oběti zasílali útočníci v příloze také obrázek, zprávu a výhružkách severokorejského režimu či kontakty na členy mezinárodních organizací.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý