22

我想在 Yii 中使用 OpenID 支持。

在研究了可能的插件后,我找到了这两个。一个用于 OpenidSelector,一个用于 LightOpenId

http://www.yiiframework.com/extension/simpleopenidselector/

http://www.yiiframework.com/extension/loid

这些是在 Yii 中用于 OpenId 支持的正确扩展吗?还要别的吗?如果这些扩展是正确的,我想获得一些关于如何处理这些扩展的指南。

这是我认为除了按照页面上的说明安装它们之外我还需要做的事情。

  1. 创建 OpenIdUserIdentity 扩展 CUserIdentity 并将 authenticate() 代码放在那里
  2. 创建一个登录页面并将 simpleopenidselector 代码放在一个视图中。
  3. 在 siteController 中创建一个 actionOpenIdLogin 方法

然后我有点迷茫,因为我不了解 Loid 中的用法示例,并且我不确定如何执行上面的 (1) 和 (3)。

如果我走在正确的轨道上,请告诉我,并可能提供一些指导。谢谢。

4

2 回答 2

10

玩了一段时间后,我将回答我自己的问题。这就是我使其工作的方式,因此您可以根据需要进行更改。

注意:我使用 userController 而不是 siteController,请按照相应扩展页面中的所有说明进行操作。

如果你使用了上面提到的两个插件,那么你接下来需要做的事情是:(这是一步一步的指南) 但最重要的步骤是 2c 和 3,它们是两者的粘合剂插件

1) 有一个使用 OpenidSelector 的登录页面。把它放在views/user/login.php

<?php
$this->widget('application.extensions.openidProviders.openidProviders', 
array ( 'options' => array ( 'lang' => 'en', 
//      'demo' => 'js:true',
    'cookie_expires' => 6*30,
    )));?>

2) 设置操作以处理来自 openidSelector 的选择。我把它放在用户控制器中。

a) 在主配置文件中。

 'components'=>array(
    'user'=>array(
        // enable cookie-based authentication
        'allowAutoLogin'=>true,
        'loginUrl' => array('/user/login'), //change the default login page
    ),

b) 在 userController 文件中,添加登录和身份验证操作

array('allow',  // allow all users to perform 'index' and 'view' actions
  'actions'=>array('login', 'authenticate'),

操作 #1 actionLogin 的代码 - 这是触发登录视图页面。

public function actionLogin()
{       
    // display the login form
    $this->render('login',array());
}

c) 动作#2 actionAuthenticate 的代码 - 从 LOID 指令页面修改的代码,这是在登录页面中选择 OpenIDProvider 时处理的。

public function actionAuthenticate ()
{
   // Put the Simple usage: code on 
   // http://www.yiiframework.com/extension/loid here:

   // Code from loid Simple usage page.
   // START HERE
   $loid = Yii::app()->loid->load();
   if (!empty($_GET['openid_mode'])) {
       if ($_GET['openid_mode'] == 'cancel') {
         $err = Yii::t('core', 'Authorization cancelled');
       } else {
         try {
             echo $loid->validate() ? 'Logged in.' : 'Failed';
       } catch (Exception $e) {
             $err = Yii::t('core', $e->getMessage());
       }
   }
   if(!empty($err)) echo $err;
   } else {
       // **NOTE:Comment out this line from the loid sample page**
       // $loid->identity = "http://my.openid.identifier"; //Setting identifier
       // this openid_identifier is need after you click the openselector
       $loid->identity = $_GET['openid_identifier']; // CHANGE HERE

       $loid->required = array('namePerson/friendly', 'contact/email'); //Try to get info from openid provider
       $loid->realm     = (!empty($_SERVER['HTTPS']) ? 'https' : 'http') . '://' . $_SERVER['HTTP_HOST']; 
       $loid->returnUrl = $loid->realm . $_SERVER['REQUEST_URI']; //getting return URL
       if (empty($err)) {
           try {
               $url = $loid->authUrl();
               $this->redirect($url);
           } catch (Exception $e) {
               $err = Yii::t('core', $e->getMessage());
           }
        }
    }
    // Code from loid Simple usage page.
    // END HERE
}

3) 在 openidProviders/views/main-en.php 中将操作 URL 更改为 Authenticate

改变

form action="examples/consumer/try_auth.php" method="get" id="openid_form"

form action="authenticate" method="get" id="openid_form"

应该是这样的。没有测试失败案例,只测试了谷歌登录。

于 2011-04-15T19:36:06.837 回答
8

在此处输入图像描述

现在有了YiiAuth,它利用了HybridAuth库。

于 2012-06-21T18:07:02.173 回答