8

我有一个包含 createuserwizard 控件的网站。创建帐户后,验证电子邮件及其验证 URL 将发送到用户的电子邮件地址。

但是,当我进行测试运行时,单击电子邮件中的 URL 时,会出现此错误:

Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).


Source Error: 

Line 17:         {
Line 18:             //store the user id
*Line 19:             Guid userId = new Guid(Request.QueryString["ID"]);*
Line 20: 
Error appeared on LINE 19. 

另一个有趣的事情是,我的测试运行中的验证 URL 看起来很奇怪:

http://localhost:4635/WebSite2/Verify.aspx?ID=System.Security.Principal.GenericPrincipal

通常,URL 应该是这样的(在 URL 的末尾有很多字符:

http://localhost:2180/LoginPage/EmailConfirmation.aspx?ID=204696d6-0255-41a7-bb0f-4d7851bf7200

我实际上是在想,它与我的错误问题(Guid 应该包含 32 位数字和 4 个破折号)与 URL 的末尾有联系。

生成 URL 的代码如下:

protected void CreateUserWizard1_SendingMail(object sender,MailMessageEventArgs e)
{ 
    string domainName = Request.Url.GetLeftPart(UriPartial.Authority) + Request.ApplicationPath; 
    string confirmationPage = "/Verify.aspx?ID=" + User.ToString(); 
    string url = domainName + confirmationPage; 
    e.Message.Body = e.Message.Body.Replace("<%VerificationUrl%>", url); 
}

请给我建议以及我应该做些什么来解决这个问题。

提前致谢。

更新:

protected void CreateUserWizard1_SendingMail(object sender,MailMessageEventArgs e)
{
    MembershipUser userInfo = Membership.GetUser(CreateUserWizard1.UserName);
    Guid userInfoId = (Guid)userInfo.ProviderUserKey;

    string domainName = Request.Url.GetLeftPart(UriPartial.Authority) + Request.ApplicationPath;
    string confirmationPage = "/Verify.aspx?ID=" + userInfo.ToString();
    string url = domainName + confirmationPage;

    e.Message.Body = e.Message.Body.Replace("<%VerificationUrl%>", url);

}

现在我的 URL 链接如下所示:

http://localhost:4635/WebSite2/Verify.aspx?ID=username

但错误“Guid 应包含 32 位数字和 4 个破折号(xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”仍然存在

4

4 回答 4

4

你有一行说:

Guid userInfoId = (Guid)userInfo.ProviderUserKey;

当然这是您应该在 URL 中提供的内容?

string confirmationPage = "/Verify.aspx?ID=" + userInfoId.ToString();
于 2012-06-27T12:33:34.230 回答
3

您将 ID 设置为:

User.ToString()

这解析为字符串:

"System.Security.Principal.GenericPrincipal"

我在任何地方都看不到 GUID,所以任何人都可以猜测您要如何生成它。

于 2012-06-27T10:56:08.063 回答
1

您没有传递 ID,在您的情况下是 GUID,您正在尝试传递 IDvalue=User.Tostring().

于 2012-06-27T10:57:32.330 回答
0

您应该进行两项更改。首先,如前所述User.ToString(),总会产生"System.Security.Principal.GenericPrincipal". 您应该将其更改为:

User.Guid.ToString()

其次,您的网页应该更加防御性地编码并使用 TryParse,如下所示:

  Guid g;
  if (Guid.TryParse(Request.QueryString["ID"], out g))
    // its a good Guid
  else
    // its not a valid Guid
于 2012-06-27T11:11:30.953 回答