转 通过js获取cookie的实例及简单分析
今天review新人写的javascript代码的时候发现了很多的问题。这里以function getCookie(name){}为例。
其中比较典型的一个问题就是如何通过javascript获取cookie里面的一个值。 那么我们先来看看cookie到底长什么样子呢?
直接在浏览器地址栏输入: javascript:alert(document.cookie); 回车。(这行代码的意思是,让浏览器执行javascript语句: alert(document.cookie);)
结果是:uin=webryan; sessionid=10293123834; pgv_send=1; cur_page=index
这个样子。
注意:1.开始没有空格,2.分号后又空格 3.最后没有分号。那么我们获取cookie的方法就比较明确了。。
一种是用document.cookie.split(“; “)的方式把字符串分割成几个段,然后遍历整个数组。 把每个数组单元等号左边的和name对比是否相等,相等则取等号右边的值。
- function getCookie(name){
- var arr = document.cookie.split("; ");
- for(var i=0,len=arr.length;i<len;i++){
- var item = arr[i].split("=");
- if(item[0]==name){
- return item[1];
- }
- }
- return "";
- }
- function getCookie(name){
- var arr = document.cookie.split("; ");
- for(var i=0,len=arr.length;i<len;i++){
- var item = arr[i].split("=");
- if(item[0]==name){
- return item[1];
- }
- }
- return "";
- }
第二种就是直接在字符串中搜索关键字。由于分号有空格,加上防止出现搜索cookie name为“str”的value是,有一个test_str的cookie名称。这里我们先进行一次过滤。 然后在找到 ;str的位置,这样就不会出问题。具体情况如下
- function getCookie(name){
- var value="";
- var cookie = ";"+document.cookie.replace(/;\s+/g,";")+";"
- var pos = cookie.indexOf(";"+name+"=");
- if(pos>-1){
- var start = cookie.indexOf("=",pos);
- var end = cookie.indexOf(";",start);
- value = unescape(cookie.substring(start+1,end));
- }
- return value;
- }
- function getCookie(name){
- var value="";
- var cookie = ";"+document.cookie.replace(/;\s+/g,";")+";"
- var pos = cookie.indexOf(";"+name+"=");
- if(pos>-1){
- var start = cookie.indexOf("=",pos);
- var end = cookie.indexOf(";",start);
- value = unescape(cookie.substring(start+1,end));
- }
- return value;
- }
不同方法在不同时刻有不同的选择。 这个就是晓晓说的选型问题。
现在实际使用的代码是
- /**
- * cookie相关
- */
- $.cookie = {
- /**
- * 读取cookie
- *
- * @param {String} n=名称
- * @return {String} cookie值
- * @example
- * $.cookie.get('id_test');
- */
- get:function(n){
- var m = document.cookie.match(new RegExp( "(^| )"+n+"=([^;]*)(;|$)"));
- return !m ? "":unescape(m[2]);
- },
- /**
- * 设置cookie
- * @param {String} name cookie名称 --必填
- * @param {String} value cookie值 --必填
- * @param {String} domain 所在域名
- * @param {String} path 所在路径
- * @param {Number} hour 存活时间,单位:小时
- * @example
- * $.cookie.set('value1','cookieval',"id.qq.com","/test",24); //设置cookie
- */
- set:function(name,value,domain,path,hour){
- var expire = new Date();
- expire.setTime(expire.getTime() + (hour?3600000 * hour:30*24*60*60*1000));
- document.cookie = name + "=" + value + "; " + "expires=" + expire.toGMTString()+"; path="+ (path ? path :"/")+ "; " + (domain ? ("domain=" + domain + ";") : "");
- },
- /**
- * 删除指定cookie,复写为过期 !!注意path要严格匹配, /id 不同于/id/
- *
- * @param {String} name cookie名称
- * @param {String} domain 所在域
- * @param {String} path 所在路径
- * @example
- * $.cookie.del('id_test'); //删除cookie
- */
- del : function(name, domain, path) {
- document.cookie = name + "=; expires=Mon, 26 Jul 1997 05:00:00 GMT; path="+ (path ? path :"/")+ "; " + (domain ? ("domain=" + domain + ";") : "");
- },
- /**
- * 删除所有cookie -- 这里暂时不包括目录下的cookie
- * @example
- * $.cookie.clear(); //删除所有cookie
- */
- clear:function(){
- var rs = document.cookie.match(new RegExp("([^ ;][^;]*)(?=(=[^;]*)(;|$))", "gi"));
- // 删除所有cookie
- for (var i in rs){
- document.cookie = rs[i] + "=;expires=Mon, 26 Jul 1997 05:00:00 GMT; path=/; " ;
- }
- },
- /**
- * uin -- 针对业务,对外开源请删除
- *
- * @return {String} uin值
- * @example
- * $.cookie.uin();
- */
- uin:function(){
- var u = $.cookie.get("uin");
- return !u?null:parseInt(u.substring(1, u.length),10);
- }
- };
转 通过js获取cookie的实例及简单分析的更多相关文章
- 通过js获取cookie的实例及简单分析
今天碰到一个在firefox下swfupload 上传时session不一致问题 在一个项目遇到多文件上传时,firefox下,服务器端的session获取不一致问题. 解决办法: 解决办法:将ses ...
- 简单利用XSS获取Cookie信息实例演示
简单利用XSS获取Cookie信息实例演示 首先要找到一个有XXS的站,这里就不整什么大站了,谷歌一下inurl:'Product.asp?BigClassName',搜出来的命中率也比较高.随便 ...
- js获取cookie
js获取cookie 之前用jQuery.cookie来获取cookie,虽然简单,但是项目上又多引用了一个插件,总觉得不太好,下面是我封装的js原生获取cookie的函数. function get ...
- node.js获取cookie
node.js 获取cookie var Cookies ={}; if (req.headers.cookie != null) { req.headers.cookie.split(';').fo ...
- js获取cookie数据并发送给服务端
js获取cookie数据并发送给服务端 <!DOCTYPE html> <html lang="en"> <head> <meta cha ...
- js获取cookie中存储的值
最近看了试卷题目发现自己会的十分的匮乏, 第一题就把自己难住了,知道有这个东西,但是实际上没有操作过. ========================================= cookie ...
- js获取cookie提取用户名asp.net+html
JavaScript是运行在客户端的脚本,因此一般是不能够设置Session的,因为Session是运行在服务器端的. 而cookie是运行在客户端的,所以可以用JS来设置cookie. 假设有这样一 ...
- js封装Cookie操作 js 获取cookie js 设置cookie js 删除cookie
每天学习一点点 编程PDF电子书.视频教程免费下载:http://www.shitanlife.com/code var CookieUtil = { // 设置cookie set : functi ...
- 用js获取cookie
//获取cookiefunction cookie_email(cookie_name){ var cookiestr = document.cookie; if (cookiestr.length ...
随机推荐
- iOS - OC NSStream 文件流
前言 @interface NSStream : NSObject @interface NSOutputStream : NSStream 1.文件流的使用 NSString *filePath = ...
- 解决JSP路径问题的方法(jsp文件开头path, basePath作用)
原文:http://blog.csdn.net/mingxunzh/article/details/4627185 在JSP中的如果使用 "相对路径" 则有可能会出现问题. 因为 ...
- linux笔记:shell编程-正则表达式
正则表达式与通配符(正则表达式匹配字符串,是包含匹配:通配符匹配文件名,是完全匹配.): 基础正则表达式: 正则表达式示例:
- 20150514Linux下rpm包安装错误及解决方案
(1)用rpm -ivh ***.rpm解压RedHat自带boost出现错误如下: warning: /media/RHEL_6.3 i386 Disc 1/Packages/boost-1.41. ...
- 解决ajax中文乱码问题
主要遇到的问题: 一.ajax向服务器提交的数据有中文,没有设置编码方式.造成服务器接收到乱码 二.服务器向ajax返回数据中有中文,没有设置响应编码方式,造成ajax接收到乱码 乱码产生的原因:不管 ...
- JavaWeb chapeter 5 Web应用程序状态管理
1. HTTP协议使用的是无状态连接,对容器而言,每一个请求都来自于一个新的客户. 2. html表单隐藏字段:对用户在网站上的访问进行会话跟踪.为服务器端程序提供预定义的输入.存储动态产生的页面上 ...
- [强连通分量] POJ 1236 Network of Schools
Network of Schools Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 16803 Accepted: 66 ...
- Gridview布局界面练习Simple Adapter
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZcAAAJcCAIAAAC6w36wAAAgAElEQVR4nOy953YbS5KuvVsiTFWlz6
- My Game --简介
曾经 我们雄心壮志,曾经 我们慷慨激昂,曾经 我们豪情满天涯. 曾经我们一起策划玩法,寻找背景题材,编写代码,幻想没有的更新.此刻由最后的孤狼把仅有成果分享给大伙. 所谓的玩法,背景,每个游戏都与众不 ...
- ROS 使用自带和usb摄像头获取图像
笔记本自带的摄像头的设备号一般为/dev/video0 第一步:安装Webcam 驱动 $ sudo apt-get install git-core $ cd ~/catkin_ws/src $ g ...