cookie的三种操作方法
1,jquery.cookie.js
这一篇文章已经写的很详细了:
http://www.cnblogs.com/afuge/archive/2013/07/03/3169048.html
2,原生js操作cookie
jquery.cookie.js一般会出现cookie不兼容问题就要用原生的js了
<script language=javascript>
//获得coolie 的值
function cookie(name){
var cookieArray=document.cookie.split(
"; "
);
//得到分割的cookie名值对
var cookie=
new
Object();
for
(var i=
0
;i<cookieArray.length;i++){
var arr=cookieArray[i].split(
"="
);
//将名和值分开
if
(arr[
0
]==name)
return
unescape(arr[
1
]);
//如果是指定的cookie,则返回它的值
}
return
""
;
}
function delCookie(name)
//删除cookie
{
document.cookie = name+
"=;expires="
+(
new
Date(
0
)).toGMTString();
}
function getCookie(objName){
//获取指定名称的cookie的值
var arrStr = document.cookie.split(
"; "
);
for
(var i =
0
;i < arrStr.length;i ++){
var temp = arrStr[i].split(
"="
);
if
(temp[
0
] == objName)
return
unescape(temp[
1
]);
}
}
function addCookie(objName,objValue,objHours){
//添加cookie
var str = objName +
"="
+ escape(objValue);
if
(objHours >
0
){
//为时不设定过期时间,浏览器关闭时cookie自动消失
var date =
new
Date();
var ms = objHours*
3600
*
1000
;
date.setTime(date.getTime() + ms);
str +=
"; expires="
+ date.toGMTString();
}
document.cookie = str;
}
function SetCookie(name,value)
//两个参数,一个是cookie的名子,一个是值
{
var Days =
30
;
//此 cookie 将被保存 30 天
var exp =
new
Date();
//new Date("December 31, 9998");
exp.setTime(exp.getTime() + Days*
24
*
60
*
60
*
1000
);
document.cookie = name +
"="
+ escape (value) +
";expires="
+ exp.toGMTString();
}
function getCookie(name)
//取cookies函数
{
var arr = document.cookie.match(
new
RegExp(
"(^| )"
+name+
"=([^;]*)(;|$)"
));
if
(arr !=
null
)
return
unescape(arr[
2
]);
return
null
;
}
function delCookie(name)
//删除cookie
{
var exp =
new
Date();
exp.setTime(exp.getTime() -
1
);
var cval=getCookie(name);
if
(cval!=
null
) document.cookie= name +
"="
+cval+
";expires="
+exp.toGMTString();
}
</script>
3,服务器端处理
/// <summary>
/// 将点击的值存放到Cookie中
/// </summary>
private void SetCookieValue(HttpContext context, string dic, string cookieName, string keyName)
{
HttpCookie cookie = new HttpCookie(cookieName);//初使化并设置Cookie的名称
if (context.Request.Cookies[cookieName] != null)
{
cookie = context.Request.Cookies[cookieName];
if (cookie.Values.Count > 0 && cookie.Values.GetValues(keyName) != null && cookie.Values.GetValues(keyName).Length > 0)
{
Remove(cookieName, keyName);
}
}
TimeSpan ts = new TimeSpan(0, 3, 0, 0, 0);//过期时间为3小时
cookie.Expires = DateTime.Now.Add(ts);//设置过期时间
cookie.Values.Add(keyName, dic);
context.Response.AppendCookie(cookie);
//NCookieUtil.SetCookie(keyName, dic);
}
/// <summary>
/// 将点击的值从Cookie中取出
/// </summary>
public string GetClickValue(HttpContext context, string cookieName, string keyName)
{
string userName = "";
if (context.Request.Cookies[cookieName] != null)
{
if (context.Request.Cookies[cookieName][keyName] != null)
{
userName = context.Request.Cookies[cookieName][keyName].ToString();
}
}
//userName = NCookieUtil.GetCookie(keyName);
return userName;
}
/// <summary>
/// 移除cookie中指定的键,若是最后一个键则移除这个cookie
/// </summary>
public static void Remove(string cookieName, string keyName)
{
HttpCookie cookie = HttpContext.Current.Request.Cookies[cookieName];
if (cookie != null)
{
if (cookie.Values.Count > 0)
{
if (cookie.Values.Count == 1)
{
//若是最后一个键则移除这个cookie,否则会多出一个空值
cookie.Values.Remove(HttpUtility.UrlEncode(keyName));
cookie.Expires = DateTime.Now.AddDays(-1);
}
else
{
cookie.Values.Remove(HttpUtility.UrlEncode(keyName));
}
HttpContext.Current.Response.Cookies.Add(cookie);
}
}
}
其实这三种方法还是建议用第二种方法!
cookie的三种操作方法的更多相关文章
- postman传入cookie的三种方式
1.直接在环境变量里面设置 2.在登录接口的tests,把返回值的cookie设置为全局变量 3.直接在cookie里面传入
- Django-多对多关系的三种创建方式-forms组件使用-cookie与session-08
目录 表模型类多对多关系的三种创建方式 django forms 组件 登录功能手写推理过程 整段代码可以放过来 forms 组件使用 forms 后端定义规则并校验结果 forms 前端渲染标签组件 ...
- 三种urllib实现网页下载,含cookie模拟登陆
coding=UTF-8 import re import urllib.request, http.cookiejar, urllib.parse # # print('-------------- ...
- 多对多的三种创建方式-forms相关组件-钩子函数-cookie与session
多对多的三种创建方式 1.全自动(推荐使用的**) 优势:第三张可以任意的扩展字段 缺点:ORM查询不方便,如果后续字段增加更改时不便添加修改 manyToManyField创建的第三张表属于虚拟的, ...
- 转:三种状态对象的使用及区别(Application,Session,Cookie)
Application状态对象 Application 对象是HttpApplication 类的实例,将在客户端第一期从某个特定的ASP.NET应用程序虚拟目录中请求任何URL 资源时创建.对于We ...
- ASP.NET Core应用的错误处理[1]:三种呈现错误页面的方式
由于ASP.NET Core应用是一个同时处理多个请求的服务器应用,所以在处理某个请求过程中抛出的异常并不会导致整个应用的终止.出于安全方面的考量,为了避免敏感信息的外泄,客户端在默认的情况下并不会得 ...
- 通过三个DEMO学会SignalR的三种实现方式
一.理解SignalR ASP .NET SignalR 是一个ASP .NET 下的类库,可以在ASP .NET 的Web项目中实现实时通信(即:客户端(Web页面)和服务器端可以互相实时的通知消息 ...
- WEB项目会话集群的三种办法
web集群时session同步的3种方法 在做了web集群后,你肯定会首先考虑session同步问题,因为通过负载均衡后,同一个IP访问同一个页面会被分配到不同的服务器上, 如果session不同步的 ...
- Linux就这个范儿 第15章 七种武器 linux 同步IO: sync、fsync与fdatasync Linux中的内存大页面huge page/large page David Cutler Linux读写内存数据的三种方式
Linux就这个范儿 第15章 七种武器 linux 同步IO: sync.fsync与fdatasync Linux中的内存大页面huge page/large page David Cut ...
随机推荐
- 【BZOJ】1124: [POI2008]枪战Maf
题意 \(n(n < 1000000)\)个人,每个人\(i\)指向一个人\(p_i\),如果轮到\(i\)了且他没死,则他会将\(p_i\)打死.求一种顺序,问死的人最少和最多的数目. 分析 ...
- POJ 1473 There's Treasure Everywhere!
题目链接 小小的模拟一下. #include <cstdio> #include <cstring> #include <string> #include < ...
- 【Oracle】悲观锁和乐观锁
悲观锁 如select * for update 悲观锁大多数情况下依靠数据库的锁机制实现,以保证操作最大程度的独占性.但随之而来的就是数据库性能的大量开销,特别是对长事务而言,这样 ...
- Node.js前端自动化工具:gulp
前端自动化工具 -- gulp 使用简介 gulp是基于流的前端自动化构建工具. 之前也谈到了 grunt的用法,grunt其实就是配置+配置的形式. 而gulp呢,是基于stream流的形式,也就是 ...
- 这世上倒底有没有神仙——说“Excel不是数据库,是不是犯了白马非马论的错误??
这问题是这样引出来的: 我上计算机应用基础课,讲到Excel,因为一直以来,很多新生对Word中的表格和Excel中的表格总是分不清,甚至有老师也问过我,Excel中的表格和Word中的表格有什么区别 ...
- OpenCV 3.1 VS 2010 Cuda 7.5 TBB Configuration 配置
Download OpenCV 3.1 Download OpenCV Extra Modules Download VS2010 Download CMake 3.2.0 Download Cuda ...
- vim operation
note: 转自 www.quora.com ,很好的网站. 具体链接如下: https://www.quora.com/What-are-some-impressive-demos-of-Vim- ...
- 百度ueditor代码高亮显示
<script type="text/javascript" charset="utf-8" src="ueditor1_4_3-utf8-ph ...
- c#面向对象基础 重写、虚方法、抽象类
虚方法 抽象类与抽象方法 1.书写规范: 在类前面加上abstract关键字,就成为了抽象类:在一个方法前面加上abstract关键字,就成为了抽象方法(抽象方法不能有实现方法,直接在后面加分号) 例 ...
- static静态结合&符号理解
上代码,方法定义为静态变量 <?php function &test(){ static $c=222; return $c; } $a=&test(); echo $a; ec ...