openssl_pkey_get_details() ожидает, что параметр 1 будет ресурсом, логическое значение
Я нашел этот сценарий "где-то":
define("ACC_NAME", "my_steam_login");
define("ACC_PASS", "my_password");
define("GROUP_ID", "my_group_id"); // open steam group page and see "Enterchat room" link, which contains ID
define("MY_STEAM_ID", "my_steamid"); // steam ID which can invite to join group
$invite_steam_id = $_GET['i'];
$ids = file('invited_ids.txt');
foreach($ids as $id){
$id = trim($id);
if ( $id == $invite_steam_id )
die($id .": Already invited!\n");
}
function _curl_parse_cookiefile($file){
$aCookies = array();
$aLines = file($file);
foreach($aLines as $line){
if('#'==$line{0})
continue;
$arr = explode("\t", $line);
if(isset($arr[5]) && isset($arr[6]))
$aCookies[$arr[5]] = $arr[6];
}
return $aCookies;
}
function GetFriendID( $steam_id ) {
if ( !$steam_id )
return 0;
$auth = explode(':', $steam_id);
if ( !$auth[2] )
return 0;
$fid = $auth[2];
$fid *=2;
$fid += 76561197960265728;
$fid += $auth[1];
return $fid;
}
$mid = GetFriendID(MY_STEAM_ID);
$fid = GetFriendID($invite_steam_id);
class RSAHelper{
var $pubkey;
public function __construct($modulus, $exponent){
$res = openssl_pkey_get_public( $this->buildCertificate($modulus, $exponent));
$details = openssl_pkey_get_details($res);
$this->pubkey = $details["key"];
}
private function buildCertificate($modulus, $exponent){
$key = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB" . "iQKBgQCy745x" . $modulus . "ID" . $exponent;
$key = "-----BEGIN PUBLIC KEY-----\n" . wordwrap($key, 16, "\n", true) . "\n-----END PUBLIC KEY-----";
return $key;
}
public function encrypt($string){
$crypted = "";
openssl_public_encrypt($string, $crypted, $this->pubkey);
return base64_encode($crypted);
}
}
$url="https://steamcommunity.com/login/getrsakey/";
$PostFields = array(
'username' => ACC_NAME
);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_COOKIESESSION, 1);
curl_setopt($ch, CURLOPT_VERBOSE, 1);
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows; U; Windows NT 5.1; pl; rv:1.9.0.7) Gecko/2009021910 Firefox/3.0.7');
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 0);
curl_setopt($ch, CURLOPT_POSTFIELDS, $PostFields);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_COOKIEJAR, dirname(__FILE__) . '/cookie.txt');
curl_setopt($ch, CURLOPT_CAINFO, dirname(__FILE__)."cacert.pem");
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);
$result=curl_exec($ch);
$json=json_decode($result,true);
$key_mod=$json['publickey_mod'];
$key_exp=$json['publickey_exp'];
$timestamp=$json['timestamp'];
$RSA=new RSAHelper($key_mod,$key_exp);
Это модифицированная версия старого скрипта, которая должна отправить приглашение в Steam Group. Эта версия должна работать, но у меня есть ошибка:
Предупреждение: openssl_pkey_get_details() ожидает, что параметр 1 будет ресурсным, логическое значение указано в /home/.../public_html/test/steaminv.php в строке 51
Кто-нибудь знает, что не так с этим скриптом?
1 ответ
В сообщении об ошибке указано, что логическое значение было указано не как ресурс.
Это означает, что openssl_pkey_get_public
функция вернула false.
Это будет сделано только в том случае, если предоставленная строка не является допустимым открытым ключом.
Это потому что buildCertificate
Метод в вашем классе не возвращает действительный открытый ключ формата PEM.
Несколько вещей:
использование
\r\n
не\n
использование
chunk_split
неword_wrap
Это не то, насколько я знаю (поправьте меня, если я ошибаюсь), как вы создаете открытый ключ. Используйте Open SSL для создания ключа.