PHP Curl と Cookie 認証に問題があります。
別のサーバーでユーザーを認証し、現在のユーザーの Cookie を返すファイルConnector.phpがあります。
問題は、curl を使用して何千ものユーザーを認証したいのですが、一度に 1 人のユーザーに対してのみ COOKIES を認証して保存することです。
connector.php のコードは次のとおりです。
<?php
if(!count($_REQUEST)) {
die("No Access!");
}
//Core Url For Services
define ('ServiceCore', 'http://example.com/core/');
//Which Internal Service Should Be Called
$path = $_GET['service'];
//Service To Be Queried
$url = ServiceCore.$path;
//Open the Curl session
$session = curl_init($url);
// If it's a GET, put the GET data in the body
if ($_GET['service']) {
//Iterate Over GET Vars
$postvars = '';
foreach($_GET as $key=>$val) {
if($key!='service') {
$postvars.="$key=$val&";
}
}
curl_setopt ($session, CURLOPT_POST, true);
curl_setopt ($session, CURLOPT_POSTFIELDS, $postvars);
}
//Create And Save Cookies
$tmpfname = dirname(__FILE__).'/cookie.txt';
curl_setopt($session, CURLOPT_COOKIEJAR, $tmpfname);
curl_setopt($session, CURLOPT_COOKIEFILE, $tmpfname);
curl_setopt($session, CURLOPT_HEADER, false);
curl_setopt($session, CURLOPT_RETURNTRANSFER, true);
curl_setopt($session, CURLOPT_FOLLOWLOCATION, true);
// EXECUTE
$json = curl_exec($session);
echo $json;
curl_close($session);
?>
認証のプロセスは次のとおりです。
- ユーザーはユーザー名とパスワードを入力します。
Connector.php?service=logon&user_name=user32&user_pass=123
Connector.php?service=logosessionInfo
ログオン サービスで以前に保存された Cookie に基づいて、ユーザーに関する情報を返します。
問題は、このコードがユーザーごとに 1 つのファイルに Cookie を保存し、複数のユーザー認証を処理できないことです。