本文实例讲述了Yii框架中用response保存cookie,用request读取cookie的原理。分享给大家供大家参考,具体如下:
在学习cookie的时候,相信很多人和我有一样的疑惑?为什么保存cookie要用response,读取cookie却用request呢?
参考https://www.imooc.com/qadetail/188079
cookie是web服务器为了保存一些用户数据而创建保存在本地的一个加密文件,这些过程是由服务器操作,所以使用response。读取cookie数据是客户端行为,所以用request。这样理解可能好一点。
再者
Request.Cookies
创建的Cookie只能用于后台不能用于HTML的前台
Response.Cookies
操作过的Cookie,所有方法获取到的都是被更新过的值,也就是说Response.Cookies
是修改所有容器中的Cookie的值;
如果还是不太明白,我们可以通过实践,使用request->cookies
删除一个cookie数据。
$cookies = \Yii::$app->response->cookies;
$array_cookies=array('name'=>'user','value'=>'doubly');
$cookies->add(new Cookie($array_cookies));
$cookies = \Yii::$app->request->cookies;
$cookies->remove('user');
echo $cookies->getValue("user");
访问网页可以发现Yii框架报错
简单的说,request->cookies
不能对cookie数据进行修改等操作。
更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
您可能感兴趣的文章:- 解析PHP的Yii框架中cookie和session功能的相关操作
- Yii2.0中的COOKIE和SESSION用法
- Yii框架操作cookie与session的方法实例详解
- Yii框架学习笔记之session与cookie简单操作示例
- yii操作session实例简介
- Yii框架用户登录session丢失问题解决方法
- Yii2下session跨域名共存的解决方案
- yii操作cookie实例简介
- Yii中的cookie的发送和读取
- YII2自动登录Cookie总是失效的解决方法
- Yii2中cookie用法示例分析
- Yii框架Session与Cookie使用方法示例