首頁  >  文章  >  後端開發  >  會話開始();

會話開始();

巴扎黑
巴扎黑原創
2016-11-30 09:23:231567瀏覽

對於PHP的session功能,始終找不到合適的答案,尤其是一些錯誤,還有一些沒有錯誤的結果,最可怕的就是後者,一直為許多的初學者為難。就連有些老手,有時都被搞得莫名其妙。本文,將這些問題,做一個簡單的總結,以便大家查閱。

1. 
錯誤提示 
Warning: Cannot send session cookie - headers already sent 
Warning: Cannot send session cache limiter - headers already s session_start()時,之前已經有實際的html內容輸出了。或許你說,我沒有啊,我只不過是echo或print一則訊息了。很抱歉,你的echo或print語句所產生的輸出,就是實際html的內容輸出。解決這類問題的方法是,將你的session_start()調到程式的第一行。

2. 

錯誤提示 

Warning: open(F:/689phpsessiondatasess_66a39376b873f4daecf239891edc98b5, O_RDWR) failed sion)沒有設定好,解決的方法是將session.save_path和session.cookie_path 設定置為 
session_save_path = c: emp 
session.cookie_path = c: emp 
然後在c:目錄下建立一個temp目錄,即可提示

3.
Warning: Trying to destroy uninitialized session in 
分析及解決方法 

出類這樣的提示,一般情況都是你直接調session_destroy()函數造成的。很多的朋友認為session_destroy()函數可以獨立的運行,其實不然。解決的方法是在你調session_destroy()函數之前,要用PHP session_start()開啟session的函數。


4.問題:怎麼得到目前session的id值呢? 
最簡單的方法是: 
echo SID; 
你會發現的。

5.問題:我的程序,在調用header函數之前沒有任何的輸出,雖然我include了一個config.php文件,但在config.php文件中也沒有任何的輸出,為什麼session還是會報出與問題1同樣的錯誤呢,是不是因為我在header之前用了PHP session_start()的緣故呢?

答:或許你確實認真的檢查了你的php程序,在引用header()之前確實也沒有任何的輸出,並且在你的include文件中也沒有任何的輸出!但是你是否用遊標鍵在?>這個PHP碼結束語句後移動檢查呢?那你會發現在?>這個後面,有一個空行或幾個空格,你刪除了這幾個空行或空格,那麼問題就解決了。

註:此問題,會出PHP4.1.2中,更高版本,沒有測試過。

6.問:用session做登入主頁面後,其它頁面怎麼用session限制登入。 。 。

答:最簡單的方法是

session_start();

if(!session_registered
('login')

││$login!=true){

echo"你沒有登陸";

}

7.問:我用session_register()註冊了session變量,可是當我用header或用javascript的重定向語句,那麼在一下頁面中,我卻訪問不到session所註冊的變量值。請問如何解決?

問題的程式片段:

session_start();$ok='loveyou';session_register('ok');header("location:next.php");?>next.phpsession_start();echo$ok;? >

解決的方法: 

當你用header函數或window.location這樣的功能後,你上一個頁面所註冊的session變量,就會容易的丟失,關於這個問題的原因,至今仍沒有一個詳細的回答。 

不過有解決的方法。如下圖 
header("Location: next.php" ."?" . SID); 

在跳到下一頁的時候,將session的當前id做為一個參數,傳到後一個頁面。


8.session如何傳數組

session_register
('data');

$data=array(1,2,3,4);

方法是​​先註冊後賦值

問題9:我先註冊後賦值


是不是可以用像$HTTP_GET_VARS['**']方式存取session值呢?

回答:可以,你可以使用以下global數組來存取session,以加強網頁的安全性 

$HTTP_SESSION_VARS 

$_SESSION 

例程:

session_start();


session_register('
username');

echo$HTTP_SESSION_VARS

['username'];

echo'

';請參照此例程修改符合您自己的程式。


問題10:session_unregister() 和 session_destroy() 有何不同? 

session_unregister()函數主要作用是註消目前的一sion.(譯自於php.net)


程式:

if(isset($_COOKIE[session_name()])){session_start();session_destroy();unset($_COOKIE[session_name()]);}


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn