Session的使用

下面使用静态方法调用Session;推荐使用$_SESSION(查看全部session),可以更好了解session的作用域

    //赋值
Session::set('name','s1');
//赋值think2作用域,set(‘名称’,‘值’,‘作用域’)
Session::set('name','s2','think2'); //判断当前作用域(think)是否赋值
echo Session::has('name');
//判断think2作用域是否赋值
echo Session::has('name','think2'); //取值,当前作用域(think)
echo Session::get('name');
//取值(think2作用域)
echo Session::get('name','think2'); // 二维数组,赋值(当前作用域)
Session::set('name2.item','thinkphp');
// 判断(当前作用域)是否赋值
Session::has('name2.item');
// 取值(当前作用域)
Session::get('name2.item'); //删除(当前作用域)
Session::delete('name');
//删除(think2作用域)
Session::delete('name','think2');
//清除(当前作用域)
Session::clear();
//清除(当前作用域)
Session::clear('think2'); echo '<pre>';
print_r($_SESSION);

函数助手调用Session

    // 赋值(当前作用域)
session('name', 'thinkphp');
echo $this->request->session('name'); // 赋值think作用域
session('name', 'thinkphp', 'think');
// 判断(当前作用域)是否赋值
echo session('?name');
// 取值(当前作用域)
echo session('name');
// 取值think作用域
echo session('name', '', 'think');
// 删除(当前作用域)
session('name', null);
// 清除session(当前作用域)
session(null);
// 清除think作用域
session(null, 'think'); echo "\n";
print_r($_SESSION);

设置有效时间:

    //方法一:application/index/config.php(全局设置)
'session' => [
'id' => '',
// SESSION_ID的提交变量,解决flash上传跨域
'var_session_id' => '',
// SESSION 前缀
'prefix' => 'index',
// 驱动方式 支持redis memcache memcached
'type' => '',
// 是否自动开启 SESSION
'auto_start' => true,
//过期时间 单位秒
'path'=>TEMP_PATH,//表示session保存在自己网站根目录中的runtime目录中
'expire'=>3600*24*30,//过期时间
], //方法二:控制器
session(array('user'=>$user,'expire'=>3600)); //方法三:控制器
Session::init([
'expire'=>60*60*12
]);
Session::set("token",$access_token);

注意: 如果expire => 0,则默认session的过期时间

Cookie的使用

下面使用静态方法调用Cookie;推荐使用$_COOKIE(查看全部cookie)

    //设置Cookie 有效期为 3600秒
Cookie::set('user_name','TPshop 团队',3600);
// 设置cookie 前缀为think_
Cookie::set('user_name','TPshop 老师',['prefix'=>'think_', 'expire'=>3600]);
// 支持数组
Cookie::set('Teacher',['zhang','wang','chen','peng']);
echo Cookie::get('user_name'); // 也支持使用Cookie类直接读取
echo "<br/>";
// 获取指定前缀的cookie值
echo Cookie::get('user_name','think_');
echo "<br/>";
// 建议的读取Cookie数据的方法是通过Request请求对象的cookie方法
echo $this->request->cookie('user_name');
echo "<br/>"; //判断
echo Cookie::has('user_name');
echo "<br/>";
//判断指定前缀的cookie值是否存在
echo Cookie::has('user_name','think_');
echo "<br/>"; //删除cookie
Cookie::delete('user_name');
// 删除指定前缀的cookie
Cookie::delete('user_name','think_'); // 清空
// 清空指定前缀的cookie
Cookie::clear('think_');

使用函数助手调用Cookie

    // 助手函数
// 初始化
cookie(['prefix' => 'think_', 'expire' => 3600]);
// 设置
cookie('name', 'value123', 3600);
// 判断
echo cookie('?name');
echo "<br/>";
// 获取
echo cookie('name');
echo "<br/>";
// 删除
cookie('name', null);
// 清除
cookie(null, 'think_');

设置有效时间:

//方法一:在控制器 cookie初始化
Cookie::init(['prefix'=>'think_','expire'=>3600,'path'=>'/']);
// 方法二:设置Cookie 有效期为 3600秒
Cookie::set('name','value',3600); //方法三:config.php设置
'cookie' => [
// cookie 名称前缀
'prefix' => '',
// cookie 保存时间
'expire' => 0,
// cookie 保存路径
'path' => '/',
// cookie 有效域名
'domain' => '',
// cookie 启用安全传输
'secure' => false,
// httponly设置
'httponly' => '',
// 是否使用 setcookie
'setcookie' => true,
],

注意:'expire' => 0,默认cookie的过期时间为关联浏览器

session或cookie无效

一般情况下session和cookie都有效的,但今天我遇到了session和cookie不能保存数据。

这种情况一般是config.php的设置的问题,下面让大家看看我发现的问题:

这里设置里有效域名x.com,但我当前的域名是ljt.com;知道问题就好解决,只要把有效域名改成ljt.com,或者domain => "" 什么都不写

