位置: 编程技术 - 正文

理解PHP中的Session及对Session有效期的控制(phpsessid是什么)

编辑:rootadmin

推荐整理分享理解PHP中的Session及对Session有效期的控制(phpsessid是什么),希望有所帮助,仅作参考,欢迎阅读内容。

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

0.什么是session? Session的中文译名叫做“会话”,其本来的含义是指有始有终的一系列动作/消息,比如打电话时从拿起电话拨号到挂断电话这中间的一系列过程可以称之为一个session。目前社会上对session的理解非常混乱:有时候我们可以看到这样的话“在一个浏览器会话期间,...”,这里的会话是指从一个浏览器窗口打开到关闭这个期间;也可以看到“用户(客户端)在一次会话期间”这样一句话,它可能指用户的一系列动作(一般情况下是同某个具体目的相关的一系列动作,比如从登录到选购商品到结账登出这样一个网上购物的过程;然而有时候也可能仅仅是指一次连接;其中的差别只能靠上下文来推断了。 然而当session一词与网络协议相关联时,它又往往隐含了“面向连接”和/或“保持状态”这样两个含义,“面向连接”指的是在通信双方在通信之前要先建立一个通信的渠道,比如打电话,直到对方接了电话通信才能开始。“保持状态”则是指通信的一方能够把一系列的消息关联起来,使得消息之间可以互相依赖,比如一个服务员能够认出再次光临的老顾客并且记得上次这个顾客还欠店里一块钱。这一类的例子有“一个TCP session”或者“一个POP3 session”。 鉴于这种混乱已不可改变,要为session下个定义就很难有统一的标准。而在阅读session相关资料时,我们也只有靠上下文来推断理解了。不过我们可以这样理解:例如我们打电话,从拨通的那一刻起到挂断电话期间,因为电话一直保持着接通的状态,所以把这种接通的状态叫做session。它是访客与整个网站交互过程中一直存在的公有变量,在客户端不支持COOKIE的时候,为了保证数据正确、安全,就采用SESSION变量。访问网站的来客会被分配一个唯一的标识符,即所谓的会话 ID。它要么存放在客户端的 cookie,要么经由 URL 传递。 SESSION的发明填补了HTTP协议的局限:HTTP协议被认为是无状态协议,无法得知用户的浏览状态,当它在服务端完成响应之后,服务器就失去了与该浏览器的联系。这与HTTP协议本来的目的是相符的,客户端只需要简单的向服务器请求下载某些文件,无论是客户端还是服务器都没有必要纪录彼此过去的行为,每一次请求之间都是独立的,好比一个顾客和一个自动售货机或者一个普通的(非会员制)大卖场之间的关系一样。 因此通过SESSION(cookie是另外一种解决办法)记录用户的有关信息,以供用户再次以此身份对web服务器提起请求时作确认。会话的发明使得一个用户在多个页面间切换时能够保存他的信息。网站编程人员都有这样的体会,每一页中的变量是不能在下一页中使用的(虽然form,url也可以实现,但这都是非常不理想的办法),而SESSION中注册的变量就可以作为全局变量使用了。 那么SESSION到底有什么用处呢?网上购物时大家都用过购物车,你可以随时把你选购的商品加入到购物车中,最后再去收银台结帐。在整个过程中购物车一直扮演着临时存贮被选商品的角色,用它追踪用户在网站上的活动情况,这就是SESSION的作用,它可以用于用户身份认证,程序状态记录,页面之间参数传递等。 SESSION 的实现中采用COOKIE技术,SESSION会在客户端保存一个包含session_id(SESSION编号)的COOKIE;在服务器端保存其他 session变量,比如session_name等等。当用户请求服务器时也把session_id一起发送到服务器,通过session_id提取所保存在服务器端的变量,就能识别用户是谁了。同时也不难理解为什么SESSION有时会失效了。 当客户端禁用COOKIE时(点击IE中的“工具”—“internet="">Internet选项”,在弹出的对话框里点击“安全”—“自定义级别”项,将“允许每个对话COOKIE”设为禁用),session_id将无法传递,此时SESSION失效。不过php5在linux/unix平台可以自动检查cookie状态,如果客户端设置了禁用,则系统自动把session_id附加到url上传递。windows主机则无此功能。

1.php session 有效期

php的session有效期默认是秒(分钟),如果客户端超过分钟没有刷新,当前session会被回收,失效。 当用户关闭浏览器,会话结束,session也会失效。

可以修改php.ini的session.gc_maxlifetime来设置session的生命周期,但并不能保证在超过这一时间后session信息立即会删除。因为GC是按机率启动的,可能在某一个长时间内都没有被启动。那么大量的session在超过session.gc_maxlifetime后仍然有效。

2.session.gc_maxlifetime,session.gc_probability,session.gc_divisor说明

理解PHP中的Session及对Session有效期的控制(phpsessid是什么)

session.gc_maxlifetime = 表示当session文件在秒后没有被访问,则视为过期session,等待GC回收。

GC进程调用的概率是通过session.gc_probability/session.gc_divisor计算得来的,而session.gc_divisor默认是, 如果session.gc_probability = ,那么GC进程在每次执行session_start()时都会调用,执行回收。

把session.gc_probability/session.gc_divisor的机率提高,会有帮助,但会对性能造成严重影响。

3.严格控制session过期方法

(1).使用memcache/redis来保存session,设置过期时间,因为memcache/redis的回收机制不是按机率的,可以确保session过期后失效。

(2).只使用php实现,创建一个session类,在session写入时,把过期时间也写入。读取时,根据过期时间判断是否已过期。

demo:

PHP文件操作之获取目录下文件与计算相对路径的方法 获取目录下文件1、获取目录下文件,不包括子目录//获取某目录下所有文件、目录名(不包括子目录下文件、目录名)$handler=opendir($dir);while(($filename=read

详解WordPress开发中get_header()获取头部函数的用法 函数意义详解从当前主题调用header.php文件。是不是很简单?好吧,如果你是新手的话这里要提醒一下,这里的get和get_children()、get_category中的get略有不

WordPress主题制作中自定义头部的相关PHP函数解析 header_image()header_image()函数是WordPress自定顶部图像的标准接口函数,该函数可以自动判断后台设置,并返回字符串形式的用户自定义顶部图像地址。本文

标签: phpsessid是什么

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

上一篇:PHP中each与list用法分析(php each list)

下一篇:PHP文件操作之获取目录下文件与计算相对路径的方法(php 获取文件类型)

  • 居民个人取得境内、境外所得,如何计算应纳税额?
  • 个人去税务局开劳务费怎么交税
  • 公司注销所有者权益账面怎么处理
  • 税收的自动稳定性主要表现在什么制度
  • 营业外收入影响所有者权益吗
  • 如何理解合并报表中少数股东损益的抵消
  • 非营利组织免税资格怎么认定
  • 房产税简易征收的时间
  • 甲供材料税金如何结算
  • 用友怎么结转本期损益
  • 三证合一办理流程及费用
  • 个人代垫公司费用微信转账如何报销
  • 学校发票抬头类型填企业还是非企业
  • 垫资的利息的合法区间
  • 技术服务税票
  • 分期收款如何确认成本
  • 商品和服务税收编码怎么查
  • 股东垫支开办费
  • 税控盘费用抵减增值税的账务处理
  • 增值税以前年度损益调整
  • 企业收入不进公账怎样做账?
  • 支付给外单位的押金是其他应收款吗
  • bios设置启动顺序(图解说明)
  • 在window中
  • 会计利润利润总额的计算
  • win10系统如何开启蓝牙
  • 货物价格如何确定
  • PHP:session_regenerate_id()的用法_Session函数
  • 折扣促销方式
  • kb4586853更新
  • thinkphp ide
  • PHP中$GLOBALS['HTTP_RAW_POST_DATA']和$_POST的区别分析
  • php缓存机制有哪些
  • framework7教程
  • 行政事业单位 银行
  • 造孽啊啥意思
  • 以前年度损益调整借贷方向
  • 固定资产无形资产计提折旧是当月还是次月
  • 购买电脑做什么分录
  • 筹办分公司
  • 自收自支是由主管部门拨款吗
  • mongo --eval
  • 个人所得税退税退多少钱怎么算
  • 三栏式明细账适用于原材料明细账
  • 现金流量表年报本期金额和上期金额
  • 安装sql server 2005,安装不成功怎么设置
  • 兼职劳务报酬税率
  • 衍生工具什么意思
  • 缴纳车辆购置税有发票吗
  • 营改增行业销售额的确定
  • 结转费用后利润怎么算
  • 持有至到期投资减值准备
  • 防伪税控服务费怎么交
  • 公司账户的钱如何转出
  • 小规模纳税人所得税计算
  • 非同一控制下企业合并发生的审计费
  • 股东分红入什么科目利润分配~应付利润
  • 会计可以用收据做账吗
  • 用工资冲借款报税可以吗
  • 高新技术企业的税收优惠政策
  • SQLServer2000 报1053错误(服务没有及时响应或控制请求)的解决方法
  • 破解浏览器内网教程
  • bios设置密码怎么设置
  • win7怎么禁止系统自动更新
  • browsercore.exe是什么
  • win8系统打开软件闪退
  • windows7旗舰版开机声音
  • windows7包含6个版本其中什么最强大支持的功能最多
  • windows打补丁后无法启动
  • win10 mobile 1709
  • pc guide
  • win7系统运行卡怎么办
  • win8的控制面板在哪里打开
  • extern定义函数
  • linux 映射 fn键
  • jquery删除当前元素
  • node js 前端
  • 大数据在税务稽查的应用
  • 江西省税务局公众号
  • 陕西个体户免税政策
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设