设为首页 收藏本站
查看: 1392|回复: 0

[经验分享] php中关于会话机制的理解

[复制链接]

尚未签到

发表于 2018-12-16 07:54:21 | 显示全部楼层 |阅读模式
  web服务器端与客户端浏览器进行通信时,是基于http协议的.但是http协议是无状态协议,所谓无状态是说本次的http请求与下一次请求是单独的请求,每次请求保存的信息都不会保存.因此会话机制就应运而生,这种机制就是解决这种问题.通过会话机制可以保留通信信息,比如用户的信息保存,因此也实现了用户在使用应用过程中的跟踪,状态的维护.


    cookie:
     cookie机制,是可以将访问产生的一段信息保存在客户端浏览器,进行下一次访问的时候,会将该信息带入请求头信息中,将信息
     传递到服务器,从而实现web应用对用户的信息跟踪与维护.

     cookie的设置方式:   setcookie(name,value,expire);    //name:cookie名称,  value:cookie值,   expire:cookie的过期时间
             当expire过时间设置为0时,浏览器关闭,就会删除cookie

     对cookie信息的获取:   $_COOKIE["name"];

     对cookie信息的修改:   $_COOKIE["name"] = value;


     删除cookie的两种方式:   
    1> setcookie(name);  //直接删除cookie

    2> setcookie(name,value,time()-100);    //设置cookie的过期时间小于当前时间
   




    session:
    session机制,同样能实现保存用户信息和维持请求状态.但是与cookie不同的是,session将保存的信息存放在,web服务器.默认是存放在文件中,在php.ini配置文件中,配置session.save_path可以将session产生的文件存放在该位置,但是需要注意的是,该文件路劲需要httpd进程的写权限比如apache的写权限,否则无法存储session数据.当指定的目录不存在时,服务器不会自动创建,而 是需要手动创建.  session机制在默认情况下,是基于cookie的.也就是说.在使用session_start();初始化时,web服务器会为访问者自动生成一个sessionID 来唯一标识用户,并且将该ID存储在客户端浏览器,以cookie机制来存储,该cookie名称为固定的,默认在php配置文件中session.name配置,值为PHPSESSID.该cookie的值是自动生成的,但是在php中可以使用session_id()获取在浏览器保存的cookie值和session_name()获取在浏览器保存的cookie名称.
  而在使用过程中保存的信息,会存放在服务器配置的文件路劲下并且以sess_为前缀,以session_id为结尾命名,比如session id为vp8lfqnskjvsiilcp1c4l484d3,那么session文件名就是sess_vp8lfqnskjvsiilcp1c4l484d3,但是session不仅仅只能基于cookie,因为浏览器可以禁用cookie,如果浏览器禁用后,客户端就不能保存该cookie信息,从而影响session的使用.
        假如浏览器禁用cookie后,我们可以使用下面的途径解决该问题:
    1、设置php.ini中的session.use_trans_sid = 1,当客户端的Cookie被禁用或出现问题时,PHP会自动 把session id附着在URL中,
       这样再通过session id就能跨页使用session变量了
    2、手动通过URL传值、隐藏表单传递session id。
    3、用文件、数据库等形式保存session_id,在跨页过程中手动调用。


     但是浏览器基本上都不会禁用cookie,因为禁用之后,浏览器访问其他应用时都会出现问题.



     设置使用session的方式:
    session_start(); //初始化session

    $_SESSION['name'] = value;    // name:要设置的session名称,  value:要设置的session名称对应的值

    $_SESSION['name'];        // 获取名称为name的session值

     session信息的删除方式:
    需要删除三个地方保存的数据,但是首先需要初始化session   session_start():
    1步: 删除客户端浏览器保存的cookie信息
        setcookie(session_name(),session_id(),time()-100); 或者   setcookie(session_name());


    2步: 清空session全局变量
        $_SESSION = array();    或者    session_unset();

    3步: 删除session文件
        session_destroy();





总结:
    cookie:通过浏览器第一次访问web应用时通过web服务器调用设置cookie的相关函数比如setcookie(),告诉客户端浏览器设置cookie
     信息,在进行下一次请求web服务器应用时,浏览器就会将保存的用户信息,发送给web服务器.从而实现跨页面获取用户信息.因此也可以说
     用户信息是维护在客户端浏览器的.

        session: 在客户端访问服务器时,通过session_start()为客户端分配一个sessionID标识.并且将用户信息保存在客户端文件.当用户
     下次访问web服务器的其他页面时,浏览器会将分配的sessionID以cookie形式串入服务器,服务器获取具有该sessionID标识的文件,从而
     获取到对应的用户信息.





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-651843-1-1.html 上篇帖子: PHP魔术方法汇总 下篇帖子: 使用PHP QRCode类库生成二维码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表