PHP入门教程之会话控制技巧(cookie与session)
本文实例讲述了PHP会话控制技巧。分享给大家供大家参考,具体如下:
Demo1.php
<formmethod="get"action="Demo2.php"> 姓名:<inputtype="text"name="username"/><br/> <inputtype="submit"value="提交"/> </form>
Demo2.php
<?php //echo$_POST['username']; //如果表单采用的get传输,那么接受必须采用 echo$_GET['username']; //到底那种比较好呢。???? //$_POST[''];比较安全 ?>
Demo3.php
<?php
//创建一个Cookie
//Cookie是在你的客户机存一个小文件,这个文件包含你登录时的信息
//setcookie可以创建一个客户机的cookie文件
//第一个参数表示cookie的名称,第二个参数表示这个cookie名称的值
//所谓的会话结束时,就是当你这个浏览器关闭时,就没有了,就自动删除
//创建一个包含过期的cookie,过期时间采用当前的时间戳+秒即可
//time()+(7*24*60*60)表示未来的7天
//一旦setcookie改变了,一刷新浏览器,就会把旧的cookie覆盖掉
setcookie('name','oneStopWeb',time()+(7*24*60*60));
?>
Demo4.php
<?php
setcookie('name','oneStopWeb');
//读取本机的cookie,采用一个超级全局变量$_COOKIE
//里面放cookie名即可
//有一个特性,setcookie并不是及时生成,它会慢一拍
//PS:慢一拍,第一次刷新,只是生成覆盖了原来。
//但获取的还是之前的,而第二次刷新,才能真正获取到。
//echo$_COOKIE['name'];
//用变量检测函数来判断cookie是否存在
if(isset($_COOKIE['name'])){
echo$_COOKIE['name'];
}else{
echo'不存在此用户';
}
?>
Demo5.php
<?php
//删除cookie
setcookie('name','oneStopWeb');
//中间删除掉了这个cookie
//将这个值设置为空即可
//setcookie('name','');
//我将过期时间调整到目前的时间还少一秒,那么就等于是过期的了
setcookie('name','oneStopWeb',time()-1);
echo$_COOKIE['name'];
?>
Demo6.php
<formmethod="post"action="Demo7.php"> 姓名:<inputtype="text"name="username"/><br/> <inputtype="submit"value="提交"/> </form>
Demo7.php
<?php
//如果姓名的指定的姓名相同,那么就生成一个cookie
//完成登录
if(isset($_POST['username'])&&$_POST['username']=='oneStopWeb'){
//如果正确了,我生成一个cookie,再跳转
setcookie('name','web');
header('Location:Demo8.php');
}else{
header('Location:Demo6.php');
}
?>
Demo8.php
<?php
if(isset($_COOKIE['name'])){
echo'欢迎光临:'.$_COOKIE['name'];
}else{
echo'非法登录';
}
?>
Demo9.php
<?php
session_start();//开户session会话处理
//session只要用到这个,就必须开启session_start()
//放在文件开头
//创建session,直接采用超级全局变量赋值即可
//session是存在服务器端,一般存放1440秒,
//如果网页没有任何操作,会自动销毁,当然,可以通过php.ini去修改保存时间
//如果关闭了浏览器,那么也自动销毁。
//及时性,不像cookie会慢半拍
$_SESSION['name1']='oneStopWeb';
$_SESSION['name2']='oneStopWeb';
//echo$_SESSION['name'];
//if(isset($_SESSION['name'])){
//echo$_SESSION['name'];
//}else{
//echo'不存在此人。';
//}
//不是删除的方法
//$_SESSION['name']='';
//真正的删除方法
//unset($_SESSION['name']);
//if(isset($_SESSION['name'])){
//echo$_SESSION['name'];
//}else{
//echo'不存在此人。';
//}
?>
Demo10.php
<?php session_start(); //销毁所有session,销毁的也慢半拍 session_destroy(); echo$_SESSION['name1']; echo$_SESSION['name2']; //cookie适用于会员登录,购物车啊。。。 //因为他不占用服务器资源,所以会员特别多,购物车特别多的,就用cookie //session一般用于后台管理登录,人少 //安全性,一段时间不操作会自动过期 ?>
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP中cookie用法总结》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《PHP运算与运算符用法总结》、《php面向对象程序设计入门教程》、《PHP网络编程技巧总结》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。