位置: 编程技术 - 正文

Discuz!X中SESSION机制实例详解

编辑:rootadmin

推荐整理分享Discuz!X中SESSION机制实例详解,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

本文实例讲述了Discuz!X中SESSION机制。分享给大家供大家参考。具体如下:

在Discuz! X中一如继往的,SESSION 并没有使用 PHP 自带的 SESSION 机制,而是系统的一套自带的机制。

在数据库中可以看到有两个 SESSION 表:一个是pre_common_adminsession,是管理员登录后台的 SESSION 表;另一个是 pre_common_session 表,是所有用户在前台浏览页面时的 SESSION 表。这两个表都是内存表(内存表的读写速度远高于 MYISAM 表及文本文件)。

在 Discuz! X 中 SESSION 与 COOKIE 是分不开的,因为 SESSION 就是从客户端读取的 COOKIE ,然后由浏览页面时触发相关的函数执行,再写入数据库 SESSION 表。

我以登录流程为例来讲解程序具体是如何执行的。在前台首页,点击登录后,弹出一个登录窗口,填写好数据后,提交。form表单提交的 URL 是:&#;数据提交到了 member.php 文件中,在程序中可看到下面的代码:

打开source/module/member/member_logging.php文件,是一个类,在类的前面可看到下面三句代码:

在类中可找到login方法,在方法中,大约 行有下面一个判断语句:

我们来看一下 source/function/function_login.php中的 setloginstatus 函数,是普通的写 COOKIE 操作,不再具体讲解:

Discuz!X中SESSION机制实例详解

到这里可以说是登录流程大部分已经走完,但是 COOKIE 不清除时,会一直存在于客户端,如果超时,程序中会在判断弃用此 COOKIE,并重新写入。

下面我们来看一下 DZX 中 SESSION 操作的类,在 source/class/calss_core.php 文件中:程序中每次请求都会加载 SESSION ,这是由核心类 discuz_core 中的 _init_session 方法来执行的,此方法被置于 类的 init方法中,说明每次加载类,会自动将 SESSION 写入。

操作 SESSION 的类是 discuz_session ,我们看这个类里面的两个方法:

至此我们知道了 SESSION 插入数据库的具体函数,与 COOKIE 的联系,但还不清楚是如何触发此操作的。打开 source/function/function_core.php 文件,找到函数,updatesession ,此函数负责更新 SESSION :

我们在程序源码中搜索此函数,可以看到在很多的模板中都有下面一句代码:浏览页面时将触发此函数,并将 SESSION 写入数据库。

整理一下思绪:

第一步:用户登录,程序将 COOKIE 写入客户端,这些 COOKIE 即是 SESSION 的部分数据,如SID、IP、TIME,不包含用户名、密码等关键信息。

第二步,登录成功后,程序会自动刷新页面,向服务器再次发送请求,服务器加载 discuz_core 核心类,并从 COOKIE 中读取到 SESSION 的相关信息,但还没有写入数据库。

第三步,核心类加载完成,程序继续执行,最后加载模板,触发 updatesession 函数,SESSION 被写入数据库。

希望本文所述对大家的php程序设计有所帮助。

ThinkPHP2.x防范XSS跨站攻击的方法 本文实例讲述了ThinkPHP2.x防范XSS跨站攻击的方法。分享给大家供大家参考。具体如下:一直使用ThinkPHP2.x,通过乌云有向提交了ThinkPHPXSS攻击的bug,抽时

ThinkPHP中数据操作案例分析 本文实例分析了ThinkPHP中数据操作方法。分享给大家供大家参考。具体如下:模板中使用函数,相信大部分的TPer都知道也用过吧。案例:获取用户名的

PHP+AJAX实现投票功能的方法 本文实例讲述了PHP+AJAX实现投票功能的方法。分享给大家供大家参考。具体如下:在这个AJAX实例中,我们将演示一个投票程序,网页在不重新加载的情

标签: Discuz!X中SESSION机制实例详解

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

上一篇:ThinkPHP进程计数类Process用法实例详解(php进程数量怎么决定)

下一篇:ThinkPHP2.x防范XSS跨站攻击的方法(php如何防止xss攻击)

  • 农产品进项税额转出怎么算
  • 生产企业出口退税的计算方法
  • 小规模纳税人普票交税吗
  • 出口货物如何申报
  • 一般纳税人可以开1%的发票吗
  • 子公司注销母公司合并报表处理
  • 快消品行业成本结转方法
  • 股息红利纳税地点
  • 医药酒精现在要兑水喝吗
  • 发票认证后1年还能用吗
  • 营改增之后的增值税
  • 个人设备租赁给公司怎么提供发票
  • 企业房产使用税
  • 只有原始凭证无入库单跟发票如何记账?
  • 营改增后融资租赁税率
  • 企业所得税是什么意思需要交不需要
  • 应收账款周转天数正常范围
  • 个人账户付款到对公账户
  • 服务业成本怎么做账
  • vmware虚拟机无法打开网页
  • 不计入开办费可以吗
  • 哪些情况下可以终止心肺复苏
  • 跨年退税怎么处理
  • giantantispywaremain.exe是什么进程 有什么作用 giantantispywaremain进程查询
  • linux如何配置ssh
  • 营改增后土地增值税若干征管规定
  • 设备租赁会计科目
  • 费用扣除制度
  • 企业支付的贷款计入gdp
  • php执行脚本
  • 固定资产折旧的计算方法
  • 远程访问群晖nas
  • php点击下载
  • html/css/javascript
  • ls -lh命令
  • rm -rf/指令指删除什么
  • 微擎框架是开源的吗
  • python读取全部文件
  • 公司账户转私账违法吗
  • 数量金额式账页图片
  • 工会会费收取
  • 应付账款转入营业外收入会计分录
  • 土地出让金的范围是什么
  • mysql事务引擎
  • mysqldump -s
  • mongodb怎么导入文件
  • 盈余公积转增资本会计科目
  • CentOS 7.3上SQL Server vNext CTP 1.2安装教程
  • 吊车租赁有限公司
  • 销售提成如何入账
  • 烈士祭扫仪式
  • 买赠业务税务处理
  • 内部债权债务的抵消分录
  • 工程履约保证金退还申请书
  • 商业承兑汇票销售产品会计分录
  • 外贸企业需要取得什么资质
  • 什么叫归集和分配
  • mysql常见语句总结
  • 阿里云 mybase
  • mysql 正则表达式 是否包含字母
  • win7跟xp怎样连接局域网
  • ubuntu20.04亮度调节
  • ubuntu 14.04.6
  • linux系统中的链接文件主要分为两种
  • centos6关闭图形界面
  • win8.1怎么用
  • 微软发布Win10优化工具
  • win10专业版系统多少g
  • linux sleep命令有什么用
  • win8.1开不了机怎么办
  • bootstrap怎么用
  • javascript声明变量的语句
  • node和javascript
  • javascript绘制图形
  • u3d transform
  • 音频资料下载
  • 审计会计税务的区别及联系
  • 城市维护建设税税率
  • 混合销售定义是什么意思
  • 资源税税率表一览表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设