php会话控制,PHP中的会话控制

会话控制-cookie

cookie的两种设置方式

cookie存储在客户端

1.setcookie()设置cookie

setcookie(‘cookie名称’,’cookie值’,’cookie存活时间’,’cookie的服务器路径’,’cookie的有效域名’,’规定是否需要在安全的HTTPS连接来传输cookie,是设为true,否则false’;

注;常用参数前三个,后面选用

例:

setcookie(‘username’,’zhangsan’,time()+3600*24,’/’,’.cc.com’,’1′);d79747f7aff4f2796660942cb8657512.png

2.通过header响应头设置cookie

header(‘Set-cookie:cookie名=cookie值’)

例:

header(‘Set-cookie:a=1’);

注意:如果设置cookie时不添加生存时间那么当浏览器关闭时会自动清除掉没有设置生存时间的cookie

cookie设置后再第二次加载时才能访问到,第一次在响应头中显示,第二次在请求头中显示[响应头比请求头慢一步]

更新cookie

注意:更新cookie,参数要一一对应

更新cookie[就是在设置一个cookie名字和要修改的那个cookie名相同把cookie值或其他参数修改,直接覆盖上一个同名的cookie]

例:

setcookie(‘user’,’zhangsan’);

//更新cookie值

setcookie(‘user’,’lisi’);

//打印查看cookie是否更新成功

//使用超全局数组$_COOKIE来打印输出

var_dump($_COOKIE[‘user’]);//输出”lisi”

打印输出cooie值

使用超全局数组$_COOKIE来打印输出查看cookie值

//打印输出全部cookie的值

var_dump($_COOKIE);

//var_dump($_COOKIE[‘指定的cookie名称’]);打印输出指定值

例:

var_dump($_COOKIE[‘user’]);//输出lisi

销毁session

注意:销毁cookie时如果该cookie有写路径销毁的时候一定要把路径参数写上

销毁cookiesetcookie(‘要销毁的cookie的名’,值设置为null,过期时间time()-3600/或0);

例:

setcookie(‘username’,”,time()-3600,’/’);

设置cookie时值中有特殊字符让特殊字符正常显示

例:

//设置cookie是特殊字符正常显示

setcookie(’email’,’123@qq.com’);//浏览器显示Set-Cookie:email=123%40qq.com[@被解析成了一个%]

//让特殊字符正常输出

setrawcookie(’email’,’123@qq.com’);//浏览器显示Set-Cookie:email=123@qq.com

PHP会话控制-session

session存储在服务器端

设置或使用session第一步先开启session

session_stat();

设置session

例:

$_SESSION[“test”]=”ceshi”;

输出查看session

//使用超全局数组$_SESSION

//查看指定session值$_SESSION[‘要查看的session的名称’];

例:

var_dump($_SESSION[‘test’]);

//查看全部session值

例:

var_dump($_SESSION);

销毁session

//unset($_SESSION[‘要销毁的session名称’])

例:

unset($_SESSION[‘test’]);

//session_destroy();销毁所有session,没有参数

例:

session_destroy();

使用cookie实现用户7天内自动登录

//登录页面

//获取post提交的值

$username=$_POST[‘username’];

$password=$_POST[‘password’];

//echo$username,$password;

//清除cookie中所有的用户信息

functionclearCookies(){

setcookie(“username”,null,0);

setcookie(“isLogin”,null,0);

}

//判断是否提交数据

if(isset($_POST[‘sub’])){

//判断用户名和密码是否正确

if($username==’张三’&&$password==’123456′){

//清除之前的登录用户cookie

clearCookies();

//信息正确设置cookie

setcookie(‘username’,$username,time()+3600*7);

setrawcookie(‘isLogin’,’1′,time()+3600*7);

//设置完成直接跳转页面

header(“Location:index.php“);

}else{

exit(‘用户名或密码不正确’);

}

}

//当点击退出时跳转到该页面并在get中附带action动作,值等于logOut

if($_GET[‘action’]==”logOut”){

clearCookies();

}

?>

用户登录

用户名

请输入用户名

密码

请输入密码

提交111111

//登录成功页面

//判断cookie中sLogin是否存在如果存在值是否等于1满足这两项进入登录,否则拦截

if(!isset($_COOKIE[‘isLogin’])||$_COOKIE[‘isLogin’]!=”1″){

exit(”);

}

?>

主页

退出

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值