Pěkné URL adresy v ASP.NET Webforms 4.0
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Pěkné URL adresy v ASP.NET Webforms 4.0Pěkné URL adresy v ASP.NET Webforms 4.0

 

Pěkné URL adresy v ASP.NET Webforms 4.0

Google       Google       11. 5. 2012       27 053×

Spolu s ASP.NET MVC přišly i nové "pěkné URL". Samozřejmě nebyly výsadou pouze MVC, i u WebForms se daly řešit, ovšem jejich vytvoření nebylo tolik efektivní a jednoduché. Od verze ASP.NET 4.0 lze tyto pěkné adresy URL generovat stejně jednoduše jako u MVC. Pojďme se nyní podívat, jak na to.

Jak to bude vypadat

Při programování webových aplikací jste se určitě setkali s tím, že jste potřebovali dynamicky generovat obsah na základě nějakého prvku v adrese URL. Představme si nyní, že máme webovou aplikaci, ve které zobrazujeme články z nějakého zdroje dat (nejčastěji databáze). Typicky by zápis při generování obsahu vypadal asi takto:

http://localhost:14412/ViewArticle.aspx?articleID=12

Je to zápis logický pro aplikaci, ovšem pro cílového klienta většinou ne. Tento vzhled je hůře stravitelný jak pro toho, kdo stránku prohlíží, tak pro různé vyhledávače apod. My bychom tedy chtěli něco takového:

http://localhost:14412/Articles/12

Jdeme programovat

Pojďme rovnou společně programovat!

Otevřte si Visual Studio a vytvořte novou prázdnou webovou aplikaci. Nejdříve vytvoříme stránku Default.aspx. Dále budeme potřebovat soubor Global.asax.

Vytvoření souboru Global.asax

Soubor rovnou otevřeme. Vidíme, že je zde připravených pět metod, které reagují na základní životní události naší webové aplikace. Nás bude zajímat metoda Application_Start().

Jak to bude fungovat?

Aplikaci nějak musíme říci, že za přepokladu zadání určitého tvaru adresy URL se má zobrazit obsah nějaké stránky aspx.

Pro tento účel je v ASP.NET připravený tzv. Routing. Veškeré třídy lze nalézt na System.Web.Routing. Zde je připravena třída RouteTable s kolekcí Routes. Do této kolekce budeme pomocí metody MapPageRoute přidávat další pravidla pro adresy URL.

V našem konkrétním případě přidáme do metody Application_Start tyto řádky kódu:

void Application_Start(object sender, EventArgs e) 
{
    System.Web.Routing.RouteTable.Routes.MapPageRoute("MyRoute", // název routy
        "Page/{Page}", // vzor, jak bude vypadat adresa URL
        "~/Default.aspx" // fyzický soubor, který se bude otevírat při zadání adresy v předešlém parametru 
        );
}

Metoda má v tomto případě tři parametry:

  • 1. parametr - string - označení routy. Tyto názvy nejsou na webu nikde zobrazovány. Slouží k tomu, když chceme s routou pracovat (např. vytvářet adresy - také si v tomto článku ukážeme).
  • 2. parametr - string - vzhled, jaký bude mít výsledná adresa. Mezi složené závorky { & } se uzavírají identifikační názvy dynamických prvků v adrese (např. při použití pro ID článku, stránky atp.).
  • 3. parametr - string - fyzický soubor, který se použije při zadání adresy.

Úprava stránky aspx

Nyní do stránky necháme dynamicky generovat ID vybrané stránky (to, co se dosadí za {Page}).  Ovšem k zadané hodnotě se nedostaneme přes Request.QueryString[int index], nýbrž budeme muset použít třídu určenou pro práci s Route:

// proměnná, skrze kterou budeme zobrazovat získané hodnoty
public string PageNameString; 

protected void Page_Load(object sender, EventArgs e)
{  
    // uložení hodnoty do proměnné PageNameString
    PageNameString = RouteData.Values["Page"].ToString();
}

Nyní ve stránce můžeme pohodlně pracovat s hodnotou skrze proměnnou PageNameString. S hodnotou si můžete pohrát, jak chcete, např. generovat nějaká data z databáze. Já poukáži na naprosto primitivní aplikaci, kde hodnotu pouze vypíšu:

<h1>Stránka <% Response.Write(PageNameString); %></h1>
<p>Nacházíte se na stránce s číselným označením <% Response.Write(PageNameString); %></p>

Výsledek by mohl vypadat nějak takto:

Výsledná aplikace

Text se samozřejmě bude měnit na základě zadané hodnoty v adresním řádku prohlížeče za klíčovým slovem Page.

Odkazování na další stránky

