facebookarchive / php-graph-sdk

The Facebook SDK for PHP provides a native interface to the Graph API and Facebook Login. https://developers.facebook.com/docs/php
Other
3.17k stars 1.95k forks source link

Getting error "Required param state missing from persistent data" #1245

Open cgkronos opened 3 years ago

cgkronos commented 3 years ago

I've an issue with php-graph-sdk, I've those functions

protected function getFacebook()
    {
        static $facebook = null;
        if($facebook == null){
            $facebook =  new Facebook\Facebook([
                'app_id' => $this->getAppId(),
                'app_secret' => $this->getAppSecret(),
                'default_graph_version' => 'v2.10'
            ]);
        }
        return $facebook;
    }
public function getLoginUrl($url)
    {
        $fb = $this->getFacebook();

        $helper = $fb->getRedirectLoginHelper();

        $autorisations = ['email']; 
        return $helper->getLoginUrl($url , $autorisations);
    }
 public function callback(&$error = null)
    {
        $fb = $this->getFacebook();

        $helper = $fb->getRedirectLoginHelper();

        try {
            $accessToken = $helper->getAccessToken();
        } catch(Facebook\Exception\ResponseException $e) {
            // When Graph returns an error
            $error = 'Graph returned an error: ' . $e->getMessage();
            return false;
        } catch(Facebook\Exception\SDKException $e) {
            // When validation fails or other local issues
            $error = 'Facebook SDK returned an error: ' . $e->getMessage();
            return false;
        }
        ....
  }

And I do $url = $Facebook->getLoginUrl(URL); then I make an <A></A> with this url And in the callback file $token = $Facebook->callback($error);

When I click on the link, the callback file is executed and$helper->getAccessToken(); causes this error: Uncaught Facebook\Exceptions\FacebookSDKException: Cross-site request forgery validation failed. Required param "state" missing from persistent data. I've seen posts about that and no fix works for me, what am I doing wrong?

Thanks in advance

cgkronos commented 3 years ago

inally I've solved my issue by switching samesite to Lax by adding that in config.php ini_set('session.cookie_samesite','Lax');