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

 
Hledat
Moderní platforma pro vytvoření vašeho nového webu – Wix.com.
Nyní už můžete mít web zdarma.
Vybavení pro Laser Game
Spuštěn Filmový magazín
Laser Game Brno

Jak blokovat stránky v IE

Google       Google       25. 8. 2006       15 298×

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 Pracujete u počítače ve stoje? Dbejte na správné držení těla

Pracujete u počítače ve stoje? Dbejte na správné držení těla

Práce ve stoje je jedna z variant, jak změnit polohu těla při dlouhodobé práci u počítače. Především je důležité nezapomínat na správné držení těla, abychom při práci nenamáhali naší krční páteř. Primářka MUDr. Michaela Tomanová představí hlavní bonusy a rizika práce u počítače ve stoje.

Obrázek ke článku Firmy musejí s nástupem Průmyslu 4.0 více dbát na kyberbezpečnost. V ohrožení je i jejich know-how.

Firmy musejí s nástupem Průmyslu 4.0 více dbát na kyberbezpečnost. V ohrožení je i jejich know-how.

Destabilizace firmy či ukradené know-how. To jsou možná hlavní budoucí rizika spojená s nedostatečnou kybernetickou bezpečností průmyslových firem, na která upozorňují experti. Vzhledem k postupující digitalizaci výrobních či technologických procesů a přechodu k takzvanému Průmyslu 4.0 může těchto hrozeb postupně přibývat. Varují před nimi i nejnovější průzkumy. 

Obrázek ke článku Nový CEBIT je připraven: Pochopit digitální dnešek a objevit digitální zítřek

Nový CEBIT je připraven: Pochopit digitální dnešek a objevit digitální zítřek

Nový veletrh  CEBIT je připraven. V polovině června začne v Hannoveru evropský festival obchodu s radikálně změněnou koncepcí věnovaný inovacím a digitalizaci.  CEBIT jedinečnou formou spojuje obchod v digitálním hospodářství 
s festivalovými prvky a posouvá do středu pozornosti téma digitální transformace hospodářství a společnosti.  

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032018 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý