PHP session 失效不傳遞的解決辦法


PHP中,session不能傳遞到下一個頁面去,一般有兩種情況:

我們先寫個php文件:<?=phpinfo()?>, 傳到服務器去看看服務器的參數配置。

轉到session部分,看到session.use_trans_sid參數被設為了零。

這 個參數指定了是否啟用透明SID支持,即session是否隨着URL傳遞。我個人的理解是,一旦這個參數被設為0,那么每個URL都會啟一個 session。這樣后面頁面就無法追蹤得到前面一個頁面的session,也就是我們所說的無法傳遞。兩個頁面在服務器端生成了兩個session文 件,且無關聯。(不知道這樣理解對不對?請高手指教。)

所以一個辦法是在配置文件php.ini里把session.use_trans_sid的值改成1。

當然我們知道,不是誰都有權限去改php的配置的,那么還有什么間接的解決辦法呢?

下面就用兩個實例來說明吧:

文件1 test1.php

<?php
//表明是使用用戶ID為標識的session
session_id(SID);
//啟動session
session_start();

//將session的name賦值為Havi
$_SESSION['name']=”Havi”;
//輸出session,並設置超鏈接到第二頁test2.php
echo “<a href=\”test2.php\”>”.$_SESSION['name'].”</a>”;
?>

文件2: test2.php

<?php
表明是使用用戶ID為標識的session
session_id(SID);
//啟動session
session_start();

//輸出test1.php中傳遞的session。
echo “This is “.$_SESSION['name'];
?>

每個頁面都要寫開啟session哦。。不然還是不能正常工作

所以,重點是在session_start();前加上session_id(SID);,這樣頁面轉換時,服務器使用的是用戶保存在服務器session文件夾里的session,解決了傳遞的問題。

不過有同鞋會反映說,這樣一來,多個用戶的session寫在一個SID里了,那Session的價值就發揮不出來了。所以還有一招來解決此問題,不用加session_id(SID);前提是你對服務器的php.ini有配置的權限:

output_buffering改成ON,道理就不表了。

第二個可能的原因是對服務器保存session的文件夾沒有讀取的權限還是回到phpinfo.php中,查看session保存的地址:

session.save_path: var/tmp

所以就是檢查下var/tmp文件夾是否可寫。

寫一個文件:test3.php來測試一下:

<?
echo var_dump(is_writeable(ini_get(“session.save_path”)));
?>

如果返回bool(false),證明文件夾寫權限被限制了,那就換個文件夾咯,在你編寫的網頁里加入:

//設置當前目錄下session子文件夾為session保存路徑。
$sessSavePath = dirname(__FILE__).’/session/’;

//如果新路徑可讀可寫(可通過FTP上變更文件夾屬性為777實現),則讓該路徑生效。
if(is_writeable($sessSavePath) && is_readable($sessSavePath))
{session_save_path($sessSavePath);}

第一次些cms遇到這樣的問題,該文來自:http://blog.163.com/lin286679722@126/blog/static/111743825201072753634367/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM