私は、Windows上で実行されているASPクラシックで書かれたログインで保護されたバックオフィスのWebサイトを持っています。ログイン状態はセッション変数に格納されます。また、ログインしたユーザーだけがアクセスできるPHPページもあります。クライアントがこのウェブサイトにログインしていることをPHPでチェックするにはどうすればよいですか?PHPからASPの古典的なセッション変数にアクセスするには?
P.S.同時に複数のユーザーがページにアクセスしている可能性があります。
私は、Windows上で実行されているASPクラシックで書かれたログインで保護されたバックオフィスのWebサイトを持っています。ログイン状態はセッション変数に格納されます。また、ログインしたユーザーだけがアクセスできるPHPページもあります。クライアントがこのウェブサイトにログインしていることをPHPでチェックするにはどうすればよいですか?PHPからASPの古典的なセッション変数にアクセスするには?
P.S.同時に複数のユーザーがページにアクセスしている可能性があります。
PHPとASPの両方のアプリケーションが同じドメイン名を共有していると仮定すると、ここではステップバイステップガイドです。
1 - sessionConnector.asp
という名前のaspファイルを作成します。
2 - sessionConnector.asp
では、Session.Contents
オブジェクトを、PHPが直列化解除できる形式のJSONなどにシリアル化します。 JSON.asp
はaspjsonです。
<%@Language=VBScript CodePage=65001%>
<!--#include file="JSON.asp"-->
<%
Set JSONObject = jsObject()
For Each Key In Session.Contents
If Not IsObject(Session.Contents(Key)) Then 'skip the objects cannot be serialized
JSONObject(Key) = Session.Contents(Key)
End If
Next
JSONObject.Flush
%>
3からGetASPSessionState()
という名前のPHP関数を作成します。
4からGetASPSessionState()
において、ASPは、ユーザを識別することができ、応答はユーザによって異なりますので、必要ASPセッションの識別子を含む$_SERVER["HTTP_COOKIE"]
で満たさCookie
ヘッダを指定することにより、sessionConnector.asp
のHTTP要求を行います。
5 - レスポンス(JSONの文字列)を取得した後、json_decodeを使用して逆シリアル化し、ASPセッション変数を探します。
function GetASPSessionState(){
if(stripos($_SERVER["HTTP_COOKIE"], "ASPSESSIONID") === false){
# since ASP sessions stored in memory
# don't make request to get ASP session state if the cookie does not contain ASPSESSIONID
# otherwise IIS will create new redundant sessions for each of your checks so it wouldn't be a memory-friendly way
# returning an empty array
return array();
} else {
$options = array('http' =>
array('method'=>"GET", 'header' => "Cookie: " . $_SERVER["HTTP_COOKIE"])
);
$cx = stream_context_create($options);
$response = file_get_contents("http://mywebsite.com/sessionConnector.asp", false, $cx);
return json_decode($response, JSON_FORCE_OBJECT);
}
}
$aspSessionState = GetASPSessionState();
if($aspSessionState["IsLoggedIn"] == true){
//user previously logged in with the ASP
}