PHP 之Section与Cookie使用总结


Posted in PHP onSeptember 14, 2012

SESSION与COOKIE区别:

Session 将信息保存在服务器上.服务器在接受到唯一的SESSION_ID后,根据这个ID获取相关数据,然后将信息传递到客户端(浏览器).

Cookie 是将所有信息以文本的形式存在本地文件,并由客户端(浏览器)进行管理与维护.
因为Session 数据存储在server端,所以远程client无法对数据进行修改;而Cookie存储在client本地,容易被获取和篡改.所以Session安全性较高.

SESSION 介绍:

PHP5 后session被设置为全局变量,可以通过 $_SESSION[session_id] 来获取.当页面启动SESSION会话,会在服务器中生成一个带唯一id的SESSION,这个SESSION在生命周期结束前一直有效.当关闭网页或结束生命周期后,session会在服务器中自动注销.

创建一个session 会话需要经过一下4个步骤:

a)启动会话..

方法有2种: bool session_star(); boolean session_register(string name);

b)注册回话.

会话变量被启动后,全部保全在$_SESSION数组当中.通过数组$_SESSION创建一个会话变量很简单,只需要给该数组添加一个变量即可.

c)使用会话:

一般操作:判断对应session_id的SESSION是否存在.不存在创建一个,存在 则通过 $_SESSION[session_id] 使用.

d)删除会话.
unset($_SESSION[session_id]);//删除单个.

  unset([$_SESSION]);//删除整个,将禁止整个会话功能,切无法恢复.

 $__SESSION=array();//删除整个,可恢复.

 session_destroy();//结束当前会话..

SESSION的生命周期:

1.控制session 生命周期的方法:

 一. 前提条件:客户端支持COOKIE!

方法:

a>通过Session来完成.

void session_set_cookie_params(int lifetime[,string path][,string domain][,bool secure]);

bool setcookie(string name [,string value] [,int expire] [,string path] [,sting domain] [,secure]);

b>通过Cookie 来完成.
二. 前提条件:客户端不支持COOKIE!

 一旦客户端不支持cookie,SESSION就不能在页面间传递,解决办法:

a>.在登陆前提示用户打开cookie.

 b>.表单POST/GET方式,来传递SESSION_ID.

 c>.设置php.ini文件中的session.use_trans_sid=1 或编译时打开-enable-trans-sid;

 d>.通过文件或数据库方式传递SESSION_ID;

服务器上对SESSION性能优化:

在服务器中,如果将所有用户的session都保存到临时目录中,会降低服务器的安全性与效率.

解决方法:将SESSION存储到服务器上的数据库或者临时文件中.

临时文件:

string session_save_path(string path);

数据库:

session 存储在临时文件时,当网站浏览量很大的时候,将会导致查询Session的效率很低,推荐数据库存储形式.

bool session_set_save_handler(string open,string close,string read,string write,string destroy,string gc);//将session_id 存储与数据库中的函数.

SESSION 缓存:

缓存即将页面中的某些信息存储到客户端指定的文件夹中,且可以设置一定的有效时间.(已经经过第一次访问,且存储)在这个有效时间内,当再次访问页面,则可直接从缓存中读取内容,从而提高页面浏览效率.

string session_cache_limiter(string cache_limiter); //缓存函数.

int session_cache_expire([int new cache_expire]); //有效时间.

COOKIE介绍:

cookie 是一种远程客户端存储数据和跟踪识别用户的机制.是服务器临时存放数据在本地用户的一个文本文件.文本文件格式:"用户名@网站地址[数字].txt"

COOKIE 常见功能:

a)记录访客的某些信息. b)在页面间传递变量; c)将页面内容存储到cookie中提高下次访问速度.
慎用COOKIE:

a)不是所有的浏览器都支持cookie.

b)数据是以明文的方式保存在本地,不适合敏感的信息,未加密的信息.

c)不同类型浏览器对cookie 文件有大小,个数限制:比如最多只能存300个cookie 文件,每个大小不超过4KB,每个域名最多支持20个cookie文件.如果超过显示,会随机删除.
创建COOKIE:

bool setcookie(string name [,string value] [,int expire] [,string path] [,sting domain] [,secure]);
读取COOKIE:

$_COOKIE[];
删除COOKIE:

a). setcookie("id", "",time()-1);//值为空,有效时间小于当前时间.0为直接删除COOKIE.

b).手动删除.在客户端找到临时存放cookie的文件.

setcookie()函数后,要执行刷新,cookie才能取得数据:

