PHP脚本的10个技巧(2)


Posted in PHP onOctober 09, 2006

会话用法
PHP 4.0有一个一直为人所期待的特性,这就是PHP的会话(session)支持。相比之下,PHP 3.0的用户则不得不使用第三方的程序库或完全不能具备这项功能。缺乏会话支持能力是PHP最大的缺陷之一,也是它最受人指摘的地方。不过,随着会话支持从早期测试版本的PHP 4.0开始就成为后者的一部分,这个障碍也荡然无存了。

有了会话支持,你就可以在用户访问网络站点期间维持用户特定的变量而无须象现在这样:设置多个cookie、使用隐蔽表单域或在你可能经常要连结的一个数据库内存储信息等。

在一个页面上启动会话就是告诉PHP引擎:你或是要开始一个会话(如果先前没有)或是继续目前的会话:

session_start();

启动一个会话将通过cookie向用户发送一个标识字符串(比如940f8b05a40d5119c030c9c7745aead9);在服务器端则会创建一个与此相匹配的临时文件,在以上例子中,其名称则是这个样子:sess_940f8b05a40d5119c030c9c7745aead9。该文件包含了注册的会话变量及其赋值。

用户访问计数器可谓使用会话的最常见实例:

启动你的PHP模块,保证PHP代码是文件的第一行:没有空白、没有HTML输出等等。这是因为,当会话函数发出一个文件头的时候,如果你在session_start()函数之前发送了空白或者HTML代码,系统即会报错。

<?
// if a session does not yet exist for this user, start one
session_start();

接下来,注册一个名为count的变量。

session_register('count');

注册变量就等于告诉了PHP:只要会话存在,一个名叫count的变量也就同时存在。目前这个变量还没有赋值。不过,如果你对它进行加1运算的话,该值即可被赋值为1:

$count++;

把以上各行代码一起考虑,实际上你已经启动了一个会话(如果先前没有)、为某个用户分配了会话id、注册了名为count的变量并把$count加1以表示用户首次访问页面:

要显示用户在当前会话下访问页面的次数,你只要打印出$count的值即可:

echo "<P>You've been here $count times.</p>";

整个访问计数器代码如下所示:

<?
session_start();
session_register('count');
$count++;
echo "<P>You've been here $count times.</p>";
?>

如果你重载以上脚本,你可以观察到计数值增加了。有意思吧?

你还可以在会话中注册数组。假设你有一个名为$faves的数组:

$faves = array ('chocolate','coffee','beer','linux');

你可以象其他单个变量一样注册该数组:

session_register('faves');

索引数组和索引其他单变量没有什么差别,比如$faves这样。如果你的用户想在Web站点的一个页面上展示自己的爱好,那么你完全可以把他喜欢的东西注册为一个名为$faves会话变量,然后你可以在其他页面上把这些值打印出来:

<?
session_start();
echo "My user likes:
<ul>";

while (list(,$v) = each ($faves)) {
echo "<li>$v"; }

echo "</ul>";
?>

这就是你要得到的:用户爱好的漂亮列表。

会话变量不能被查询字符串所覆盖,这就是说,你不能键入http:///www.yourdomain.com/yourscript.php?count=56 这样的指令为注册会话变量$count分配新值。这一点对安全而言是非常重要的:你只能在服务器端脚本上修改或者删除(未注册的)会话变量。

如果你想完全删除某个会话变量,你可以从系统中取消注册该变量:

session_unregister('count');

彻底删除某个会话,比如按下Logout按钮就是这样的例子,那么你可以写下如下的代码:

session_destroy();

使用会话来存储变量值可以让我们免于编写数据库处理代码的痛苦,这样也就不会过度增加对系统的负载,同时也减少了对专有数据库语法的使用范围,再说,你也不再非得向访问站点的用户发送一大堆cookie了。而现在呢——只需要一个cookie、一个变量就全部搞定了,真是一滴水就映出了全部光辉!实在是不能比这更简单的了。

