2016-05-05 4 views
3

私は、Windows上で実行されているASPクラシックで書かれたログインで保護されたバックオフィスのWebサイトを持っています。ログイン状態はセッション変数に格納されます。また、ログインしたユーザーだけがアクセスできるPHPページもあります。クライアントがこのウェブサイトにログインしていることをPHPでチェックするにはどうすればよいですか?PHPからASPの古典的なセッション変数にアクセスするには?

P.S.同時に複数のユーザーがページにアクセスしている可能性があります。

答えて

6

PHPとASPの両方のアプリケーションが同じドメイン名を共有していると仮定すると、ここではステップバイステップガイドです。

1 - sessionConnector.aspという名前のaspファイルを作成します。

2 - sessionConnector.aspでは、Session.Contentsオブジェクトを、PHPが直列化解除できる形式のJSONなどにシリアル化します。 JSON.aspaspjsonです。

<%@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 
} 
関連する問題