0

我正在尝试为仅使用 Google 作为身份验证提供程序的网站实施 OpenID。我使用 OpenIdButton 控件将用户发送到他们的 Google Apps 登录,因为我总是希望他们去同一个地方。

该按钮将它们发送到正确的位置并将它们正确返回到 ReturnToUrl,但 OnLoggedIn 事件似乎从未触发过。我正在通过在方法中设置 TextBox 值来检查事件,并且我看到 TextBox 值没有变化。这是我的代码...

<tr>
  <td>
    <asp:TextBox ID="devMsg" runat="server"/>
  </td>
</tr>
<tr>
  <td valign="top" align="center">
    <font size="-1"><b>Sign in with your</b></font>
    <br />
    <br />
<rp:OpenIdButton ID="OpenIdButton1" runat="server" Text="Login with your Google account!"
             ImageUrl="http://www.google.com/accounts/google_transparent.gif"
                 Identifier="https://www.google.com/accounts/o8/site-xrds?hd=dev.connexcloud.com"
                 ReturnToUrl="http://localhost:1587/OpenIdRelyingPartyWebForms/loginGoogleApps.aspx"
                 OnLoggedIn="OpenIdLogin_LoggedIn" />
    <br />
    <br />
    <font size="-1"><b>Account</b></font>
  </td>
</tr>


protected void OpenIdLogin_LoggedIn(object sender, OpenIdEventArgs e)
{
  this.devMsg.Text = "no response";

  if (e.Response != null)
  {
    devMsg.Text = "response";

    switch (e.Response.Status)
    {
      case AuthenticationStatus.Authenticated:
           this.devMsg.Text = "authenicated";
           break;
      case AuthenticationStatus.Canceled:
           this.devMsg.Text = "canceled";
           break;
      case AuthenticationStatus.Failed:
           this.devMsg.Text = "failed";
           break;
    }
  }
}

TextBox 从未被设置为任何内容,因此在我看来,当 Google 返回响应时,从未进行过 OpenIdLogin_LoggedIn 调用。

4

1 回答 1

1

您是否尝试过在 LoggedIn 处理程序中设置断点?我怀疑它正在工作。在调用 LoggedIn 处理程序后,控件FormsAuthentication.RedirectFromLoginPage使用 OpenID 声明标识符进行调用,这将在您注意到之前清除您在其中设置的 TextBox。

除了断点之外,您可以测试它的另一种方法是e.Cancel = true在您的处理程序中进行设置,这会抑制对FormsAuthentication.RedirectFromLoginPage.

于 2010-07-16T14:16:07.457 回答