YII中session和cookie

简介:

一,在Yii中使用session 
与原生态php5的session使用差别是,php5使用session_start();$_session['key'] = $value; 
在yii中,session已经被封装。不需要start,但需要new一个session对象。

Java代码   收藏代码
  1. /***** 方式一、实例添加 *****/  
  2. $session=new CHttpSession;  
  3. $session->open();  
  4. $value1=$session['name1'];  
  5.   
  6. /***** 方式二、直接调用应用添加 *****/  
  7. Yii::app()->session->add('name','foobar');  
  8. Yii::app()->session->add('name2','foobar');  
  9. Yii::app()->session->add('name3','foobar');  
  10. //或者  
  11. $session = Yii::app()->session;  
  12. $session['key'] = 'value';  
  13. var_dump($session['key']);  
  14.    
  15. //遍历  
  16. foreach($session as $name=>$value)  

一个实例

Java代码   收藏代码
  1. $session = new CHttpSession;  
  2. $session->open();  
  3.           
  4. $user_id = $this->user->id;  
  5. $sessionKey = $user_id.'_is_sending';  
  6.           
  7. if(isset($session[$sessionKey])){  
  8.     $first_submit_time = $session[$sessionKey];  
  9.     $current_time      = time();  
  10.     if($current_time - $first_submit_time < 10){  
  11.         $session[$sessionKey] = $current_time;  
  12.         $this->response(array('status'=>1'msg'=>'不能在10秒钟内连续发送两次。'));  
  13.     }else{  
  14.         unset($session[$sessionKey]);//超过限制时间,释放session";  
  15.     }  
  16. }  
  17.   
  18. //第一次点击确认按钮时执行  
  19. if(!isset($session[$sessionKey])){  
  20.     $session[$sessionKey] = time();  
  21. }  
  22.           
  23. var_dump($sessionKey);var_dump($session[$sessionKey]);exit();  

二,在Yii中使用cookie 
Yii实现了一个cookie验证机制,可以防止cookie被修改 。启用之后可以对cookie的值进行HMAC检查。 
Cookie验证在默认情况下是禁用的。如果你要启用它,可以编辑应用配置中的组件中的CHttpRequest部分。 

一定要使用经过Yii验证过的cookie数据。使用Yii内置的cookies组件来进行cookie操作,不要使用$_COOKIES。 
实例:

Java代码   收藏代码
  1. // 检索一个名为$name的cookie值   
  2. $cookie=Yii::app()->request->cookies[$name];   
  3. $value=$cookie->value;   
  4. ......   
  5. // 设置一个cookie   
  6. $cookie=new CHttpCookie($name,$value);   
  7. Yii::app()->request->cookies[$name]=$cookie;   

 

