php的session 有什么用
session是什么,刚开始我也不明白,非专业词典翻译为会议,会议期。
直到接触asp后才知道session是干什么的,有什么用。
作个不太恰当的比喻吧(虽然不恰当,但意义却是一样的),session就好象你和你女友(或妻子)之间的感情似的,session是你和网站之间的感情。
session在WEB技术中占有非常重要的份量。
由于网页是一种无状态的连接程序,因此你无法得知用户的浏览状态。
因此我们必须
通过session记录用户的有关信息,以供用户再次以此身份对web服务器提供要求时作确认,例如,我们在某些网站中常常要求用户登录,
但我们怎么知道用户已经登录了呢,如果没有session的话,登录信息是无法保留的,那岂不要让用户在每一页网页中都要提供
用户名和密码。
当然,session不光用于用户身份认证功能,还可能用于其它方面,以后我们会提到的。
session用中文来解释就是会话期。
一个会话期开始于用户输入一个站点的网址时,结束于他离开这个站点时。
session最早出现在动态脚本语言Active Server Pages中,它的功能之强大,是一句话无法说清楚的。
当php还在3.0版本时,session是它永远的痛。
虽然php具有执行速度快,使用灵活,功能强大等优点,但因为session的问题,使很多站点的开发放弃了php,至少我的老板是这样认为的。
当时有很多php免费函数库提供在php3上实现session的方案,但都让人感觉不正宗。
就好象你花好几千大洋买的手机却配置一个很粗糙的草作的袋子一样,虽然功能是一样的,但总让人觉得别扭。
php4的出现让php在session问题上
有了翻身的机会。
虽然它的session实现还不是很理想(主要是效率问题),但毕竟是它自己实现的,而且可以实际使用了。
那我们用session干什么呢,你说了半天,我用不上的话,你岂不有卖纸张之嫌。
OK,我们来看看session有什么用:作过网站的人都有这样的体会,在一页页面中的变量(在本章都指服务器端变量,下同)是不能在下一页中用的,虽然有一些办法可以实现,比如用form,urlstring等等
但有些对于用户来说是不方便的,即使让form自动提交,但其中的延时在现今的网络状况下足以让人窒息,而这两种方法都明显加大程序员的负担。
如果你正在开发一个大型项目,那这些额外的负担是不能忽略的。
而有了session就好办了,session中注册的变量可以作为全局变量使用。
什么,全局变量?
好极了。
这样一来,你知道有什么用了吧:最主要的用于用户身份认证,程序状态记录,页面之间参数传递。
说了它这么半天的好处,你已经动心了吧,先别高兴,它还有缺点呢:它是用文件保存的变量(当然效率不高了,虽然可以用别的方式,但
很麻烦的),不能保存对象。
与之相对的是,asp中的session可以保存对象变量,用内存变量来保存session变量。
但为什么我们还选用php呢,呵呵,
为什么,你能从本书的开始看到这章,想必你也应该明白了吧,你还不明白,Faint,你再从头看起吧,我保证你成为PHP专家^_^。
session是怎样实现的呢?呵呵,你一定以为很高深吧,我来告诉你它的秘密。
如果说只保存变量的话,很多读者都明白,这是很简单的,
但前面我们说过,http协议是一种无状态的连接,你怎么知道那个变量是谁的,这个变量又是谁的呢?在session实现中用cookie实现的。
cookie
存在于客户端,也就是用户的机器中,里面保存着用户的session ID,也就是session号码,当用户的浏览器请求服务器时把session ID也一起送到
服务器,这样服务器就可以识别你是谁,也就可以把变量识别开了。
这样我们就不难理解了,为什么有时session会失效了。
不信的话,你可以试试:
在IE的"工具"菜单上有"选项"菜单,打开后再选"安全"->"自定义级别",将安全设置中的"允许使用每个对话cookies"设为禁用,再看看
session能不能用。
这下明白了吧!不过php4在linux/unix平台上可以自动检查cookies状态,当cookies 不可用时,自动会把session ID
附带在url上进行传递。
这是它在session方面比asp多的唯一的优点了。
php session原理
session有多种实现方式,
可以用mysql的表存储(表类型为 内存)
也可以用文件保存
他们都在服务器中存储。
php中的session该怎么理解
Session是个容器里面保存的当前连接的部分信息,以及编程人员自己存入的一些信息。
由于我们http协议不是一直和服务器连接的当1次请求回应完成后到下一次请求直接其实没和服务器连接
为了实现一直连接的话我们要引入Session这个容器来保存一些信息造成一直连接的假象
举个最简单的例子,我们登录一个网站输入用户名和密码后登陆成功转到成功页之后再你没有请求时我们已经断开了喝服务器的链接 这时候其实服务器已井丢掉了你的登陆信息的 当你在做一些事情比如点开一个超链接时我们不用再输入用户名和密码的实现这个的就是用的session
session里也可保存我们自己想要村的任何东西最常见的用处是登陆后显示的用户昵称,购物车里的物品基本都是存在session里的
并且session会为每个新的连接创建一个也就是说每个连接有自己的专门的session互相之间不能访问
最后就是session的存在时间
我们可以再用户点注销时释放他的session,但80%的用户都是习惯的关闭浏览器这时我们无法知道的所以
session有个存在时间当一定时间没有请求时就会自己释放!
PHP中 cookies和SEssion的详细用法
一、sesion 是一个常用的方法,在不同的编程语言中的用法不一样。
下面就把如何在php中用session和大家分享一下。
page1:session.php
<?php
session_start();
session_register("username");
$_SESSION['username']='user';
?>
这个页面是给session变量附值,与数据库结结合方法也是一样的。
我们可以根据需要设置session的属性。
page2:session1.php
<?php session_start();
echo $_SESSION['username'];
?>
这个页面主要是输出session的值,但是我们要注意。
session_start();
一定要在每次使用之前打开。
好了,这是使用session的一般方法。
希望对你有用。
二、Cookies的使用。
例子 1. setcookie() 发送例子 $value = 'something from somewhere';
setcookie("TestCookie", $value);
setcookie("TestCookie", $value,time()+3600); /* expire in 1 hour */
setcookie("TestCookie", $value,time()+3600, "/~rasmus/", ".utoronto.ca", 1);
注意 cookie 中值的部分在发送的时候会被自动用 urlencode 编码并在接收到的时候被自动解码并把值赋给与自己同名的 cookie 变量。
如果不想这样并且在使用 PHP 5 的话,可以用 setrawcookie() 来代替。
下面这个简单的例子可以得到刚才所设定的 cookie 的值:
<?php
// 输出单独的 cookie
echo $_COOKIE["TestCookie"];
echo $HTTP_COOKIE_VARS["TestCookie"];
// 另一个调试的方法就是输出所有的 cookie
print_r($_COOKIE);
?>
要删除 cookie 需要确保它的失效期是在过去,才能触发浏览器的删除机制。
下面的例子说明了如何删除刚才设置的 cookie:
例子 2. setcookie() 删除例子 // 将过期时间设为一小时前
setcookie("TestCookie", "", time() - 3600);
setcookie("TestCookie", "", time() - 3600, "/~rasmus/", ".utoronto.ca", 1);
也可以通过在 cookie 名称中使用数组符号来设定数组 cookie,可以设定多个 cookie 作为数组单元,在脚本提取 cookie 时所有的值都放在一个数组种: 例子 3. setcookie() 中使用数组的例子 <?php
// 设定 cookie
setcookie("cookie[three]", "cookiethree");
setcookie("cookie[two]", "cookietwo");
setcookie("cookie[one]", "cookieone");
// 刷新页面后,显示出来
if (isset($_COOKIE['cookie'])) {
foreach ($_COOKIE['cookie'] as $name => $value) {
echo "$name : $value <br />
";
}
}
?>
这就是session 和cookie 的使用方法。
php语言中session指的是甚么
不管php还是jspsession都是会话对象保存临时数据的,比如你做个用户登录功能,要记住用户的状态,就能够把用户的值存到session里。
然后只要这个状态存在,就能够在其他页面取到这个session里的值