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();
}
?>