- 44浏览
- 2022-09-09
下面使用静态方法调用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生存期限就到你关闭浏览器为止
版权声明:
1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。
2、本站仅提供信息发布平台,不承担相关法律责任。
3、若侵犯您的版权或隐私,请联系本站管理员删除。
4、本文由会员转载自互联网,如果您是文章原创作者,请联系本站注明您的版权信息。