js和PHP关于cookie的设置

js及PHP关于cookie的获取、设置、删除

Cookie,有时也用其复数形式 Cookies。类型为“小型文本文件”,是某些网站为了辨别用户身份,进行Session跟踪而储存在用户本地终端上的数据(通常经过加密),由用户客户端计算机暂时或永久保存的信息 。Cookie是一段不超过4KB的小型文本数据,由一个名称(Name)、一个值(Value)和其它几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。下面介绍js和PHP关于cookie的一些操作。

js获取cookie

document.cookie//获取到当前浏览器的所有cookie

js设置cookie

document.cookie = "name = 张三";//设置cookie给cookie赋值,值是键值对的形式,cookie可以设置多个不会覆盖,但是当cookie的名字相同时会覆盖。
//cookie是存在浏览器上,浏览器为了保持自己的效率,默认情况下,会给cookie设置一个有效期,有效期是会话级别也就是当浏览器关闭的时候就失效了
var date = new Date();
var date = dade.getTime()+5*1000-8*3600*1000;//时间日期对象必须使用世界标准时间,所以要加上本地时间的时差
var date2 = new Date(date1);
document.cookie = "name = 张三;expires="+date2;//给cookie设置有效期,有效期为5秒

js删除cookie

document.cookie = "name = 张三";
var date = new Date();
var date = dade.getTime()-5*1000-8*3600*1000;//删除cookie其实就是将cookie的有效期设置为过期的时间
var date2 = new Date(date1);
document.cookie = "name = 张三;expires="+date2;

js中cookie操作的注意事项

1、cookie必须是分域名存储的,也就是说在当前域名下设置的cookie只能在当前域名下获取。
2、cookie存储是按照键值对的形式存储的。
3、在同一个浏览器上cookie可以在当前页面设置,别的页面访问,跨文件访问的。
4、设置cookie有效期时,时间日期对象必须使用世界标准时间。
5、默认情况下cookie的有效期是会话级别也就是当浏览器关闭的时候就失效了。

js中cookie操作的封装

/**
 * 获取cookie的函数
 * @param {1} key 将要获取的cookie的键
 */
function getCookie(key){
    // 先获取所有cookie
    var cookies = document.cookie;
    // 通过 ;  将所有cookie分割
    var arr = cookies.split("; ");
    // 遍历这个数组 
    var length = arr.length;
    for(var i=0;i<length;i++){
        // 通过 =  分割每一个元素
        var brr = arr[i].split("=");
        // 判断第一个元素是否和key相等
        if(brr[0]===key){
            // 将第二个元素返回
            return brr[1];
        }
    }
}
/**
 * 设置cookie的函数
 * @param {1} key 要设置的cookie的键
 * @param {2} value 要设置的cookie的值
 * @param {3} seconds 要设置的cookie的有效期   多少秒之后
 * @param {4} path 要设置的cookie有效的路径
 */
function setCookie(key,value,seconds=0,path="/"){
    if(seconds==0){
        document.cookie = key + "=" + value + ";path="+path;
    }else{
        var date = new Date(+new Date()-8*3600*1000+seconds*1000);
        document.cookie = key + "=" + value + ";expires="+date+";path="+path;
    }
    
}
/**
 * 删除cookie的方法
 * @param {1} key 将要删除的cookie的键
 * @param {2} path 将要删除的cookie的有效路径
 */
function removeCookie(key,path="/"){
    setCookie(key,null,-1,path);
}

PHP获取cookie

<?php
$res = $_COOKIE['name'];
?>

PHP设置cookie

<?php
setcookie('name','张三', time()+60);//time()获取的是当前时间,+60表示从当前时间往后60秒
?>

PHP删除cookie

<?php
setcookie("name", "" , time()-1);//就是设置cookie的有效期,将有效期设置为过期的时间
?>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值