Molto spesso all'interno delle nostre pagine dobbiamo far riferimento ad altre, ad esempio attraverso l'uso di WebClient, passando come riferimento un cookie, che ad esempio contiente l'ID di sessione piuttosto che il cookie di autenticazione.
In casi come questi si è portati ad utilizzare l'accoppiata WebRequest/WebResponse perchè, a prima vista, la classe WebClient non espone una proprietà diretta per associare cookie.
In realtà basta aggiungere alla collezioone Headers, che è di tipo WebHeaderCollection, il cookie stesso, come una normale header HTTP, che è poi quello che in fin dei conti è.
Il codice riportato non fa altro che trasmettere un cookie alla pagina remota:
<%@ Import namespace="System.Net" %> <SCRIPT RUNAT="SERVER" LANGUAGE="C#"> void Page_Load() { Response.Write(GetUrlWithCookie("http://www.sito.ext/login.aspx")); } string GetUrlWithCookie(string url) { // WebClient WebClient request = new WebClient(); // aggiungo cookie WebHeaderCollection headerCookies = new WebHeaderCollection(); headerCookies.Add("Cookie", "cookie=valore"); request.Headers.Add(headerCookies); // scarico risultato Byte[] bResult = request.DownloadData(url); // de-encoding dei dati e conversione in stringa Encoding objEncoded = Encoding.GetEncoding("iso-8859-1"); return objEncoded.GetString(bResult); } </SCRIPT>
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
I più letti di oggi
- Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
- Accedere con ASP.NET ad un documento XML creato dall'oggetto recordset di ADO e ASP
- Richiamare programmaticamente le operazioni di aggiornamento, eliminazione e inserimento di FormView, DetailsView e GridView
- Ricavare lo spazio occupato su disco dal nostro sito
- Realizzare siti sicuri con ASP.NET Web Pages