이것은 문제의 절반 만 해결할 수 있지만 $ _REQUEST ('signed_request')가 $ _REQUEST ('signed_request')가 아닌 $ _REQUEST [ 'signed_request']를 기억하십시오.
편집 : 당신은 변수 당신이 원하는 그냥 사람을 받고
: 당신이 언급 한 바와 같이 마지막 부분을 무시, 여기 당신의 대답이다. 서명 된 요청을 반환하고 개인 키를 사용하여 요청의 암호를 해독해야합니다. 방법 : Heres :
function parse_signed_request($signed_request, $secret) {
list($encoded_sig, $payload) = explode('.', $signed_request, 2);
// decode the data
$sig = base64_url_decode($encoded_sig);
$data = json_decode(base64_url_decode($payload), true);
if (strtoupper($data['algorithm']) !== 'HMAC-SHA256') {
error_log('Unknown algorithm. Expected HMAC-SHA256');
return null;
}
// check sig
$expected_sig = hash_hmac('sha256', $payload, $secret, $raw = true);
if ($sig !== $expected_sig) {
error_log('Bad Signed JSON signature!');
return null;
}
return $data;
}
function base64_url_decode($input) {
return base64_decode(strtr($input, '-_', '+/'));
}
서명 된 요청과 앱 비밀을 전달하면 배열이 반환됩니다. 나는 페이스 북 SDK로 그것을 할 수있는 방법이 있지만 확실하지는 않지만 사용하지는 않는다.
추가 정보 : https://developers.facebook.com/docs/authentication/signed_request/
goodluck는!
이 문제를 해결할 수 있었습니까? 경우 예? 솔루션을 공유해주십시오. –