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

[经验分享] PHP中cookie和会话编程

[复制链接]

尚未签到

发表于 2015-8-27 10:30:24 | 显示全部楼层 |阅读模式
      使用PHP进行用户认证的方式有三种:HTTp认证、使用session、使用cookie。
   
      使用php进行http认证:
               是通过结合header()函数和$PHP_AUTH_USER、$PHP_AUTH_pw全局变量的方法来创建的一个基本认证机制。
           一个简单的PHP脚本可以通过发送适当的HTTP头以在客户机屏幕自动显示用户名/口令对话框以模拟HTTP认证请求/响应系统。
            



1 <?php
2   if((!isset($PHP_AUTH_USER)) || (!isset($PHP_AUTH_PW)))
3   {
4   header('WWW-Authenticate:Basic reallm="My Private Stuff"');
5   header('HTTP/1.0 401 Unauthorized');
6   echo 'Authorization Required.';
7   exit;
8   }
9   else if((isset($PHP_AUTH_USET)) && (isset($PHP_AUTH_PW)))
10   {
11   if(($PHP_AUTH_USER!="validname") || ($PHP_AUTH_PW!="goodpassword"))
12   {
13   header('WWW-Authenticate:Basic reallm="My Private Stuff"');
14   header('HTTP/1.0 401 Unauthorized');
15   echo 'Authorization Required.';
16   exit;
17   }
18   else if(($PHP_AUTH_USE=="validname") || ($PHP_AUTH_PW=="goodpassword"))
19   {
20   echo 'YOu are authorized';
21   }
22   }
23 ?>
  
  运行结果如下:
  
DSC0000.png
      cookie是服务器在用户的机器上存储信息的一种方式。利用这种方式,站点可以在访问期间记住或跟踪用户。
      
      Cookie的配置与应用:
  

         cookie通过HTTP  Headers从服务器端返回到浏览器上,首先,服务器端在响应中利用Set-cookie header来创建一个cookie,然后,浏览器在它的请求中通过cookie header(包含这个已经创建的cookie),并且返回至服务器,从而完成浏览器的验证。
     

     



Setcookie(string name, string value, int expire,string path, string domain, int secure);
  
  
        其中name是cookie变量名称标识,你在php中将能象使用普通变量名相同来用他引用cookie变量。value是cookie变量的初始值,expire 表示该cookie变量的有效时间;path 为该cookie变量的相关路径;domain 表示cookie变量的网站;secure 则需在 https 的安全传输时才有效。
  
DSC0001.png
  
  
  
  接收和处理Cookie
  PHP对Cookie的接收和处理的支持非常好,是完全自动的,跟FORM变量的原则一样,特别简单。
  比如设置一个名为 MyCookier的Cookie,PHP会自动从WEB服务器接收的HTTP头里把它分析出来,并形成一个与普通变量一样的变量,名为$ myCookie,这个变量的值就是Cookie的值。数组同样适用。另外一个办法是引用PHP的全局变量$HTTP_COOKIE_VARS数组。
  分别举例如下:(假设这些都在以前的页面里设置过了,并且仍然有效)



1 echo $MyCookie;
2 echo $CookieArray[0];
3 echo $_COOKIE["MyCookie"];
4 echo $HTTP_COOKIE_VARS["MyCookie"];
  
  删除Cookie
  要删除一个已经存在的Cookie,有两个办法:
  

  



1 SetCookie("Cookie", "");
2 SetCookie("Cookie", "value" , time()-1 / time() );
  
  
  使用Cookie的限制
  1、必须在HTML文件的内容输出之前设置;
  2、不同的浏览器对Cookie的处理不一致,且有时会出现错误的结果。
  3、限制是在客户端的。一个浏览器能创建的Cookie数量最多为30个,并且每个不能超过4KB,每个WEB站点能设置的Cookie总数不能超过20个。
  
  



1 <?php
2   if($_GET[out])
3   {
4   setcookie('id','');
5   setcookie('pass','');
6   echo '<script>location.href="cook.php"</script>';
7   }
8   if($_POST['name'] && $_POST['password'])
9   {
10   setcookie('id',$_POST['name'],time()+3600);
11   setcookie('pass',$_POST['password'],time()+3600);
12   echo '<script>location.href="cook.php"</script>';
13   }
14   else
15   {
16   echo $_POST['name'];
17   }
18   if($_COOKIE[id] && $_COOKIE[pass])
19   {
20   echo "登陆成功<br>用户名:".$_COOKIE[id]."<br>密码:".$_COOKIE[pass];
21   echo '<br><a href="cook.php?out=out">退出</a>';
22   }
23 ?>
24 <form action="" method="post">
25 用户名:<input type="text" name="name"><br>
26 密码:<input type="password" name="password"><br>
27 <input type="submit" value="登陆">
28 </form>
  
  
  Session的配置与应用:
            
  



1 session_start();                    //初始化session.需在文件头部
2 $_SESSION[name]=value;  //配置Seeeion
3 echo $_SESSION[name];    //使用session
4 isset($_SESSION[name]);   // 判断
5 unset($_SESSION[name]);   //删除
6 session_destroy();             //结束session
7 session_name():存取目前session名称
8 session_module_name():存取目前session模块
9 session_save_path():存取目前session路径
10 session_id():存取目前session代号
11 session_register():注册新的变量
12 session_is_registered():检查变量是否注册
13 session_decode():session资料解码
14 session_encode():session资料编码
  

  
  在浏览某个网站时,在浏览器没有关闭的情形之下,一个WEB应用的开始和结束。一个session可以数次http的请求和应答,每一个被创建的session都有一个唯一的标识串,叫做sessionID,这个串被发发送到客户端,同时在服务器端也生成了同样唯一的标识串入口。这个标识串或则放在文本中,或者放在一个数据库中。然后程序可以在这个sessionID下注册一些session变量。这些变量如同一般的变量一样可以保存文本或数值信息,可以通过session被读出或写入。session的唯一标识一般是系统内部唯一的sessionID。
  
  




1 <?php
2   session_start();
3   if($_GET[out])
4   {
5   unset($_SESSION[id]);
6   unset($_SESSION[pass]);
7   }
8   if($_POST['name'] && $_POST['password'])
9   {
10   $_SESSION[id]=$_POST['name'];
11   $_SESSION[pass]=$_POST['password'];
12   }
13  
14   if($_SESSION[id] && $_SESSION[pass])
15   {
16   echo "登陆成功<br>用户名:".$_SESSION[id]."<br>密码:".$_SESSION[pass];
17   echo '<br><a href="session.php?out=out">退出</a>';
18   }
19 ?>
20 <form action="" method="post">
21 用户名:<input type="text" name="name"><br>
22 密码:<input type="password" name="password"><br>
23 <input type="submit" value="登陆">
24 </form>

  

运维网声明 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-104913-1-1.html 上篇帖子: php数据库操作实例 下篇帖子: 1.2 EcShop之路-PHP
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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