PHP模拟登陆并返回cookie

php会话技术主要包括两个,一个是cookie,另外一个是session。写三个页面,模拟一下系统登录判断的过程

index.php

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>欢迎来到完美世界,请先进行登陆</title>
</head>
<body>
    <form action="check.php" method="post">
        用户名:<input type="text" name="name2">
        密码:  <input type="password" name="pass2">
        <input type="submit" value="登录">
    </form>
</body>
</html>

check.php

<?php
    header("Content-type:text/html;charset=utf-8");    #解决php中中文乱码问题
	$a = "THISISSESSID20180802";
	$b = "THISISSESSIDhttponly20180802";
    if(!isset($_COOKIE['SESSIONid']) and !isset($_COOKIE['test_http'])){       #如果没有携带cookie则说明没有登陆,进入如下
        echo "<br/>";
		if(empty($_POST)){   #如果没有点击提交
			echo "<a href='index.php'>请先登录系统</a>";
		}else{    #否则的话说明进行了提交
			$name = $_POST["name2"];
			$pass = $_POST["pass2"];
			if($name == "admin" && $pass == "123456"){   #如果帐号密码正确则返回自定义cookie值
				echo "用户名密码正确";
				setcookie("SESSIONid",$a,0,"","",0);  //设置普通Cookie
				#setcookie("SESSIONid",$a,0,"","",0,1);//设置HttpOnly Cookie
                #setcoookie第三个值为0时,代表浏览器退出则cookie失效,第七个值代表是否设置httponly,值为1时代表设置
				header("Location: secret.php");      #直接进行一个跳转
			}else{
				echo "用户名或密码错误";
				echo "<a href='index.php'>请登录</a>";
		   }
		}
		
	}else{
		header("Location: secret.php"); 
	}
?>

secret.php

<?php
	header("Content-type:text/html;charset=utf-8"); 
    if(!isset($_COOKIE['SESSIONid'])){       #如果直接访问这个则拒绝
        echo "<br/>";
        echo "<a href='index.php'>请先登录系统</a>";
    }else{
        phpinfo();
    }
?>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

~Echo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值