欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

asp.net各种cookie代码和解析实例

程序员文章站 2024-02-27 12:14:33
cookie是一段文本信息,在客户端存储 cookie 是 asp.net 的会话状态将请求与会话关联的方法之一。cookie 也可以直接用于在请求之间保持数据,但数据随后...

cookie是一段文本信息,在客户端存储 cookie 是 asp.net 的会话状态将请求与会话关联的方法之一。cookie 也可以直接用于在请求之间保持数据,但数据随后将存储在客户端并随每个请求一起发送到服务器。浏览器对 cookie 的大小有限制,因此,只有不超过 4096 字节才能保证被接受。

编写cookie

复制代码 代码如下:

//方式1:
response.cookies["username"].value="mike";
response.cookies["username"].expires=datetime.maxvalue;

//方式2:
httpcookie acookie = new httpcookie("last");
acookie.value="a";
acookie..expires=datetime.maxvalue;
response.cookies.add(acookie);


//方式1:
response.cookies["userinfo1"]["name"].value="mike";
response.cookies["userinfo1"]["last"].value="a";
response.cookies["userinfo1"].expires=datetime.maxvalue;

//方式2:
httpcookie cookie = new httpcookie("userinfo1");
cookie.values["name"]="mike";
cookie.values["last"]="a";
cookie.expires=datetime.maxvalue;
//cookie.expires = system.datetime.now.adddays(1);//设置过期时间  1天
response.cookies.add(cookie);

读取cookie
internet explorer 将站点的 cookie 保存在文件名格式为 <user>@<domain>.txt 的文件中,其中 <user> 是您的帐户名。
注意:在获取cookie的值之前,应该确保该 cookie 确实存在。否则,您将得到一个异常

复制代码 代码如下:

if (request.cookies["username"]!=null)
{
  string str = request.cookies("username").value;
}

//多值cookie的读取
if ( request.cookies["userinfo1"]!=null )
{
  string name=request.cookies["userinfo1"]["name"];
  string last=request.cookies["userinfo1"]["last"];
}


//读取 cookie 集合
for(int i = 0 ;i<request.cookies.count ;i++)
{
    httpcookie cookies = request.cookies;
    response.write("name="+cookies.mame+"<br/>");
    if (cookies.haskeys )//是否有子键
    {
        system.collections.specialized.namevaluecollection namecoll
                                             = acookie.values ;
        for(int j=0;j<namecoll.count;j++)
        {
            response.write("子键名="+ namecoll.allkey[j] +"<br/>");
            response.write("子键值="+ namecoll[j] +"<br/>");
        }

    }
    else
    {
        response.write("value="+cookies.value+"<br/>");       
    }
}

运行此代码时,可看到一个名为“asp.net_sessionid”的cookie,asp.net用这个 cookie 来保存您的会话的唯一标识符。

修改 cookie
修改的方法与创建方法相同

删除 cookie
将其有效期设置为过去的某个日期。当浏览器检查 cookie 的有效期时,就会删除这个已过期的 cookie。

复制代码 代码如下:

httpcookie cookie = new httpcookie("userinfo1");
cookie.expires=datetime.now.adddays(-30);
response.cookies.add(cookie);


修改cookie
 response.cookies["info"]["user"] = "2";
 response.cookies["info"].expires = datetime.now.adddays(1);        //删除cookie下的属性


 httpcookie acookie=request.cookies["info"];
 acookie.values.remove("userid");
 acookie.expires = datetime.now.adddays(1);
 response.cookies.add(acookie);        //删除所有cookie,就是设置过期时间为现在就行了


 int limit=request.cookies.count - 1;
 for(int i=0;i<limit;i++)
 {
     acookie = request.cookies(i)
     acookie.expires = datetime.now.adddays(-1)
     response.cookies.add(acookie)
 }   

如果有主站及二级域名站且cookie要共享的话则要加入如下设置

复制代码 代码如下:

cookie.domain = ".主域名";//例如.keleyi.com
cookie.path = "/";

cookie.expires adddays(-1)是立即过期