ASP.NET PageState a jeho efektivní správa
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

ASP.NET PageState a jeho efektivní správaASP.NET PageState a jeho efektivní správa

 

ASP.NET PageState a jeho efektivní správa

Google       Google       1. 3. 2007       7 607×

Článek obsahuje popis řešení efektivní správy ASP.NET PageState. Zabývá se problémy, jako je např. uložení PageState na serveru a šifrování. Pro lepší pochopení uveřejňuji okomentované zdrojové soubory ke stažení.

Reklama
Reklama

V rámci svého webu jsem vytvořil nestandardní, ale velmi efektivní systém, který se stará o ukládání a načítání pagestate. Předně bych rád zmínil, že se nejedná o návod, ale spíš o popis řešení. V projektu jsou řešeny tyto problémy: ukládání identifikátoru do původního skrytého pole, automatické mazání starších záznamů, šifrování pagestate a samozřejmě jeho ukládání různými způsoby na server. V závěru vám nabídnu celý projekt s podrobně okomentovanými zdroji ke stažení a na případné dotazy rád odpovím.

Základ

Základem celého systému jsou třídy HiddenFieldPageStatePersister a PageStateManager. Obě třídy v rozporu s vaším očekáváním dědí ze standardní třídy System.Web.UI.HiddenFieldPageStatePersister, ale první z nich ke standardnímu způsobu ukládání přidává pouze šifrování s pomocí šifry Rijndael, a proto se jí nebudu věnovat. Šifrování zajišťuje statická třída, kterou používám už dlouhou dobu a funguje velice spolehlivě – nejsem jejím autorem a bohužel si nevzpomínám na její původ. Druhá třída se stará o kompletní správu pagestate, jeho serverové ukládání, načítání i odstranění. Nejdůležitější jsou přepsané metody Load a Save, ve kterých se používá tzv. fiktivní pagestate. Celé to spočívá v tom, že pagestate uložíte na server a základní třídě podstrčíte identifikátor, ta ho uloží do skrytého pole. Třída také obsahuje metodu, která v případě potřeby odstraní přebytečný záznam s pagestate.

Uchovávání na serveru

O samotné uchovávání na serveru se stará nějaký persister, který implementuje rozhraní IPageStatePersister, které definuje metody pro uložení, načtení a odstranění pagestate na serveru. K dispozici jsou persistery pro souborový systém, SQL databázi a session. Další persistery je možné poměrně snadno začlenit do projektu, a nebo ho můžete přiřadit přes konfigurační soubor – jako hodnotu atributu Persister uveďte zápis typ,assembly.

Cache

Poslední podstatnou částí je třída PageStateCahe, která implementuje timeout pro záznamy uložené na serveru. Dvanáct hodin po vytvoření záznamu dojde k vyvolání události, při které dojde k zavolání metody persisteru, která odstraní pagestate. Ke kontrole dochází každou minutu.

Konfigurace

O deklarativní konfiguraci se stará třída SectionHandler, která, jak už z názvu vyplývá, implementuje handler pro vlastní sekci v konfiguračním souboru web.config. Handler musíte připojit v části configSections.

<?xml version="1.0"?>
<configuration>
  <!-- nastavení aplikace -->
  <configSections>
    <!-- konfigurace sekcí -->
    <sectionGroup name="Programujte">
      <!-- přiřazení handleru k sekci -->
      <section name="PageStateSettings" type="Programujte.PageState.SectionHandler, PageState" />
    </sectionGroup>
  </configSections>

  <!-- řetězce pro připojení k DB -->
  <connectionStrings>
    <add name="ConnectionString" connectionString="řetězec pro připojení"/>
  </connectionStrings>

  <!-- skupina sekci Programujte -->
  <Programujte>
    <!-- nastavení page adaptéru, který se stará o alternativní ukládání pagestate -->
    <PageStateSettings CacheTimeOut="720" ConnectionStringName="ConnectionString" Enabled="true" Encryption="true" FolderPath="~\pagestate"  Persister="SQL" IDColumnName="pagestateID" StateColumnName="pagestate" TableName="pagestate">
      <!-- soubory, ve kterých bude uplatněn standardní postup uložení pagestate -->
      <ExcludedFiles>
        <!-- není defaultní -->
        <add path="~\*.aspx" />
        <remove path="~\*.aspx" />
      </ExcludedFiles>
    </PageStateSettings>
  </Programujte>
</configuration>

Následující tabulka popisuje význam atributů a podsekcí sekce PageStateSettings. Výchozí hodnoty jsou zvýrazněné tučně.

