ホームページ >バックエンド開発 >C#.Net チュートリアル >C#でのCookieの読み込み例を詳しく解説
Link:
1. Cookieを書く
1. Name属性とValue属性はプログラムによって設定され、デフォルト値は空の参照です。
2. Domain 属性のデフォルト値は、この Cookie を発行するページがどのディレクトリにあるかに関係なく、現在の URL のドメイン名部分です。
デフォルトのドメイン属性は www.kent.com です。この属性はプログラムによって必要な値に設定できます。
3. Path 属性のデフォルト値は、この Cookie を送信するページがどのディレクトリにあるかに関係なく、ルート ディレクトリ、つまり「/」です。この Cookie の範囲は、プログラムによって特定のパスに設定することでさらに制限できます。
4. Expires 属性、この属性はこの Cookie の有効期限の日時を設定します。 Cookie の有効期間が設定されていない場合 (デフォルト設定)、Cookie を作成することもできますが、Cookie はユーザーのハードドライブには保存されず、ユーザーのセッション情報の一部となり、Cookie は削除されると消えます。ブラウザが閉じられているか、セッションがタイムアウトになった場合、このタイプの Cookie は非永続 Cookie と呼ばれます。 SessionID を格納する Cookie は、ハードディスクには保存されず、メモリ上にのみ存在します。
5. ResponseのCookies属性に送信したいCookieを添付してクライアントに送信します: Response.Cookies.Add(Cookie)
6. 同じDomain属性+Path属性を持つCookieがすべてクライアント上に存在するファイル内では、Cookie は「*」で区切られます。各 Cookie の 1 行目は Cookie の名前、2 行目は値、3 行目はこの Cookie の範囲を示す Domain 属性 + Path 属性で構成される文字列、残りの行には日々の処理情報が含まれます有効期限日時などの Cookie の情報。 Cookie には単純なチェックサムも含まれているため、Cookie 名または値の長さが変更された場合、ブラウザは変更を検出して Cookie を削除します。
2. Cookie の読み取り
1. Request.Cookies 属性には、クライアントからサーバーに送信されたすべての Cookie のコレクションが含まれており、リクエスト URL の範囲内の Cookie のみが HTTP とともにブラウザによって要求されます。リクエストがサーバーに送信されます。
2. NameとValueの属性とサブキーの値が読みやすい。
3. Domain 属性と Path 属性は読み取れません。Domain 属性は常に ""、Path 属性は常に "/" です。元々、これらの属性の用途は限られていました。ページが Cookie と同じドメイン上にない場合、ページの場所では Cookie をまったく受信しません。
4. Cookieの有効期限が読み取れません。実際、ブラウザが Cookie 情報をサーバーに送信するとき、ブラウザには有効期限情報は含まれません。 Expires プロパティを読み取ることはできますが、常に日付/時刻値 0 が返されます。 Expires 属性の主な役割は、ブラウザによる Cookie ストレージの日常的な管理を支援することです。サーバーの観点から見ると、Cookie は存在するか存在しないかのどちらかであるため、有効期限はサーバーにとって有益な情報ではありません。したがって、ブラウザは Cookie を送信するときにこの情報を提供しません。 Cookie の有効期限が必要な場合は、再度設定する必要があります。
3. Cookie の変更と削除
1. 実際、Cookie を直接変更することはできません。同じ名前の Cookie を作成し、その Cookie をブラウザに送信して、クライアント マシン上の古い Cookie を上書きする必要があります。 。
2. 同様に、Cookie を直接削除することはできません。ブラウザが有効期間を確認するときに、Cookie の有効期間を過去の特定の時点に変更することができます。 Cookie の有効期限が切れたこの Cookie は削除されます。有効期限を変更してCookieを削除する
IV. CookieとSessionの関係
1. asp.netのセッションはCookieとCookielessの2つの方法を使用できます。Cookieを使用しない方法は、URLにSessionIDを入れることです。クライアントとサーバーの間を行き来する場合、Cookie を使用する必要はありません。この方法についてはここでは説明しません。
2. asp.net では、クライアントが初めて URL を要求すると、サーバーはクライアントの SessionID を生成し、それを非永続的な Cookie としてクライアントに送信します。
3. 非永続的な Cookie はブラウザを閉じた後にのみ消えます。セッションのタイムアウト判定は次のとおりです。
3.1 クライアントが初めてサーバーにアクセスするとき、非永続的なセッション ID が取得されます。 Cookieがクライアントに送信されます。
3.2 ブラウザを閉じる前にこのURLにアクセスすると、ブラウザはSessionIDをサーバーに送信し、サーバーはSessionID(つまり、さまざまな値)に基づいて、この顧客に対応するサーバーのさまざまなステータスを維持します。これらのセッションは Web アプリケーションで操作できます。
3.3 サーバーはこのSessionIDの有効期限を維持しており、セッションタイムアウトはIISで設定できます。リクエストごとに、サーバーはこの SessioID の有効期限を設定されたタイムアウト期間だけ延長します。
3.4 SessionIDの有効期限が切れたこと、つまり設定されたタイムアウト期間内に顧客が再度サイトを訪問しなかったことをサーバーが検出すると、SessionIDとこのSessionIDに関連するすべてのSession変数が削除されます。
3.5 クライアントのブラウザが閉じられるまで、サーバーがセッション ID を削除したことはわかりません。クライアントは引き続きこのセッション ID の Cookie をサーバーに送信しますが、この時点でサーバーはセッション ID を認識しなくなり、ユーザーを削除します。新規ユーザーとして、新しいセッション ID を再度割り当てます。
Cookie の作成:
値が gjy で有効期間が 1 日のユーザー名 Cookie をクライアント上に作成します。
方法 1:
Response.Cookies["username"].Value="zxf"; Response.Cookies["username"].Expires=DateTime.Now.AddDays(1);
方法 2:
System.Web.HttpCookie newcookie=new HttpCookie("username"); newcookie.Value="gjy"; newcookie.Expires=DateTime.Now.AddDays(1); Response.AppendCookie(newcookie);
サブキーを含む Cookie を作成します。
System.Web.HttpCookie newcookie=new HttpCookie("user"); newcookie.Values["username"]="zxf"; newcookie.Values["password"]="111"; newcookie.Expires=DateTime.Now.AddDays(1); Response.AppendCookie(newcookie);または:
System.Web.HttpContext.Current.Response.Cookies.Add(Cookie);Cookie の読み取り: サブキーなしの読み取り:
if(Request.Cookies["username"]!=null) { Response.Write(Server.UrlDecode(Request.Cookies["username"]));または:
HttpContext.Current.Request.Cookies[strCookieName] }サブキー付きの読み取り:
if(Request.Cookies["user"]!=null) { Response.Write(Server.UrlDecode(Request.Cookies["user"]["username"].Value)); Response.Write(Server.UrlDecode(Request.Cookies["user"]["password"].Value));追加と読み取りの 2 つの方法:Add:
れーれー
読む:Response.AppendCookie(newcookie); System.Web.HttpContext.Current.Response.Cookies.Add(Cookie);Cookie の有効期限を設定しない限り、ブラウザを閉じると Cookie は自動的に期限切れになります Cookie の変更時刻を削除するだけです: Cookie.Expires = DateTime.Now.AddDays( -1 );
Request.Cookies["username"] HttpContext.Current.Request.Cookies["username"]
例:
using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; public class Cookie { /// <summary> /// Cookies赋值 /// </summary> /// <param name="strName">主键</param> /// <param name="strValue">键值</param> /// <param name="strDay">有效天数</param> /// <returns></returns> public bool setCookie(string strName, string strValue, int strDay) { try { HttpCookie Cookie = new HttpCookie(strName); //Cookie.Domain = ".xxx.com";//当要跨域名访问的时候,给cookie指定域名即可,格式为.xxx.com Cookie.Expires = DateTime.Now.AddDays(strDay); Cookie.Value = strValue; System.Web.HttpContext.Current.Response.Cookies.Add(Cookie); return true; } catch { return false; } } /// <summary> /// 读取Cookies /// </summary> /// <param name="strName">主键</param> /// <returns></returns> public string getCookie(string strName) { HttpCookie Cookie = System.Web.HttpContext.Current.Request.Cookies[strName]; if (Cookie != null) { return Cookie.Value.ToString(); } else { return null; } } /// <summary> /// 删除Cookies /// </summary> /// <param name="strName">主键</param> /// <returns></returns> public bool delCookie(string strName) { try { HttpCookie Cookie = new HttpCookie(strName); //Cookie.Domain = ".xxx.com";//当要跨域名访问的时候,给cookie指定域名即可,格式为.xxx.com Cookie.Expires = DateTime.Now.AddDays(-1); System.Web.HttpContext.Current.Response.Cookies.Add(Cookie); return true; } catch { return false; } } }
Cookie Cookie = new Cookie(); Cookie.setCookie("name", "aaa",1);//赋值 Cookie.getCookie("name");//取值 Cookie.delCookie("name");//删除例:
using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; public class Cookie { /// <summary> /// Cookies赋值 /// </summary> /// <param name="strName">主键</param> /// <param name="strValue">键值</param> /// <param name="strDay">有效天数</param> /// <returns></returns> public bool setCookie(string strName, string strValue, int strDay) { try { HttpCookie Cookie = new HttpCookie(strName); //Cookie.Domain = ".xxx.com";//当要跨域名访问的时候,给cookie指定域名即可,格式为.xxx.com Cookie.Expires = DateTime.Now.AddDays(strDay); Cookie.Value = strValue; System.Web.HttpContext.Current.Response.Cookies.Add(Cookie); return true; } catch { return false; } } /// <summary> /// 读取Cookies /// </summary> /// <param name="strName">主键</param> /// <returns></returns> public string getCookie(string strName) { HttpCookie Cookie = System.Web.HttpContext.Current.Request.Cookies[strName]; if (Cookie != null) { return Cookie.Value.ToString(); } else { return null; } } /// <summary> /// 删除Cookies /// </summary> /// <param name="strName">主键</param> /// <returns></returns> public bool delCookie(string strName) { try { HttpCookie Cookie = new HttpCookie(strName); //Cookie.Domain = ".xxx.com";//当要跨域名访问的时候,给cookie指定域名即可,格式为.xxx.com Cookie.Expires = DateTime.Now.AddDays(-1); System.Web.HttpContext.Current.Response.Cookies.Add(Cookie); return true; } catch { return false; } } }
注:Cookieが中国語で文字化けした場合、Cookie.setCookie("name ", Server.UrlEncode("aaa"),1)、読み取り時にデコードするだけです
さらに: Cookie の有効期限が設定されていない限り、Cookie はブラウザーの有効期限が切れたときに自動的に期限切れになります。閉店しました
以上がC#でのCookieの読み込み例を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。