我来做百科(第二十天) D

简介:

有朋友(注册会员)告诉我,她忘记密码了。对哦,要做一个“找回密码”的系统才行。
又找了一下资料,看到一篇不错的文章,介绍了“选择何种方式帮助用户找回密码”,他的结论是:
 1〉不采取密码答案和问题
2〉用邮件找回密码
3〉用户自己输入注册邮件
4〉发送到邮件中的是激活地址而非密码
5〉注册时告诉用户这个密码将来要用来找回密码,提供测试邮件帐户能否收到系统的入口。
   6〉如果您将遗忘密码保护信息,可以填写申诉表来找回您的密码。
其中第六点是我自己写的,我觉得应该需要。如果按照这个思路,首先用户注册的时候要提醒,而且判断好email格式,至于“提供测试邮件帐户能否收到系统的入口”就先不做了,偷懒一下。在“找回密码”的页面用户先输入用户名,再输入email,都正确了就发送邮件。至于“激活地址”我是用了一个50位的随机数,这个随机数会保存到会员表的一个字段中。当用户打开激活地址,来到“重设密码”页面,首先页面检测这个随机数是不是在表中,有的话就可以重设密码。这个应该也先输入用户名一起判断比较好啊,又懒一把。
思路有了,编写程序就不难了,就是发email弄了我很久。本来服务器上有一个邮局系统可以用,但问题是设来设去也搞不成功,郁闷过后,只好用了163的帐号来发。但又发现新建的帐号163关了smtp,再郁闷一下,只好用自己的邮箱来顶一下了。代码如下:

/// <summary>
/// 发送邮件
/// </summary>

public   static   bool  SendEmailForGetpass( string  name,  string  email,  string  random)
{
    
try
    
{
        MailAddress from 
= new MailAddress("xxx@163.com""ShundeBK.cn");
        MailAddress to 
= new MailAddress(email, name);
        MailMessage message 
= new MailMessage(from, to);
        message.Subject 
= "顺德百科 ShundeBK.cn 取回密码";

        message.Body 
= @"<a href='http://shundebk.cn/passport/Setpass.aspx?code=" + random + "' target='_blank'>取回密码</a>;
        message.Priority = MailPriority.High;
        message.IsBodyHtml 
= true;

        SmtpClient client 
= new SmtpClient("smtp.163.com");
        client.Credentials 
= new System.Net.NetworkCredential("xxx""xxx");
        client.Send(message);

        
return true;
    }

    
catch (Exception e)
    
{
        
throw e;
        
return false;
    }

}

终于完成了这个“取回密码”系统。叫我朋友测试,通过!


本文转自博客园cloudgamer的博客,原文链接:我来做百科(第二十天) D,如需转载请自行联系原博主。

相关文章
|
1月前
|
JavaScript 前端开发 测试技术
"0元搞定!手把手教你建网站,简单得就像泡桶方便面一样,上线个人网站轻而易举!"
没有服务器和公网IP,想要其他人访问自己做好的网站,该怎么办?今天教大家使用这款简单免费的内网穿透小工具——ngrok,有了它轻松让别人访问你的项目~
|
11月前
|
数据采集 机器学习/深度学习 弹性计算
阿里云服务器可以用来做什么?(老司机经验之谈)
2023阿里云服务器可以用来做什么?(老司机经验之谈)使用阿里云服务器可以做什么?阿里云百科分享使用阿里云服务器常用的十大使用场景,说是十大场景实际上用途有很多,阿里云百科分享常见的云服务器使用场景,如本地搭建ChatGPT、个人网站或博客、运维测试、学习Linux、跑Python、小程序服务器等等,云服务器吧分享使用阿里云服务器可以做的几件小事
123 0
|
弹性计算 应用服务中间件 双11
关于这次阿里云服务器活动的价格整理拿去看吧
普惠上云,阿里云越来越便宜了,整理了阿里云服务器活动报价,有需要的拿去吧
173 0
关于这次阿里云服务器活动的价格整理拿去看吧
|
前端开发 JavaScript