當前位置: 首頁>>代碼示例>>PHP>>正文


PHP LinkedIn::is_authenticated方法代碼示例

本文整理匯總了PHP中LinkedIn::is_authenticated方法的典型用法代碼示例。如果您正苦於以下問題:PHP LinkedIn::is_authenticated方法的具體用法?PHP LinkedIn::is_authenticated怎麽用?PHP LinkedIn::is_authenticated使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在LinkedIn的用法示例。


在下文中一共展示了LinkedIn::is_authenticated方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: indexAction

 public function indexAction(Request $request, $provider)
 {
     try {
         // get previous url
         $session = $request->getSession();
         $loginUrl = $this->getRequest()->headers->get('referer');
         // make sure we find the configuration
         if ($this->container->hasParameter($provider) && !$this->getUser()) {
             // get current configuration for provider
             $configs = $this->container->getParameter($provider);
             if ($provider == 'twitter') {
                 define('TWITTER_CONSUMER_KEY', $configs['api_key']);
                 define('TWITTER_CONSUMER_SECRET', $configs['api_secret']);
                 define('TWITTER_OAUTH_CALLBACK', $this->getRequest()->getUri());
                 if (!$session->get('oauth_token')) {
                     $connection = new \TwitterOAuth(TWITTER_CONSUMER_KEY, TWITTER_CONSUMER_SECRET);
                     $request_token = $connection->getRequestToken(TWITTER_OAUTH_CALLBACK);
                     $session->set('oauth_token', $request_token['oauth_token']);
                     $session->set('oauth_token_secret', $request_token['oauth_token_secret']);
                     switch ($connection->http_code) {
                         case 200:
                             return $this->redirect($connection->getAuthorizeURL($request_token['oauth_token']));
                             break;
                         default:
                             throw new \Exception('Could not connect to Twitter. Refresh the page or try again later.');
                             break;
                     }
                 } else {
                     $connection = new \TwitterOAuth(TWITTER_CONSUMER_KEY, TWITTER_CONSUMER_SECRET, $session->get('oauth_token'), $session->get('oauth_token_secret'));
                     $access_token = $connection->getAccessToken($request->get('oauth_verifier'));
                     $session->set('access_token', $access_token);
                     $content = $connection->get('account/verify_credentials');
                     $this->findUser($provider, array('id' => (string) $content->id, 'first_name' => (string) $content->name, 'last_name' => (string) $content->name, 'email' => (string) $content->id . '@twitter.com'));
                 }
             } elseif ($provider == 'google') {
                 // include google library
                 include dirname(__DIR__) . '/Vendor/Google/autoload.php';
                 $client = new \Google_Client();
                 $client->addScope("email");
                 $client->addScope("profile");
                 $client->setClientId($configs['api_key']);
                 $client->setClientSecret($configs['api_secret']);
                 $client->setRedirectUri($this->get_clean_url($this->getRequest()->getUri()));
                 if ($request->get('code', false)) {
                     $client->authenticate($request->get('code'));
                     $service = new \Google_Service_Oauth2($client);
                     $user = $service->userinfo->get();
                     //get user info
                     $this->findUser($provider, array('id' => (string) $user->id, 'first_name' => (string) $user->givenName, 'last_name' => (string) $user->familyName, 'email' => (string) $user->email));
                 } else {
                     return $this->redirect($client->createAuthUrl());
                 }
             } elseif ($provider == 'facebook') {
                 $facebook = new \FaceBook($configs['api_key'], $configs['api_secret'], $this->getRequest()->getUri());
                 if (!$facebook->is_authenticated()) {
                     return $this->redirect($facebook->get_redirect_url());
                 } else {
                     $this->findUser($provider, $facebook->get_user($session));
                 }
             } elseif ($provider == 'linkedin') {
                 $linkedin = new \LinkedIn($configs['api_key'], $configs['api_secret'], $this->getRequest()->getUri());
                 if (!$linkedin->is_authenticated()) {
                     return $this->redirect($linkedin->get_redirect_url());
                 } else {
                     $this->findUser($provider, $linkedin->get_user($session));
                 }
             }
         }
     } catch (\Exception $e) {
         $this->get('session')->getFlashBag()->add('error', $e->getMessage());
     }
     return $this->redirect($this->generateUrl($this->container->getParameter('login_path')));
 }
開發者ID:phpcodebooster,項目名稱:social-login,代碼行數:73,代碼來源:DefaultController.php


注:本文中的LinkedIn::is_authenticated方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。