总结

session:存放在服务器

cookie:存放在浏览器

Cookies生存期限就到你关闭浏览器为止

ThinkPHP5——Session和Cookie的更多相关文章

  1. 理解Session与Cookie

    写在前面的话:Session和Cookie是非常有意思的两个概念,对于两者的管理可以处理的很复杂,但是无论如何,理解Session和Cookie的基本概念和发明初衷,对于问题的解决,大有裨益. === ...

  2. PHP之session与cookie

    1.session与cookie的关系 众所周知,session是存储在服务器端,cookie是存储在客户端,如果禁用了浏览器的cookie功能,很多时候(除非进行了特殊配置)服务器端就无法再读取se ...

  3. 安全退出,清空Session或Cookie

    概览: 网站中点击退出,如果仅仅是重定向到登录/出页面,此时在浏览器地址栏中输入登录后的某个页面地址如主页,你会发现不用登录就能访问.这种所谓的退出并不是安全的. 那么怎样做到安全退出呢? 那就是点击 ...

  4. 11月7日上午PHP会话控制(session和cookie)、跨页面传值

    1.session  登录上一个页面以后,长时间没有操作,刷新页面以后需要重新登录. 特点:(1)session是存储在服务器:   (2)session每个人(登陆者)存一份: (3)session ...

  5. 【荐】PHP Session和Cookie,Session阻塞,Session垃圾回收,Redis共享Session,不推荐Memcached保存Session

    什么是 Session 在 web 应用开发中,Session 被称为会话.主要被用于保存某个访问者的数据. 由于 HTTP 无状态的特点,服务端是不会记住客户端的,对服务端来说,每一个请求都是全新的 ...

  6. Session与Cookie概念

    摘:一.Session机制session是一种服务器端的状态管理技术,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息.当程序需要为某个客户端的请求创建一个session的时候,服务 ...

  7. session和cookie

    第一次听到cookie这个词的时候着实兴奋了一段时间,以为是小饼干呢~快喝一杯82年的java压压惊!哈哈~ 与cookie的第一次邂逅——清缓存和清cookie 刚毕业的时候上班,做二次开发,明明后 ...

  8. 深入理解Session与Cookie

    Session与cookie的作用都是为了保持访问用户与后端服务器的交互状态. cookie通过把所有要保存的数据通过HTTP协议的头部从客户端传递到服务端,又从服务端再传回到客户端,所有的数据都存储 ...

  9. TP中的session和cookie

    session:1.session('name','value');  //设置session2.$value = session('name');  // 获取所有的session 3.2.2版本新 ...

随机推荐

  1. emacs考场短配置

    (set-background-color "gray15") (set-foreground-color "gray") ;;设置颜色 (global-set ...

  2. [考试反思]0810NOIP模拟测试16:黎明

    好吧,你尽力啦.我不说什么啦 []200 []180 [6]170 [7]160 [11]150 [12]140 还好,和前面的差距不大.虽说没有原来最好的那段时间考得那么好,但貌似还可以接受. 这次 ...

  3. CSPS模拟 47

    考试时T1没玩明白,用一个WA90把100盖住了? T1 Emotional Flutter 题目非常蠢萌,只是注意当你把黑块前伸s距离后,应把脚的长度视为0,而不应为1. T2 Endless Fa ...

  4. FastJson稍微使用不当就会导致StackOverflow

    GitHub 9.4k Star 的Java工程师成神之路 ,不来了解一下吗? GitHub 9.4k Star 的Java工程师成神之路 ,真的不来了解一下吗? GitHub 9.4k Star 的 ...

  5. csps模拟测试57

    T1 天空龙 大神题,考察多方面知识,例如:快读 附上考试代码,以供后人学习 应某迪要求,我决定多写一点. 正如文化课有知识性失分和非知识性失分一样,OI也同样存在. 但非知识性失分往往比知识性失分更 ...

  6. Jenkins+JMeter+Ant 接口持续集成

    ​JMeter安装 JMeter安装包: 下载地址:https://jmeter.apache.org/download_jmeter.cgi 依赖JDK环境 JDK环境配置: JAVA_HOME   ...

  7. Mybatis自定义TypeHandler解决特殊类型转换问题

    我们知道,Java和MySQL中的数据类型是不同的,Java中除了基本数据类型,还有对象. 有时候使用MySQL存储数据,或者从MySQL中读取数据时,会有一些特殊需求

  8. LeetCode18. 四数之和

    LeetCode18. 四数之和 给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c + d 的值 ...

  9. JS如何在不给新空间的情况下给数组去重?

    1.先排序,在让相邻元素对比去重 const nums = [3, 1, 1, 5, 2, 3, 4, 3, 5, 5, 6, 4, 6, 6, 6]; Array.prototype.arrayNo ...

  10. jQuery—— 选择器汇总

    jQuery里的选择器有3种: 元素选择器,id选择器, 类选择器:   $("div") // 选择所有<div>元素 $("#test") // ...