位置: 编程技术 - 正文

Laravel中的Sessionid处理机制详解(laravel中的session有效期)

编辑:rootadmin

推荐整理分享Laravel中的Sessionid处理机制详解(laravel中的session有效期),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:laravel中的session有效期,laravel中的session有效期,laravel中的设计模式,laravel中的设计模式,laravel中的session有效期,laravel中的一些模式及其应用,laravel中的一些模式及其应用,laravel中的session有效期,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

本文主要给大家介绍了关于Laravel中Sessionid处理机制的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

在 Laravel 的配置文件 config/session.php 中可以设置 Session Cookie Name,比如这个项目中设置名称为“sns_session”:

我们可以看到刷新页面,查看 cookie,会发现一个名称为 sns_session 的 cookie,名字就是我们自定义的。

这个 sessionid 就是 cookie 和 session 联系的桥梁,服务器通过这个 sessionid 判断来自哪个客户端的请求。

Laravel 的 sessionid 每次刷新发生变化

但是,每次刷新页面,这个 cookie 值都会发生改变!那么这样服务器如何保持会话呢?因为你的 sessionid 总是在变。

Laravel 对 cookie 进行加密

Laravel中的Sessionid处理机制详解(laravel中的session有效期)

我们在 vendor/laravel/framework/src/Illuminate/Session/Store.php 的 save 方法中调试一下,打印一下这里的调用栈:

每次刷新页面,这个 Store 对象的 id 属性其实是没有变化的,这个属性就是 sessionid 这个 cookie 的值。也就是说,sessionid 的值并不是每次发生变化,而是写 cookie 的时候,值发生了变化。

在 vendor/laravel/framework/src/Illuminate/Cookie/Middleware/EncryptCookies.php 中的 encrypt 方法找到了原因,这个中间件对所有 cookie 值进行了加密处理,它被包含在 web 中间件。

而这种加密方式是每次加密的结果都不同,所以表现为 sessionid 的值每次都发生了变化,而实际上并没有改变。在需要用到这个 cookie 的时候会被解密回去。

Laravel 框架这样设计的目的可能是为了防止 session 劫持吧!考虑还是比较全面的!

其他补充知识

原生 PHP 设置 session 名称

session_name() 函数:

session_name() 函数返回当前会话名称。 如果指定 name 参数, session_name() 函数会更新会话名称, 并返回 原来的 会话名称。

请求开始的时候,会话名称会被重置并且存储到 session.name 配置项。 因此,要想设置会话名称,那么对于每个请求,都需要在 调用 session_start() 或者 session_register() 函数 之前调用 session_name() 函数。

COOKIE和SESSION的区别和关系

COOKIE保存在客户端,而SESSION则保存在服务器端 从安全性来讲,SESSION的安全性更高 从保存内容的类型的角度来讲,COOKIE只保存字符串(及能够自动转换成字符串) 从保存内容的大小来看,COOKIE保存的内容是有限的,比较小,而SESSION基本上没有这个限制 从性能的角度来讲,用SESSION的话,对服务器的压力会更大一些 SEEION依赖于COOKIE,但如果禁用COOKIE,也可以通过url传递

总结

标签: laravel中的session有效期

本文链接地址:https://www.jiuchutong.com/biancheng/288310.html 转载请保留说明!

上一篇:使用PHP连接数据库实现留言板功能的实例讲解(推荐)(php连接数据表)

下一篇:PHP 传输会话curl函数的实例详解(php之间传递数据)

  • 跨月发票税率开错了如何处理合适?
  • 餐饮设备租赁服务属于
  • 计税基础怎么算
  • 车险退到对公账户会计分录是
  • 财务台账包含什么
  • 公司的纳税信用等级对财务人员有什么影响
  • 能直接从公司账户向个人账户转钱吗
  • 怎么报企业所得税季报
  • 跨年发票问题
  • 外购原材料自用要进项转出吗
  • 转贴现视为贷款银行如何进行账务处理?
  • 6%的增值税专用发票怎么开
  • 买酒专票怎么可以抵税
  • 促销服务费经营范围怎么写
  • 一个企业为另一个企业作证有法力
  • 资产负债表写错数字怎么改
  • 电子普通发票进什么科目
  • 有限责任公司自然人独资可以增加股东吗
  • 支票能够拿来付款吗
  • 销售二手设备税率
  • 鸿蒙工具栏在哪里
  • 劳务人员劳务费
  • 商品从总仓到分拣要多久
  • linux基本命令有哪些
  • php获取ftp文件目录
  • 个税扣除项怎么扣除
  • 销售折扣的税票怎么开
  • 增值税专用发票抵扣期限
  • 旧设备投资的税务处理
  • 员工补偿金分录
  • 职工教育经费计入管理费用吗
  • 自然vc
  • 加拿大猞猁雪兔
  • 企业会计准则应付利息计入什么科目?
  • 发票抬头可以是两个人吗
  • reactjs路由跳转
  • 现金流量表中如何考虑折旧费
  • Smarty实现页面静态化(生成HTML)的方法
  • php正则匹配时间
  • 房地产企业销售佣金税前扣除
  • 基于matlab的随机森林回归和交叉验证
  • 实现php搜索框代码
  • 在税务局怎么查补缴的社保
  • phpcms怎么用
  • 增值税哪些行业不能抵扣
  • 加油的电子发票在哪里找
  • 残保金季度申报如何计算
  • 累计盈余定义
  • 开具红字发票抵扣后如何退税?
  • 建筑行业每月报税
  • 销售返现如何做账务处理
  • 营改增对建筑业税负的影响
  • 所有者权益包括少数股东权益吗
  • 辅导期一般纳税人标准
  • 进出口企业需要哪些手续
  • 资本公积可以随便增加吗
  • 一次性开票分期确认收入已什么做原始凭证
  • 关联方交易舞弊手段
  • sql如何学
  • tcpdump的用法
  • centos启动有三个选项
  • 如何把itunes的音乐导入ipod
  • linux远程操作常用命令
  • pascl32.exe - pascl32是什么进程 有什么用
  • 学习笔记一
  • perl中打开文件
  • cocos2d安装教程
  • cocos2dx视频教程
  • sockaddr_in和sockaddr
  • Javascript Boolean、Nnumber、String 强制类型转换的区别详细介绍
  • nodejs await
  • python 连接符
  • jquery.js插件
  • android sdk api文档
  • Android性能优化的方面12个
  • python语言解析
  • 企业年金企业账户部分可以提取么
  • 预缴的增值税怎么做账务处理
  • 深圳国家税务总局
  • 重庆税务信息采集如何操作
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设