Pokud budeme chtít odkazovat na další stránky, např. na stránku, která bude mít ID hodnoty 26, nebude to žádný problém. Normálně sestavíme adresu :

<asp:HyperLink ID="HyperLink1" runat="server" NavigateUrl="~/Page/26">Přejít na stránku 26</asp:HyperLink>

Toto řešení je samozřejmě možné a funguje tak, jak má. Ovšem za předpokladu, že takovýchto odkazů na webu máme víc a najednou se rozhodneme trochu změnit systém zobrazování adresy z Page/{Page} na např. MyWeb/Page/{Page}, všechny odkazy budou nefunkční.

Proto je lepší generovat odkazy dynamicky. K tomu máme v ASP.NET metodu GetRouteURL, která tuto adresu generuje na základě registrované routy v našem Global.asax. Metoda má dva parametry: první je název routy (první parametr metody MapPageRoute v Global.asax), druhý je anonymní objekt, který bude definovat hodnoty dynamicky definovaných prvků v URL.

Při generování adresy pro náš HyperLink by zdrojový kód vypadal asi takto:

HyperLink1.NavigateUrl = GetRouteUrl("MyRoute", // název routy 
            new { Page = "56" } // anonymní objekt definují prvky routy
            );

Další možnosti zápisu...

Pokud bychom chtěli adresu generovat do komponenty HyperLink přímo ve stránce aspx, můžeme použít tento zápis:

<%$ RouteURL: Page=26  %>

Naopak pokud bychom chtěli hodnotu do stránky vrátit, lze použít ekvivalentní zápis:

<%$ RouteValue: Page %>

Samozřejmě jsou tyto zápisy platné při použití u vlastností komponent. Pokud je zapíšete jenom tak do stránky aspx, aplikace vyhodí chybu.

Na závěr

V dnešní době je vytváření přívětivých URL prakticky samozřejmost. Do jisté míry to i znepříjemňuje život útočníkům na webové stránky, zejména v případě, kdy v URL předáváme ID pro nějaký SQL dotaz...

Doufám, že vám tento článek přinesl zase něco dalšího. Také jsem se trochu snažil dokázat, jak WebForms dokážou konkurovat MVC.

×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    
2 hlasy
Google
(fotka) Milan SukMilan studuje 3. ročník obecného gymnázia. V současnosti pracuje jako PHP programátor. Mezi jeho záliby patří samozřejmě IT, dále moderní přírodní vědy a z kulturní stránky hra na kytaru/klavír. Věří v open source a svobodný software. Je uživatel linuxových distribucí.
Web     Twitter     Facebook    

Nové články

Obrázek ke článku Stavebnice umělé inteligence 1

Stavebnice umělé inteligence 1

Článek popisuje první část stavebnice umělé inteligence. Obsahuje lineární a plošnou optimalizaci.  Demo verzi je možné použít pro výuku i zájmovou činnost. Profesionální verze je určena pro vývojáře, kteří chtějí integrovat popsané moduly do svých systémů.

Obrázek ke článku Hybridní inteligentní systémy 2

Hybridní inteligentní systémy 2

V technické praxi využíváme často kombinaci různých disciplín umělé inteligence a klasických výpočtů. Takovým systémům říkáme hybridní systémy. V tomto článku se zmíním o určitém typu hybridního systému, který je užitečný ve velmi složitých výrobních procesech.

Obrázek ke článku Jak vést kvalitně tým v IT oboru: Naprogramujte si ty správné manažerské kvality

Jak vést kvalitně tým v IT oboru: Naprogramujte si ty správné manažerské kvality

Vedení týmu v oboru informačních technologií se nijak zvlášť neliší od jiných oborů. Přesto však IT manažeři čelí výzvě v podobě velmi rychlého rozvoje a tím i rostoucími nároky na své lidi. Udržet pozornost, motivaci a efektivitu týmu vyžaduje opravdu pevné manažerské základy a zároveň otevřenost a flexibilitu pro stále nové výzvy.

Obrázek ke článku Síla týmů se na home office může vytrácet. Odborníci radí, jak z pracovních omezení vytěžit maximum

Síla týmů se na home office může vytrácet. Odborníci radí, jak z pracovních omezení vytěžit maximum

Za poslední rok se podoba práce zaměstnanců změnila k nepoznání. Především plošné zavedení home office, které mělo být zpočátku jen dočasným opatřením, je pro mnohé už více než rok každodenní realitou. Co ale dělat, když se při práci z domova ztrácí motivace, zaměstnanci přestávají komunikovat a dříve fungující tým se rozpadá na skupinu solitérů? Odborníci na personalistiku dali dohromady několik rad, jak udržet tým v chodu, i když pracovní podmínky nejsou ideální.

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