phpsession赋值
① 关于php中SESSION取值的问题
在PHP中使用过SESSION的朋友可能会碰到这么一个问题,SESSION变量不能跨页传递。这令我苦恼了好些日子,最终通过查资料思考并解决了这个问题。我认为,出现这个问题的原因有以下几点:
1、客户端禁用了cookie
2、浏览器出现问题,暂时无法存取cookie
3、php.ini中的session.use_trans_sid = 0或者编译时没有打开--enable-trans-sid选项
为什么会这样呢?下面我解释一下:
Session储存于服务器端(默认以文件方式存储session),根据客户端提供的session id来得到用户的文件,取得变量的值,session id可以使用客户端的Cookie或者Http1.1协议的Query_String(就是访问的URL的“?”后面的部分)来传送给服务器,然后服务器读取Session的目录……。也就是说,session id是取得存储在服务上的session变量的身份证。当代码session_start();运行的时候,就在服务器上产生了一个session文件,随之也产生了与之唯一对应的一个session id,定义session变量以一定形式存储在刚才产生的session文件中。通过session id,可以取出定义的变量。跨页后,为了使用session,你必须又执行session_start();将又会产生一个session文件,与之对应产生相应的session id,用这个session id是取不出前面提到的第一个session文件中的变量的,因为这个session id不是打开它的“钥匙”。如果在session_start();之前加代码session_id($session id);将不产生新的session文件,直接读取与这个id对应的session文件。
PHP中的session在默认情况下是使用客户端的Cookie来保存session id的,所以当客户端的cookie出现问题的时候就会影响session了。必须注意的是:session不一定必须依赖cookie,这也是session相比cookie的高明之处。当客户端的Cookie被禁用或出现问题时,PHP会自动把session id附着在URL中,这样再通过session id就能跨页使用session变量了。但这种附着也是有一定条件的,即“php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项”。
明白了以上的道理,现在我们来抛开cookie使用session,主要途径有三条:
1、设置php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项,让PHP自动跨页传递session id。
2、手动通过URL传值、隐藏表单传递session id。
3、用文件、数据库等形式保存session_id,在跨页过程中手动调用。
通过例子来说明吧:
s1.php
<?php
session_start();
$_SESSION['var1']="中华人民共和国";
$url="<ahref=".""s2.php">下一页</a>";
echo$url;
?>
s2.php
<?php
session_start();
echo"传递的session变量var1的值为:".$_SESSION['var1'];
?>
运行以上代码,在客户端cookie正常的情况下,应该可以在得到结果“中华人民共和国”。
现在你手动关闭客户端的cookie,再运行,可能得不到结果了吧。如果得不到结果,再“设置php.ini中的session.use_trans_sid = 1或者编译时打开打开了--enable-trans-sid选项”,又得到结果“中华人民共和国”
这也就是上面所说的途径1。
下面再说途径2:
修改的代码如下:
s1.php
<?php
session_start();
$_SESSION['var1']="中华人民共和国";
$sn=session_id();
$url="<ahref=".""s2.php?s=".$sn."">下一页</a>";
echo$url;
?>
s2.php
<?php
session_id($_GET['s']);
session_start();
echo"传递的session变量var1的值为:".$_SESSION['var1'];
?>
办法3还是通过例子来说明:
login.html
<!DOCTYPEHTMLPUBLIC"-//W3C//DTDHTML4.01Transitional//EN">
<html>
<head>
<title>Login</title>
<metahttp-equiv="Content-Type"content="text/html;charset=??????">
</head>
<body>
请登录:
<formname="login"method="post"action="mylogin1.php">
用户名:<inputtype="text"name="name"><br>
口令:<inputtype="password"name="pass"><br>
<inputtype="submit"value="登录">
</form>
</body>
</html>
mylogin1.php
<?php
$name=$_POST['name'];
$pass=$_POST['pass'];
if(!$name||!$pass){
echo"用户名或密码为空,请<ahref="login.html">重新登录</a>";
die();
}
if(!($name=="laogong"&&$pass=="123")){
echo"用户名或密码不正确,请<ahref="login.html">重新登录</a>";
die();
}
//注册用户
ob_start();
session_start();
$_SESSION['user']=$name;
$psid=session_id();
$fp=fopen("e:\tmp\phpsid.txt","w+");
fwrite($fp,$psid);
fclose($fp);
//身份验证成功,进行相关操作
echo"已登录<br>";
echo"<ahref="mylogin2.php">下一页</a>";
?>
mylogin2.php
<?php
$fp=fopen("e:\tmp\phpsid.txt","r");
$sid=fread($fp,1024);
fclose($fp);
session_id($sid);
session_start();
if(isset($_SESSION['user'])&&$_SESSION['user']="laogong"){
echo"已登录!";
}
else{
//成功登录进行相关操作
echo"未登录,无权访问";
echo"请<ahref="login.html">登录</a>后浏览";
die();
}
?>
同样请关闭cookie测试,用户名:laogong 密码:123 这是通过文件保存session id的,文件是:e: mpphpsid.txt,请根据自己的系统决定文件名或路径。
至于用数据库的方法,我就不举例子了,与文件的方法类似。
总结一下,上面的方法有一个共同点,就是在前一页取得session id,然后想办法传到下一页,在下一页的session_start();代码之前加代码session_id(传过来的session id);
② php session 在多个客户端同时调用时是否会重新赋值
互不干扰的。
session生成时生成一个带有session_id 的文件。
不同客户端默认生成的session内容储存在不同的文件中。
具体的你可以看一下php.ini中的session_save_path
储存session文件的目录。看看客户端生成session的机制。
③ PHP post值提交与session赋值
看的有点乱,登陆页面时做在哪个服务器上的?看你写的好像是在B服务器上的,但是登陆在B服务器上那你还要从A服务器上传什么值?
还有session不能用来跨服务器传值,只能通过post或者url或者cookie(不太安全)。
④ thinkphp中怎么在view给session赋值
具体看代码;
class ArticlelModel extends Model {
protected $_auto = array (
array('addtime','time',1,'function'),
array('username','getName',1,'callback')
);
//这个函数获取session里的name值
protected function getName(){
return $_SESSION["name"];
}
}
这里需要注意最后一个参数function和callback的区别;
function:使用函数,会自动去Common/common.php去寻找对应的函数;
callback:使用在当前模型中定义的回调方法
Session 用于Session 设置、获取、删除和管理操作
用法
session($name, $value='')
参数
name(必须):如果传入数组 则表示进行session初始化,如果传入null表示清空当前session,如果是字符串则表示session赋值、获取或者操作。
Value(可选):要设置的session值,如果传入null表示删除session,默认为空字符串
返回值
见详(根据具体的用法返回不同的值)
session函数是一个多元化操作函数,传入不同的参数调用可以完成不同的功能操作,包括下面一些功能。[-more-]
session初始化设置
如果session方法的name参数传入数组则表示进行session初始化设置,例如:
session(array('name'=>'session_id','expire'=>3600));
支持传入的session参数包括:
参数名
说明
id
session_id值
name
session_name 值
path
session_save_path 值
prefix
session 本地化空间前缀
expire
session.gc_maxlifetime 设置值
domain
session.cookie_domain 设置值
use_cookies
session.use_cookies 设置值
use_trans_sid
session.use_trans_sid 设置值
cache_limiter
session_cache_limiter设置值
cache_expire
session_cache_expire设置值
type
session hander类型,可以使用hander驱动扩展
Session初始化设置方法 无需手动调用,在App类的初始化工作结束后会自动调用,通常项目只需要配置SESSION_OPTIONS参数即可,SESSION_OPTIONS参数的设置是一个数组,支持的索引名和前面的session初始化参数相同。
默认情况下,初始化之后系统会自动启动session,如果不希望系统自动启动session的话,可以设置SESSION_AUTO_START为false,例如:
'SESSION_AUTO_START' =>false
关闭自动启动后可以项目的公共文件或者在控制器中通过手动调用session_start或者session('[start]') 启动session。
session赋值
Session赋值比较简单,直接使用:
session('name','value'); //设置session
相当于:
$_SESSION['name'] = 'value';
session取值
Session取值使用:
$value = session('name');
相当于使用:
$value = $_SESSION['name'];
session删除
session('name',null); // 删除name
相当于:
unset($_SESSION['name']);
要删除所有的session,可以使用:
session(null); // 清空当前的session
相当于:
$_SESSION = array();
session判断
要判断一个session值是否已经设置,可以使用
session('?name');
用于判断名称为name的session值是否已经设置
相当于:
isset($_SESSION['name']);
session管理
session方法支持一些简单的session管理操作,用法如下:
session('[操作名]');
支持的操作名包括:
操作名
含义
start
启动session
pause
暂停session写入
destroy
销毁session
regenerate
重新生成session id
使用示例如下:
session('[pause]'); // 暂停session写入
session('[start]'); // 启动session
session('[destroy]'); // 销毁session
session('[regenerate]'); // 重新生成session id
本地化支持
如果在初始化session设置的时候传入prefix参数或者单独设置了SESSION_PREFIX参数的话,就可以启用本地化session管理支持。启动本地化session后,所有的赋值、取值、删除以及判断操作都会自动支持本地化session。
本地化session支持开启后,生成的session数据格式由原来的
$_SESSION['name'] 变成 $_SESSION['前缀']['name']
假设前缀设置为think,则赋值操作:
session('name','value'); //设置session
相当于:
$_SESSION['think']['name'] = 'value';
取值操作:
$value = session('name');
相当于使用:
$value = $_SESSION['think']['name'];
删除操作:
session('name',null);
相当于:
unset($_SESSION['think']['name']);
清空操作:
session(null);
相当于:
unset($_SESSION['think']);
判断操作:
session('?name');
相当于:
isset($_SESSION['think']['name']);
⑤ php中$_session[]是什么意思
用户会话保存变量
1.php文件
<?php
session_start();
$_SESSION["str"]="我是中国人!!!";
?>
2.php文件
<?php
session_start();
echo $_SESSION["str"];
?>
先执行1.php,,再执行2.php,,会看到在1.php里面设置的变量被输出了,,就这作用,,用来保存跨域的变量
楼上说的不对,,session虽说是保存在服务器端,,但对客户端仍有数据发送,并且是以cookie的方式,,如果客户端禁用了cookie,,session也是用不了的.....还有,,session也是可以造假的...并不一定百分之一百安全
⑥ PHP中怎样将Session里面的值 赋给页面的一个文本里面
<input type="text" name="text1" value="<?php echo $_SESSION['code']?>"/>
⑦ php SESSION用法 $_SESSION['']初始值
注意,在使用session之前一定要调用
<?php
session_start();
开始会话,否则会出错。在你的代码里我看不到。
$_SESSION数组的使用类似于普通数组。但它是有”魔法“的。当页面结束后,$_SESSION的内容会被PHP解析器自动保存下来,同时在用户的浏览器留下一个cookie。下次用户访问时,使用该cookie继续会话。
所以,检查一个session是否存在和普通数组一样:
<?php
//正确,检查flag下标是否设置
if(isset($_SESSION['flag']))...
//错误,会导致警告,下标不存在
if($_SESSION['flag'])...
//存储一个session值
$_SESSION['flag']=1;
//删除一个session值
unset($_SESSION['flag']);
一个没有设置的session是没有初始值的。就像你初始化一个空数组一样。
⑧ php 怎么使用session
PHP session用法其实很简单它可以把用户提交的数据以全局变量形式保存在一个session中并且会生成一个唯一的session_id,这样就是为了多了不会产生混乱了,并且session中同一浏览器同一站点只能有一个session_id,下面我们一起来看看关于session使用方法。
如何使用session,凡是与session有关的,之前必须调用函数session_start();
为session赋值很简单,如:
<?php
Session_start();
$Name = "这是一个Session例子";
Session_Register("Name");//注意,不要写成:Session_Register("$Name");
Echo $_SESSION["Name"];
//之后$_SESSION["Name"]为"这是一个Session例子"
?>
在php4.2之后,可以为session直接赋值:
复制代码 代码如下:
<?PHP
Session_Start();
$_SESSION["name"]="value";
?>
⑨ php session是如何赋值如何查看的
php session赋值,就是通过在在php的页面中开启你的session,通过session_start();开启之后就可以像普通变量那样赋初值,$_SESSION['admin'] = 'admin',这样的赋值的,还有一种就是通过html的表单传值过来,$_SESSION['admin'] = $_POST['admin'],这样来赋值的,session我们一般都是用在验证是否已经登录使用,举个例子:
<?php
session_start();
if(!isset($_SESSION[$adminconf['admin']]) || $_SESSION[$adminconf['admin']] ==''){
header('Location:'.APP_MAIN.'/stie/admin_login.php'); //跳回到登录界面
exit();
}
?>