Java代码   收藏代码
  1. 'components'=>array(  
  2.     'user'=>array(  
  3.         //'class'=>'CWebUser',//你可以自定义你的Cwebuser  
  4.         'identityCookie'=>array('domain' => '.domain.cc','path' => '/'),//配置用户cookie作用域  
  5.         // enable cookie-based authentication  
  6.         'allowAutoLogin'=>true,//有多个分站时,同步登陆  
  7.         'stateKeyPrefix'=>'yourprefix',//你的前缀,必须指定为一样的  
  8.         'loginUrl'=>array('/user/login'),  
  9.     ),  
  10.     'session' => array(  
  11.         'cookieParams' => array('domain' => '.domain.cc''lifetime' => 0),//配置会话ID作用域 生命期和超时  
  12.         'timeout' => 3600,  
  13.         //这里千万不要指定cookieMode => none,否则无法对应sessionid导致无法登录,更别说同步了。(有些不负责的博客竟然说同步登录需要设定这个属性为none!!!!太坑爹了。。。)  
  14.     ),   
  15.     'statePersister'=>array( //指定cookie加密的状态文件  
  16.         'class'=>'CStatePersister',//指定类       
  17.         'stateFile'=>'../CommonLib/protected/runtime/state.bin',//配置通用状态文件路径,注意,如果你的站点是分布式的,你必须把该文件复制一份到不同服务器上,否则无法跨域。因为里面有个通用密钥,密钥不同则无法验证身份。  
  18.     ),  

 将session保持在数据库的设置:

Java代码   收藏代码
  1. 'session' => array (  
  2.     'class' => 'system.web.CDbHttpSession',  
  3.     'connectionID' => 'db',  
  4.     //'sessionTableName' => 'YiiSession',  
  5. ),  

 

相关文章
|
1月前
|
存储 安全 搜索推荐
理解Session和Cookie:Java Web开发中的用户状态管理
理解Session和Cookie:Java Web开发中的用户状态管理
58 4
|
1月前
|
存储 缓存 网络协议
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点,GET、POST的区别,Cookie与Session
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点、状态码、报文格式,GET、POST的区别,DNS的解析过程、数字证书、Cookie与Session,对称加密和非对称加密
|
2月前
|
缓存 Java Spring
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
文章比较了在Servlet和Spring Boot中获取Cookie、Session和Header的方法,并提供了相应的代码实例,展示了两种方式在实际应用中的异同。
187 3
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
|
2月前
|
存储 安全 数据安全/隐私保护
Cookie 和 Session 的区别及使用 Session 进行身份验证的方法
【10月更文挑战第12天】总之,Cookie 和 Session 各有特点,在不同的场景中发挥着不同的作用。使用 Session 进行身份验证是常见的做法,通过合理的设计和管理,可以确保用户身份的安全和可靠验证。
25 1
|
3月前
|
存储 缓存 数据处理
php学习笔记-php会话控制,cookie,session的使用,cookie自动登录和session 图书上传信息添加和修改例子-day07
本文介绍了PHP会话控制及Web常用的预定义变量,包括`$_REQUEST`、`$_SERVER`、`$_COOKIE`和`$_SESSION`的用法和示例。涵盖了cookie的创建、使用、删除以及session的工作原理和使用,并通过图书上传的例子演示了session在实际应用中的使用。
php学习笔记-php会话控制,cookie,session的使用,cookie自动登录和session 图书上传信息添加和修改例子-day07
|
3月前
|
存储 前端开发 Java
JavaWeb基础7——会话技术Cookie&Session
会话技术、Cookie的发送和获取、存活时间、Session钝化与活化、销毁、用户登录注册“记住我”和“验证码”案例
JavaWeb基础7——会话技术Cookie&Session
|
3月前
|
存储 安全 NoSQL
Cookie、Session、Token 解析
Cookie、Session、Token 解析
65 0
|
4月前
|
存储 JavaScript 前端开发
Cookie 反制策略详解:Cookie加解密原理、Cookie和Session机制、Cookie hook、acw_sc__v2、jsl Cookie调试、重定向Cookie
Cookie 反制策略详解:Cookie加解密原理、Cookie和Session机制、Cookie hook、acw_sc__v2、jsl Cookie调试、重定向Cookie
250 1
|
4月前
|
存储 安全 搜索推荐
【JavaWeb 秘籍】Cookie vs Session:揭秘 Web 会话管理的奥秘与实战指南!
【8月更文挑战第24天】本文以问答形式深入探讨了Web开发中关键的会话管理技术——Cookie与Session。首先解释了两者的基本概念及工作原理,随后对比分析了它们在存储位置、安全性及容量上的差异。接着,通过示例代码详细介绍了如何在JavaWeb环境中实现Cookie与Session的操作,包括创建与读取过程。最后,针对不同应用场景提供了选择使用Cookie或Session的指导建议,并提出了保障二者安全性的措施。阅读本文可帮助开发者更好地理解并应用这两种技术。
72 1
|
4月前
|
C# 开发者 Windows
WPF遇上Office:一场关于Word与Excel自动化操作的技术盛宴,从环境搭建到代码实战,看WPF如何玩转文档处理的那些事儿
【8月更文挑战第31天】Windows Presentation Foundation (WPF) 是 .NET Framework 的重要组件,以其强大的图形界面和灵活的数据绑定功能著称。本文通过具体示例代码,介绍如何在 WPF 应用中实现 Word 和 Excel 文档的自动化操作,包括文档的读取、编辑和保存等。首先创建 WPF 项目并设计用户界面,然后在 `MainWindow.xaml.cs` 中编写逻辑代码,利用 `Microsoft.Office.Interop` 命名空间实现 Office 文档的自动化处理。文章还提供了注意事项,帮助开发者避免常见问题。
281 0