PHP 相关文章推荐
杏林同学录(八)
Oct 09 PHP
修改了一个很不错的php验证码(支持中文)
Feb 14 PHP
thinkphp的CURD和查询方式介绍
Dec 19 PHP
ThinkPHP3.1新特性之对页面压缩输出的支持
Jun 19 PHP
PHP简单实现“相关文章推荐”功能的方法
Jul 19 PHP
PHP多进程编程实例
Oct 15 PHP
php curl请求信息和返回信息设置代码实例
Apr 27 PHP
php计划任务之验证是否有多个进程调用同一个job的方法
Dec 07 PHP
Yii2框架数据库简单的增删改查语法小结
Aug 31 PHP
thinkphp集成前端脚手架Vue-cli的教程图解
Aug 30 PHP
Laravel解决nesting level错误和隐藏index.php的问题
Oct 12 PHP
laravel 框架执行流程与原理简单分析
Feb 01 PHP
PHP脚本的10个技巧(1)
Oct 09 #PHP
图书管理程序(三)
Oct 09 #PHP
一个从别的网站抓取信息的例子(域名查询)
Oct 09 #PHP
一个PHP+MSSQL分页的例子
Oct 09 #PHP
基于文本的留言簿
Oct 09 #PHP
图书管理程序(一)
Oct 09 #PHP
图书管理程序(二)
Oct 09 #PHP
You might like
php xml留言板 xml存储数据的简单例子
2009/08/24 PHP
php array_values 返回数组的值实例详解
2016/11/17 PHP
PHP仿qq空间或朋友圈发布动态、评论动态、回复评论、删除动态或评论的功能(上)
2017/05/26 PHP
关于laravel-admin ueditor 集成并解决刷新的问题
2019/10/21 PHP
PHP设计模式(一)工厂模式Factory实例详解【创建型】
2020/05/02 PHP
日期函数扩展类Ver0.1.1
2006/09/07 Javascript
在Javascript里访问SharePoint列表数据的实现方法
2011/05/22 Javascript
JQuery中操作Css样式的方法
2014/02/12 Javascript
Javascript和Java获取各种form表单信息的简单实例
2014/02/14 Javascript
jQuery常用数据处理方法小结
2015/02/20 Javascript
如何利用AngularJS打造一款简单Web应用
2015/12/05 Javascript
jQuery Form 表单提交插件之formSerialize,fieldSerialize,fieldValue,resetForm,clearForm,clearFields的应用
2016/01/23 Javascript
JavaScript Array对象详解
2016/03/01 Javascript
基于MVC5和Bootstrap的jQuery TreeView树形控件(一)之数据支持json字符串、list集合
2016/08/11 Javascript
jQuery实现点击任意位置弹出层外关闭弹出层效果
2016/10/19 Javascript
AngularJS定时器的使用与移除操作方法【interval与timeout】
2016/12/14 Javascript
JS去除重复并统计数量的实现方法
2016/12/15 Javascript
angular分页指令操作
2017/01/09 Javascript
Angular6项目打包优化的实现方法
2019/12/15 Javascript
Python中 Lambda表达式全面解析
2016/11/28 Python
python算法表示概念扫盲教程
2017/04/13 Python
mac系统下Redis安装和使用步骤详解
2019/07/09 Python
python使用建议技巧分享(三)
2020/08/18 Python
python实现三种随机请求头方式
2021/01/05 Python
简单聊聊H5的pushState与replaceState的用法
2018/04/03 HTML / CSS
美国狗旅行和户外用品领先供应商:kurgo
2020/08/18 全球购物
生物化工专业个人自荐信
2013/09/26 职场文书
开办饭店创业计划书
2013/12/28 职场文书
三年大学生活自我鉴定
2014/01/21 职场文书
网络编辑求职信
2014/04/30 职场文书
IT工程师岗位职责
2014/07/04 职场文书
2015元旦标语横幅
2014/12/09 职场文书
考研英语复习计划
2015/01/19 职场文书
销售助理岗位职责
2015/02/11 职场文书
新手入门Mysql--sql执行过程
2021/06/20 MySQL
MySQL8.0升级的踩坑历险记
2021/11/01 MySQL