文章分类 | 推荐文章 | 最新文章 | 热点文章 | 最新软件 | 精品软件 | 下载排行 | 推荐下载 | firefox | WPS | 杀毒软件 | Picasa
清风网络
首 页 软件下载 网络学院 数码学院
QQ 电脑入门 游戏 操作系统 图形图像 办公软件 媒体动画 精文荟萃 常用软件 网页编程 技术开发 网络技术 认证考试 网站建设 文章专栏
当前位置:清风网络学院网络编程PHPPHP 会话 (Session) 使用入门
精品推荐
特别推荐
·菜鸟学PHP之Smarty入门
·PHP环境安全配置教程
·PHP入门指导:如何学习PHP?
·Php+Mysql注入专题
·PHP:实现给上传图片加水印的程序代码
·PHP动态网站开发中常用的8个小技巧
·PHP初学者:配置Apache服务器并且设置DNS
·初学PHP指导:php.ini 配置详细选项
·好文分享:PHP入门的学习方法
·急速搭建属于自己的Discuz!6论坛
·PHP入门:初学来看配置文件PHP.INI的中文注释
·php.ini配置,php.ini 中的 php-5.2.0 配置指令详解
·总结:一些PHP学习过程中的心得和经验
·新手入门:JSP初学者必须掌握的语法点
·PHP技巧:PHP脚本编程中的文件系统函数库
·详细讲解PHP编程中分页显示的制作
·成为PHP编程高手应该遵循的三个准则
·谈谈生成静态页面的一些经验
·新手入门:详细解述七个软件开发的原则
·简单的webservice开发例子
热点TOP10
·一个Struts实现分页,增删改查,Tiles,国际化的DEMO
·80004005 及其它错误消息的疑难解答
·Windows XP下PHP+MySQL环境搭建
·菜鸟学PHP之Smarty入门
·MyEclipse+struts+Hibernate配置开发
·简单的webservice开发例子
·Php+Mysql注入专题
·学习教程:Java Annotation 高级应用
·PHP+Access设计留言版实战
·TomCat 多虚拟站点配置
·PHP 会话 (Session) 使用入门
·PHP 操作 XML 文件:读取、显示
·初学者学习PHP开发应该掌握的几段精华代码
·基于Servlet的Google Earth之旅
·模板用xml的思路
·动态网页制作学习:PHP预定义变量
·用PHP实现多级树型菜单
·php.ini配置,php.ini 中的 php-5.2.0 配置指令详解
·PHP预定义变量
·JDBC连接Oracle数据库常见问题及解决方法

PHP 会话 (Session) 使用入门

日期:2008年4月7日 作者: 查看:[大字体 中字体 小字体]


  对比起 Cookie,Session 是存储服务器端的会话,相对安全,并且不像 Cookie 那样有存储长度限制,本文简单介绍 Session 的使用。

  由于 Session 是以文本文件形式存储在服务器端的,所以不怕客户端修改 Session 内容。实际上在服务器端的 Session 文件,PHP 自动修改 Session 文件的权限,只保留了系统读和写权限,而且不能通过 FTP 修改,所以安全得多。

  对于 Cookie 来说,假设我们要验证用户是否登陆,就必须在 Cookie 中保存用户名和密码(可能是 md5 加密后字符串),并在每次请求页面的时候进行验证。如果用户名和密码存储在数据库,每次都要执行一次数据库查询,给数据库造成多余的负担。因为我们并不能只做一次验证。为什么呢?因为客户端 Cookie 中的信息是有可能被修改的。假如你存储 $admin 变量来表示用户是否登陆,$admin 为 true 的时候表示登陆,为 false 的时候表示未登录,在第一次通过验证后将 $admin 等于 true 存储在 Cookie,下次就不用验证了,这样对么?错了,假如有人伪造一个值为 true 的 $admin 变量那不是就立即取的了管理权限么?非常的不安全。

  而 Session 就不同了,Session 是存储在服务器端的,远程用户没办法修改 Session 文件的内容,因此我们可以单纯存储一个 $admin 变量来判断是否登陆,首次验证通过后设置 $admin 值为 true,以后判断该值是否为 true,假如不是,转入登陆界面,这样就可以减少很多数据库操作了。而且可以减少每次为了验证 Cookie 而传递密码的不安全性了(Session 验证只需要传递一次,假如你没有使用 SSL 安全协议的话)。即使密码进行了 md5 加密,也是很容易被截获的。

  当然使用 Session 还有很多优点,比如控制容易,可以按照用户自定义存储等(存储于数据库)。我这里就不多说了。

  Session 在 php.ini 是否需要设置呢?一般不需要的,因为并不是每个人都有修改 php.ini 的权限,默认 Session 的存放路径是服务器的系统临时文件夹,我们可以自定义存放在自己的文件夹里,这个稍后我会介绍。

  开始介绍如何创建 Session。非常简单,真的。

  启动 Session 会话,并创建一个 $admin 变量:

<?php
    
//  启动 Session
    
session_start
();
    
//  声明一个名为 admin 的变量,并赋空值。
    
$_SESSION["admin"] = null
;
?>

  如果你使用了 Seesion,或者该 PHP 文件要调用 Session 变量,那么就必须在调用 Session 之前启动它,使用 session_start() 函数。其它都不需要你设置了,PHP 自动完成 Session 文件的创建。

  执行完这个程序后,我们可以到系统临时文件夹找到这个 Session 文件,一般文件名形如:sess_4c83638b3b0dbf65583181c2f89168ec,后面是 32 位编码后的随机字符串。用编辑器打开它,看一下它的内容:

adminN;

一般该内容是这样的结构:

变量名类型:长度:值;

并用分号隔开每个变量。有些是可以省略的,比如长度和类型。

  我们来看一下验证程序,假设数据库存储的是用户名和 md5 加密后的密码:

login.php

<?php

[1] [2] [3] [4] [5] [6] [7] [8] [9] 下一页 




上一篇:如何正确理解 PHP 的错误信息

下一篇:用 PHP 编程语言开发动态 WAP 页面

PHP 会话 (Session) 使用入门 相关文章:
·最详细的黑客入门法则
·大智慧股票软件Level-2入门手册
·菜鸟入门 IE浏览器防黑技巧十则
·破解入门教学(二)
·新手入门:操作系统重装完全攻略
·从零开始学黑客:网络黑客新手入门指南
·Photoshop入门与进阶实例:开天辟地软件的界面设计
·DirectX游戏开发入门
·Windows下C语言网络编程快速入门
·菜鸟学PHP之Smarty入门
PHP 会话 (Session) 使用入门 相关软件:
·孙鑫VC++从入门到精通开发详解视频教程FLASH版
·CorelDraw12 入门与实例(图文教程 菜鸟先飞系列教材)
·Photoshop 入门教程
·催眠大师密训专业教程之入门指导手册(繁体版)
·Flash MX 从入门到精通
·ASP入门教程
·AutoCAD 14从入门到精通
·软件破解入门教程和解密手册
·巧夺天工Photoshop入门与进阶实例光盘
·扑克魔术入门必看

特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
[打印本页] [关闭窗口] 转载请注明来源:http://www.viphot.com
| 帮助(?) | 版权声明 | 友情连接 | 关于我们 | 信息发布
Copyright 2007 www.viphot.com All Rights Reserved. 鄂ICP备05000083号Powered by:vipcn