導航:首頁 > IDC知識 > php二級域名session

php二級域名session

發布時間:2020-11-08 09:32:05

1、如何在PHP頁面設置session的作用域名

在guest裡面
<?php
session_start();
$pathinfo = pathinfo($_SERVER['PHP_SELF']);
$dir = str_replace('/','',$pathinfo['dirname']);

if( $dir != 'guest' )exit();
if($_SESSION['username'] != ''){

}

2、PHP網頁如何設置二級域名共享session

站點和站點之間是不能共享SESSION的,不管是幾級域名。但是可以通過寫cookie的方法或者單點登錄、WEBSERVICE等技術使站點之間的信息相互交換和共享。

3、php主域名和子域名怎麼樣共享session

這個 很明顯 需要傳遞session_id 只要傳遞了就能讀取一個

4、php怎樣實現用戶二級域名同時登陸問題

應該認真看PHP手冊裡面說的很明白的
bool setcookie ( string $name [, string $value [, int $expire [, string $path [, string $domain [, bool $secure [, bool $httponly]]]]]]

用SETCOOKIE函數就可以,有個可選參數是 string $domain 這個就是作用域名,比如你要設置www.aa.com 和bbs.aa.com 同樣有效就這個參數為".aa.com"記得前面有個.

5、php 一級域名和二級域名怎麼公用session值?能傳遞過去,到伺服器不會記錄session,怎

把session 設置在根域名下,
ini_set('session.cookie_domain', 'abc.com');

6、關於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="<a href=".""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="<a href=".""s2.php?s=".$sn."">下一頁</a>";
echo $url;
?>
s2.php
<?php
session_id($_GET['s']);
session_start();
echo "傳遞的session變數var1的值為:".$_SESSION['var1'];
?>
辦法3還是通過例子來說明:
login.html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Login</title>
<meta http-equiv="Content-Type" content="text/html; charset=??????">
</head>
<body>
請登錄:
<form name="login" method="post" action="mylogin1.php">
用戶名:<input type="text" name="name"><br>
口 令:<input type="password" name="pass"><br>
<input type="submit" value="登錄">
</form>
</body>
</html>
mylogin1.php
<?php
$name=$_POST['name'];
$pass=$_POST['pass'];
if(!$name || !$pass) {
echo "用戶名或密碼為空,請<a href="login.html">重新登錄</a>";
die();
}
if (!($name=="laogong" && $pass=="123")) {
echo "用戶名或密碼不正確,請<a href="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 "<a href="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 "請<a href="login.html">登錄</a>後瀏覽";
die();
}
?>

同樣請關閉cookie測試,用戶名:laogong 密碼:123 這是通過文件保存session id的,文件是:e: mpphpsid.txt,請根據自己的系統決定文件名或路徑。

至於用資料庫的方法,我就不舉例子了,與文件的方法類似。

總結一下,上面的方法有一個共同點,就是在前一頁取得session id,然後想辦法傳到下一頁,在下一頁的session_start();代碼之前加代碼session_id(傳過來的session id);

7、php如何實現多域名下的session共用

跨域啊,好像不行,試試GETJSON

8、為什麼在二級域名中取不到session?

session是針對域名的 不是針對目錄的 要不同域名下session通用要做共享處理 可以用資料庫存儲或者其他方法~

9、php 如何使用session 讓同一伺服器上的2個域名同時登錄

可以做到session分發
/**
* 子站點分發方法,將用戶信息和對應的秘鑰發送到子站點
* 子站點必須有對應的方法
*/
public function distributeCheckLogin(){
//多個站點發送

foreach($this->urlMap as $key=>$val){
$data['userInfo'] = $_SESSION['userInfo'];
$data['key'] = md5($data['userInfo']['id'].'_'.$val['key']);
$json = base64_encode(json_encode($data));
//$val 相當於http://b.com
echo "<script src='{$val}/Login/Oos/checkLoginKey/token/{$json}'></script>";
}

}
這個方法放在b.com裡面/Login/Oos/這個下面具體自己完善,我給的使我們這邊的思路
public function checkLoginKey(){
$token = json_decode(base64_decode($_GET['token']),true);
if( md5($token['userInfo']['id'].'_'.$this->deploy['USER_KEY']) != $token['key']){
return false;
}
$_SESSION['userInfo'] = $token['userInfo'];
}

與php二級域名session相關的知識