Atribut / podsekce Možné hodnoty Význam
CacheTimeOut Libovolné číslo (720). Životnost záznamů v minutách.
ConnectionStringName Libovolný řetězec (ConnectionString). Název jednoho z řetězců v sekci connectionStrings.
Enabled True nebo false. Rychlé vypnutí nebo zapnutí správy pagestate.
Encryption True nebo false. Rychlé vypnutí nebo zapnutí šifrování pagestate.
FolderPatch Libovolná cesta ~\* (~\pagestate). Cesta, kam mohou být uloženy soubory s pagestate.
Persister SQL, File, Session, HiddenField nebo zápis typ,assembly. Udává, jaký persister se má použít.
IDColumnName Libovolný řetězec (pagestateID). Název sloupce, kam se ukládá identifikátor.
StateColumnName Libovolný řetězec (pagestate). Název sloupce, kam se ukládá pagestate.
TableName Libovolný řetězec (pagestate). Název databázové tabulky, která obsahuje výše zmíněné sloupce.
ExcludedFiles <add path="~\*.aspx" />
<remove path="~\*.aspx" />
Kolekce souborů, kde bude uplatněn standardní postup uložení pagestate.

Použití na webu

Pro použití na webu slouží třída PageAdapter, kterou ke svému projektu přiřadíte s pomocí souboru .browser. Soubor s následujícím obsahem uložte do složky App_Browsers ve vašem webovém projektu.

<browsers>
  <browser refID="Default" >
    <controlAdapters>
      <adapter controlType="System.Web.UI.Page" adapterType="Programujte.PageState.PageAdapter" />
    </controlAdapters>
  </browser>
</browsers>

Závěr

Článek je určen pro pokročilé vývojaře, ale doufám, že jsem všem dostatečně vysvětlil, o co vlastně jde. Další podrobnosti se dovíte v kompletních a okomentovaných zdrojových souborech, které si můžete stáhnout, libovolně upravit a šířit dál. K provozu potřebujete ASP.NET server s podporou .NET 2.0+, pro .NET 1.x nebo MONO je nutné provést drobné úpravy. Na projektu je určitě hodně co zlepšovat, ale to už nechám na vás.

×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.

Hlasování bylo ukončeno    
0 hlasů
Google
(fotka) Dušan JanošíkDušan vyvíjí software a webové aplikace na platformě .NET. Je milovníkem neuznávaných teorií, a zajímá se o parapsychologii a teraristiku.
Web     Twitter     Facebook     LinkedIn    

Nové články

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í.

Reklama
Reklama
Obrázek ke článku Pouze jedna z deseti lokálních firem ví o pokutách plynoucích z GDPR

Pouze jedna z deseti lokálních firem ví o pokutách plynoucích z GDPR

Trend Micro, celosvětový lídr v oblasti bezpečnostních řešení a VMware, přední světový dodavatel cloudové infrastruktury a řešení pro podnikovou mobilitu, oznámily výsledky výzkumu mezi českými a slovenskými manažery zodpovědnými za ochranu osobních údajů, který zjišťoval, jak jsou připraveni na nové nařízení o ochraně osobních údajů (GDPR). Většina firem v České republice a na Slovensku nad 100 zaměstnanců je již s novým nařízením GDPR obeznámena. Výzkum provedený ve spolupráci s agenturou Ipsos ukázal, že téměř 8 firem z 10 o nařízení ví, přičemž jeho znalost je o něco vyšší na Slovensku (89 %) než v České republice (69 %).

Obrázek ke článku Vyděračský software Locky se vrací, tváří se jako potvrzení platby, odhalil tým Cisco Talos

Vyděračský software Locky se vrací, tváří se jako potvrzení platby, odhalil tým Cisco Talos

Jeden z nejznámějších ransomwarů, Locky, se vrací. Po většinu roku 2016 patřil mezi nejrozšířenější vyděračské softwary. Ke svému šíření využíval emailové kampaně s infikovanými přílohami. Ransomware Locky byl rozesílán prostřednictvím botnetu (internetový robot zasílající spamy) Necurs. Jeho aktivita na konci roku 2016 téměř upadla a spolu s ní i šíření ransomwaru Locky. Před několika týdny se Necurs opět probudil a začal posílat spamy nabízející výhodný nákup akcií. Dne 21. dubna zaznamenal bezpečnostní tým Cisco Talos první velkou kampaň ransomwaru Locky prostřednictvím botnetu Necurs za posledních několik měsíců.

Obrázek ke článku Dovozci baterií mění logistiku, letadlo nahrazuje námořní doprava

Dovozci baterií mění logistiku, letadlo nahrazuje námořní doprava

Dovozci baterií do mobilů či notebooků upouštějí od letecké přepravy zboží. V letošním roce plánují dovézt až 80 % produktů lodí. Přitom před 5 lety byla většina baterií do mobilních přístrojů dovezených do České republiky přepravována letadlem. Za proměnou způsobu transportu akumulátorů stojí zpřísnění pravidel pro leteckou přepravu, která přinášejí vyšší náklady i náročnou agendu.

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ý