sidphp
① 關於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.use_trans_sid 的值
您好:
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選項」。
③ 不完整的HTTP請求行(sid和PHPSESSID被刪除)這是怎麼會事
如果正常執行,返回值為1;
如果拋出ArithmeticException,返回值為2;
如果拋出其他Exception,則拋出該Exception,無返回值。
④ php中在循環外部如何強制結束循環
不可能。PHP 是單線程的。如果這個線程正在執行一個循環。就只能在循環中做條件判斷。不可能有另外的代碼同時在運行。。自然也不能通過其它代碼中斷它。。
如果你一定要這么做,我這里只有一個不是辦法的辦法。。。在循環裡面寫一個讀取文件。判斷這個文件的內容是0還是1。。如果是0則中斷。。這樣。如果在循環結束之前。有東西把這個文件的內容變成 0 了。那循環也就中斷了。。
不過,這樣的做法效果非常低。。你也可以改為。判斷一個文件是否存在。。如果存在則中斷循環並刪除這個文件。以便下次可以繼續循環。。任意程序只要創建了這個文件就會讓循環中斷。
⑤ php 身份證 正則 檢測是否有效怎麼寫
你的正則表達式的規則錯了。。當然不能執行啦
http://blog.sina.com.cn/s/blog_461c24d50100dtnz.html
這是規則。如果你只是拿來主義,就無視吧。
代碼長篇大論,是對你負責;說真的,網路沒幾個願意自己寫那麼多字的人。我第二程序是自己寫的,試驗過了。可以自動把身份證升級到18位,然後驗證。
正則表達式其實是來自數學的概念,後來加入了編程語言。正則表達式驗證身份證簡單,但是有缺點,你的要求是:驗證出身年月日,很可惜,正則沒辦法驗證的太完善。也就是說只要符合規則就是正確(比如19940939之類的出生年月。。。),所以寫程序就是為了完善它。話說多了= =不採納也沒辦法。我自認為我比樓上的好多了。
<?php
$s15="/^[0-9]{15}$/";
//15位正則表達式
$s18="/^[0-9]{6}[1]{1}[9]{1}[0-9]{2}[0-1]{1}[0-9]{1}[0-3]{1}[0-9]{1}[0-9]{3}[0-9X]{1}$/";
//18位正則表達式
$sid="18位或者15位身份證";
if(preg_match($s15,$sid) or preg_match($s18,$sid))
//如果滿足這兩個條件的其中一個,輸出echo
echo 'ok';
else
echo 'no';
?>
簡單不好用,我花了一個小時寫了一個15位轉18位然後自動驗證的函數:
<?php
function check($sid)
{
if(strlen($sid)== 15)
//如果是15身份證,進入自動轉換程序,把15位升級到18位
{
$wi=array('7','9','10','5','8','4','2','1','6','3','7','9','10','5','8','4','2','1');
$sid=substr_replace($sid,19,6,0);
$count=array();
for($i=0;$i<18;++$i)
{
@$count[$i]=$sid[$i]*$wi[$i];
}
$sum=array_sum($count)%11;
$zuihou=array('1','0','X','9','8','7','6','5','4','3','2');
$sid=substr_replace($sid,$zuihou[$sum],17,0);
//這個sid是18位的。= = 不信你拿自己的身份證(15位)放過來試驗,肯定沒錯。
}
$wi18=array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);
$sum2=array();
for($j=0;$j<17;$j++)
{
$sum2[$j]=$sid[$j]*$wi18[$j];
}
$sum2=array_sum($sum2)%11;
$yz=array('1','0','X','9','8','7','6','5','4','3','2');
if($yz[$sum2] == $sid[17])
//如果最後一位和驗證號一樣,則返回真
return true;
else
return false;
}
$sid="18位或者15位身份證";
if(check($sid))
echo '是正確的身份證';
else
echo '身份證不正確';
?>
⑥ php網站的用戶sid怎麼做
調取用戶信息加密,需要驗證的地方,調取資料庫,加密,對比,如果相同,則登陸成功設置SESSION或cookies