个人理解是因为session 跟cookie都是在client 跟server之间传输,在页面显示前,我们就必须获取到相应的数据.所以一般是在获取 http:// 或https://时必须带上session 或cookie..当在执行setcookie()时,仅仅在本地存储了cookie 但是地址上并没有带上cookie..因而需要刷新,让服务器给地址协议带上cookie发送个客户端,这样才能取得到值..

正是以上session_star(),setcookie()前,html页面不能有输出...所以说cookie 或者session认第一,就没人敢认第二.

PHP 相关文章推荐
PHP extract 将数组拆分成多个变量的函数
Jun 30 PHP
PHP随机生成随机个数的字母组合示例
Jan 14 PHP
PHP正则替换函数preg_replace和preg_replace_callback使用总结
Sep 22 PHP
PHP进程同步代码实例
Feb 12 PHP
PHP实现的增强性mhash函数
May 27 PHP
详解WordPress中分类函数wp_list_categories的使用
Jan 04 PHP
Symfony2框架创建项目与模板设置实例详解
Mar 17 PHP
php操作access数据库的方法详解
Feb 22 PHP
Linux服务器下PHPMailer发送邮件失败的问题解决
Mar 04 PHP
php中html_entity_decode实现HTML实体转义
Jun 13 PHP
laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析
Dec 20 PHP
PHP使用PDO 连接与连接管理操作实例分析
Apr 21 PHP
PHP 文件系统详解
Sep 13 #PHP
PHP 面向对象详解
Sep 13 #PHP
关于访问控制的一首PHP面试题(对属性或方法的访问控制)
Sep 13 #PHP
PHP基础陷阱题(变量赋值)
Sep 12 #PHP
php中判断文件存在是用file_exists还是is_file的整理
Sep 12 #PHP
PHP中file_exists与is_file,is_dir的区别介绍
Sep 12 #PHP
PHP中几种常见的超时处理全面总结
Sep 11 #PHP
You might like
php smarty模版引擎中的缓存应用
2009/12/11 PHP
PHP安全配置详细说明
2011/09/26 PHP
PHP常见漏洞攻击分析
2016/02/21 PHP
PDO操作MySQL的基础教程(推荐)
2017/08/18 PHP
在JS中最常看到切最容易迷惑的语法(转)
2010/10/29 Javascript
禁止ajax缓存获取程序最新数据的方法
2013/11/19 Javascript
JS上传图片前实现图片预览效果的方法
2015/03/02 Javascript
jquery显示loading图片直到网页加载完成的方法
2015/06/25 Javascript
Bootstrap CSS布局之表单
2016/12/17 Javascript
Vue声明式渲染详解
2017/05/17 Javascript
jQuery remove()过滤被删除的元素(推荐)
2017/07/18 jQuery
webpack手动配置React开发环境的步骤
2018/07/02 Javascript
前端防止用户重复提交js实现代码示例
2018/09/07 Javascript
js+html5 canvas实现ps钢笔抠图
2019/04/28 Javascript
react中Suspense的使用详解
2019/09/01 Javascript
[01:14:41]DOTA2-DPC中国联赛定级赛 iG vs Magma BO3第一场 1月8日
2021/03/11 DOTA
利用一个简单的例子窥探CPython内核的运行机制
2015/03/30 Python
对于Python异常处理慎用“except:pass”建议
2015/04/02 Python
Python计算三维矢量幅度的方法
2015/06/15 Python
Python实现读取txt文件中的数据并绘制出图形操作示例
2019/02/26 Python
对Python函数设计规范详解
2019/07/19 Python
python GUI库图形界面开发之PyQt5窗口类QMainWindow详细使用方法
2020/02/26 Python
python访问hdfs的操作
2020/06/06 Python
python3.4中清屏的处理方法
2020/07/06 Python
Kmeans均值聚类算法原理以及Python如何实现
2020/09/26 Python
CSS3 网页下拉菜单代码解释 中文翻译
2010/02/27 HTML / CSS
基于canvas使用贝塞尔曲线平滑拟合折线段的方法
2018/01/10 HTML / CSS
印度尼西亚最大和最全面的网络商城:Blibli.com
2017/10/04 全球购物
迷你唐卡软皮鞋:Minnetonka Moccasin
2018/05/01 全球购物
《木笛》教学反思
2014/03/01 职场文书
竞选学习委员演讲稿
2014/09/01 职场文书
单位个人查摆问题及整改措施
2014/10/28 职场文书
2015年度个人思想工作总结
2015/04/08 职场文书
土建技术员岗位职责
2015/04/11 职场文书
详解Nginx 工作原理
2021/03/31 Servers
python ansible自动化运维工具执行流程
2021/06/24 Python