Facebook과 상호 작용하는 웹 애플리케이션을 개발할 때 getUser()가 지속적으로 0을 반환하는 문제는 일반적으로 마주쳤다. 이로 인해 필요한 사용자 정보에 대한 액세스가 방해를 받고 인증 오류가 발생할 수 있습니다.
이 동작의 잠재적인 이유 중 하나는 PHP SDK가 $_REQUEST 변수에 의존하기 때문입니다. 이 변수는 다른 요청 변수($ _GET, $_POST 및 $_COOKIE)를 환경에 추가하세요. PHP 버전도 역할을 할 수 있습니다.
base_facebook.php 파일 내 getCode() 함수를 검사하면 다음 코드가 나타납니다.
protected function getCode() { if (isset($_REQUEST['code'])) { if ($this->state !== null && isset($_REQUEST['state']) && $this->state === $_REQUEST['state']) { // CSRF state has done its job, so clear it $this->state = null; $this->clearPersistentData('state'); return $_REQUEST['code']; } else { self::errorLog('CSRF state token does not match one provided.'); return false; } } return false; }
이 문제를 해결하려면 다음 코드를 수정하면 됩니다.
protected function getCode() { $server_info = array_merge($_GET, $_POST, $_COOKIE); if (isset($server_info['code'])) { if ($this->state !== null && isset($server_info['state']) && $this->state === $server_info['state']) { // CSRF state has done its job, so clear it $this->state = null; $this->clearPersistentData('state'); return $server_info['code']; } else { self::errorLog('CSRF state token does not match one provided.'); return false; } } return false; }
이 수정은 모든 요청 변수를 $server_info 변수로 통합하여 getCode() 함수가 PHP 환경 구성에 관계없이 이러한 소스 중 하나에서 코드 매개변수에 액세스합니다.
위 내용은 Facebook의 PHP SDK `getUser()`가 항상 0을 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!