图片 23

MVC应用程序请求密码的功能(一)

用户验证邮箱有效性,是在登录之后进行的,因此只需要点击“验证”铵钮即可,系统即发送验证的邮件至用户的邮箱中。
另外,当用户忘记密码时,是在没有登录系统之下进行的,因此需要输入用户的帐号才能进行下一步。
均是使用这个存储过程[dbo].[usp_UserRequestAction_Request]。

图片 1

Ok,还差2个存储过程,第一个是更新IsVerify字段值:
图片 2

 代码:
图片 3

 

下面Insus.NET以新浪邮箱为例,登录之后,可以在选项中看到如下信息:
图片 4

图片 5图片 6

经过一系列的练习,实现了会员注册《MVC会员注册》,
登录《MVC应用程序实现会员登录功能》,
以及注销《MVC会员注销功能Cookie的应用》等功能。

 

在演示中已经达到我们最初的想法,但是邮件还是没有发送出去,只是存在MailingList列表中。下一篇Insus.NET将会实现MVC应用程序自动执行也发送邮件。

 

一个专业的站点,也许不止使用一个邮箱来发送服务邮件,电子报,会员服务等,应该把主发送的邮件列于此。

图片 7图片 8

 

接下来,你还需要创建另外一张表,是记用户请求的事件,记录用户的一些信息,如帐号,邮箱,链接有时效性等:

到这里,这部分算完成了,会员可以直接访问此页或是我们可以在登录介面中,放一个链接,可以导向此页:
图片 9

Source Code

添加一个发送的邮箱参数,Insus.NET使用新浪的邮箱:
图片 10

 

在此Insus.NET建议网友不要尝试使用上面的帐号与密码登录上面所列的邮箱,密码肯定不是所显示的啦。

 
接下来的流程是,用户会打开他的邮箱,查阅刚刚系统发送的邮件。邮件内容就是看实际需求了,如提示用户,是不是自己本人操作,安全性等,这些都不是怎样重要,重要的是那一条链接。
指示用户点击链接。这个链接会导上到网站一个页面。当到这个页面时,系统会在这页面进行一些程序处理,检查链接有效性,时间是否过期,如果一切没有问题,会进更新IsVerify字段为ture.

 

图片 11图片 12

接下来,创建一张邮件参数表[dbo].[EmailParameter]:
图片 13

图片 14图片 15

去控制器打开MemberController.cs添加两个Result:
图片 16

 

 

Source Code

 创建RequestPassword视图,参考下图的目录与路径:
图片 17

图片 18

接下来,创建一个存储过程,添加邮件参数:
图片 19

Source Code

最后来看看实时操作演示:

 

开始吧,在数据库创建一张表[dbo].[ChangeRequestPassword],用户请求密码时,存储会员每一次请求临时的token信息:
图片 20

由于你需要做2个功能,一个是要求用户验证邮箱有效性,也有可以以邮箱来让用户修改用户密码。因此需要创建一个表来存储这2个类型的数据:
图片 21

上面的会员请求密码存储过程,首先判断会员在请求密码时所输入的帐号与邮箱是否正确。
接着产生一个全新的token码。当然这个token码,你也可以按照你的处理方式来产生,唯一性即可。
#36行代码,是选择在邮件参数中,使用哪一个参考,即是说使用哪一个邮箱来发送。
#38与#39行代码的网址,是一个真实正确的网址,肯定的你需要更改你MVC应用程序中的网址。
最后是把信息插入至订阅邮件列表的表中。等待程序来处理。

 
当用户发出验证邮箱或是更改密码时,让程序执行下面的存储过程:

还差一些什么呢?会员忘记密码时,能够请求密码或是重置自己的密码。现在Insus.NET就实现这个功能。本次演示中,Insus.NET的实现思路是会员填写注册的信息,如帐号和邮箱等,然后给邮箱发送一个超链接,用户打开链接,出现重置密码的网页。此时会员就可以在24小时有效的情况之下重置密码。

ALTER TABLE [dbo].[Users]
ADD [Email] VARCHAR(100) NULL, 
[IsVerify] BIT NOT NULL DEFAULT(0)


 SELECT * FROM [dbo].[Users]

token字段,是唯一字段,将用来发送给会员。Account和Email是用来记录会员请求的帐号与邮箱。而最后一个字段Expire是一个记录过期的字段。到时程序会根据此字段的时间来链接判断是否失效。

CREATE TABLE [dbo].[UserRequestAction](
    [Type] NVARCHAR(2) NOT NULL FOREIGN KEY REFERENCES [dbo].[RequestActionType] ([Type]),
    [Token] [uniqueidentifier] NOT NULL DEFAULT(NEWID()),
    [Account] [nvarchar](30) NOT NULL,
    [Email] [nvarchar](150) NOT NULL,
    [Expire] [datetime] NOT NULL DEFAULT (DATEADD(day,(1),CURRENT_TIMESTAMP)),
)

GO

现在可以转到MVC应用程序,打开Entities目录下的MemberEntity.cs,添加一个方法:
图片 22

CREATE PROCEDURE [dbo].[usp_UserRequestAction_Request]
(
    @Type NVARCHAR(2),
    @U_nbr NVARCHAR(20)
)
AS
IF NOT EXISTS(SELECT TOP 1 1 FROM [dbo].[Users] WHERE [U_nbr] = @U_nbr)
BEGIN
    RAISERROR(N'帐号错误或不存存在,请联系系统管理员。',16,1)
    RETURN
END

DECLARE @Email NVARCHAR(100)
SELECT @Email = [Email] FROM [dbo].[Users] WHERE [U_nbr] = @U_nbr


IF EXISTS(SELECT TOP 1 1 FROM [dbo].[UserRequestAction] WHERE [Type] = @Type AND [Account] = @U_nbr AND [Email] = @Email)
    UPDATE [dbo].[UserRequestAction] SET [Token] = NEWID(),[Expire] = DATEADD(day,(1),CURRENT_TIMESTAMP) WHERE [Type] = @Type AND [Account] = @U_nbr AND [Email] = @Email
ELSE
    INSERT INTO [dbo].[UserRequestAction] ([Type],[Account],[Email]) VALUES (@Type,@U_nbr,@Email)
GO

最后再创建一张表,是用来存储所有订阅等待的将要发送邮箱地址。
图片 23