C#创建cookie读写cookie

一、创建cookie

    HttpCookie cookie = new HttpCookie("UserInfo");//创建多值cookie
              cookie.Expires = DateTime.Now.AddDays(1);//设置cookie的失效时间为一天,如果不设置失效时间,cookie会在浏览器关闭即消失,不会保存本地文件
              cookie.Values["LoginName"] = txtusername.Text;

       cookie.Values["Pwd"] = txtusername.Text;

    这样创建了一个key为UserInfo的cookie,具有LoginName和Pwd两个属性。

    创建为cookie不要忘记添加cookie,否则是取不出来的

    Response.Cookies.Add(cookie);

注:如果使用response.Cookies创建cookie就不用写上一句代码了。

二、取cookie

    HttpCookie cookies = Request.Cookies["UserInfo"];//取cookie

    txtusername.Text = cookies.Values["LoginName"];//去cookie的LoginName属性 赋值给帐号文本框
    txtpass.Attributes.Add("value",cookies.Values["Pwd"]);//密码框不能直接赋值,使用添加属性可以赋值

 


 

cookie属性:

name字段:为一个cookie的名称。

value字段:为一个cookie的值。

domain字段:为可以访问此cookie的域名。

path字段:为可以访问此cookie的页面路径。 比如domain是abc.com,path是/test,那么只有/test路径下的页面可以读取此cookie。

expires 字段:为此cookie超时时间。若设置其值为一个时间,那么当到达此时间后,此cookie失效。不设置的话默认值是Session,意思是cookie会和session一起失效。当浏览器关闭(不是浏览器标签页,而是整个浏览器) 后,此cookie失效。

Size字段 :此cookie大小。

http字段  :cookie的httponly属性。若此属性为true,则只有在http请求头中会带有此cookie的信息,而不能通过document.cookie来访问此cookie。

secure字段 :设置是否只能通过https来传递此条cookie

在这里只写了简单的Cookie操作

设置Cookie

public void AddCookie()
{
//方法一:
HttpCookie Cookie1 = new HttpCookie("CookieName");
Cookie1.Expires
= DateTime.Now.AddDays(1);//设置过期时间 Cookie1.Values["key1"] = "Value1";
Cookie1.Values["key2"] = "Value2"; Response.Cookies.Add(Cookie1);
//响应一个Cookies
//方法二: Response.Cookies["CookieName"].Values["Key1"] = "Value1"; Response.Cookies["CookieName"].Values["Key2"] = "Value2";//存多值 Response.Cookies["CookieName"].Expires = DateTime.Now.AddDays(1);//设置过期时间
//方法三: HttpCookie cookie3 = new HttpCookie("CookieName"); DateTime dt = DateTime.Now; //获取当前时间 TimeSpan ts = new TimeSpan(0, 0, 1, 0, 0);//过期时间为1分钟 cookie3.Expires = dt.Add(ts);//设置过期时间 cookie3.Values.Add("Key1", "Value1"); cookie3.Values.Add("Key2", "Value2"); Response.AppendCookie(cookie3); //响应一个Cookies }

获取Cookie

public void ReadCookie()
{
//方法一:
HttpCookie cookies1 = Request.Cookies["CookieName"];
string Values1 = cookies1.Value;
//string Values 1= cookies.Values["Key"];//获取多值
//方法二:
string Values2 = Request.Cookies["CookieName"].Value;
//string Values2 = Request.Cookies["CookieName"].Values["Key"];//获取多值
//方法三:(获取多值)
string Values3 = Server.UrlDecode(Request.Cookies["CookieName"]["Key"]);
//System.Web.HttpContext.Current.Request.Cookies["CookieName"];//同Request.Cookies
}

修改Cookie

public void UpdateCookie()
{
//修改只需要重新给要修改的cookie赋值就行,这样旧的就会被覆盖掉。
//所以这里只写一种方法,更多请参考创建cookie
HttpCookie Cookie = Request.Cookies["CookieName"];
Cookie.Expires = DateTime.Now.AddDays(1);//设置过期时间
Cookie.Value = "Value";//设置值
Response.Cookies.Add(Cookie);//响应一个Cookies
}

删除Cookie

public void DeleteCookie()
{
//删除cookie只需修改的cookie的过期时间(expires)过去的时间即可
//所以这里只写一种方法,更多请参考创建cookie
HttpCookie Cookie = Request.Cookies["CookieName"];
Cookie.Expires = DateTime.Now.AddDays(-1);//设置过期时间
Response.Cookies.Add(Cookie);//响应一个Cookies
}
  •  注意:对Cookie进行操作时应先判断cookie不为空

  • 注意:当Cookie存中文出现乱码,则在存放时给中文编码,读取时解码即可,如Cookie.setCookie("name", Server.UrlEncode("Value"),1)

  • 注意:只要不给cookie设置过期时间,cookie在浏览器关闭的时候自动失效

 

posted @ 2021-10-13 10:31  清语堂  阅读(1155)  评论(0编辑  收藏  举报