zoukankan      html  css  js  c++  java
  • MVC应用程序请求密码的功能1

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

    经过一系列的练习,实现了会员注册《MVC会员注册http://www.cnblogs.com/insus/p/3439599.html
    登录《MVC应用程序实现会员登录功能http://www.cnblogs.com/insus/p/3466512.html
    以及注销《MVC会员注销功能Cookie的应用http://www.cnblogs.com/insus/p/3471147.html等功能。

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


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


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

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


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


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



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


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



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


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

     数据库的设计还没有完成,还有几个存储过程要写:


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

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



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

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

     代码:


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


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

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

     
     

    如何提高nodejs程序的稳定性,健壮性

     

      在网上看到一些帖子,吐糟,质疑nodejs 程序的稳定性,为什么呢?其一,可能这个和javascript有关吧,node是拿javascript去实现的,而javascript又被称为是“世界上误解最深的语言”,我们可以去看看nodejs 创始人的说法,可以去看看知乎的这篇文章,为什么node 用javascript去实现,其二,nodejs 毕竟还年轻,而且官网在部分模块也标注了此模块的目前的状态。

      这2天我抽了点时间思考了下这个问题,我觉得我们程序首先功能应该是独立的,就是一个功能出异常了,不应该去影响另外一个正常的功能,不应该将整个程序都崩溃掉,其次,即使是程序崩溃了,我们也应该有一个让程序自动启动,另外,应该去记录日志,方便我们跟踪问题。我觉得主要可以从以下方面提高nodejs 稳定性:

      1)保持良好的代码结构:

        我们知道node是单线程,非阻塞io,默认就是异步,通过回调的方式处理后面的流程,如果嵌套的层次太多了,势必会引起代码逻辑结构的混乱,也不利于维护和升级,可以采用async这个异步流程控制模块,来理清我们的代码逻辑。

      2)使用 process.on('uncaughtException', function(err){...}); 来处理未被捕捉的错误。

      3)使用try~catch 来捕获异常:

         这个只能解决一部分问题,不是万能的,在上面说到因为node是单线程,非阻塞io,默认就是异步,通过回调的方式处理后面的流程,try~catch 是不能捕获的callback 里面的error的错误的,怎么捕获到callback里面的错误呢 ? 可以采用domain模块

      4)使用domain模块来处理程序的异常

         先看看对domain的解释:domain是 EventEmitter类的一个子类。监听它的error事件来处理它捕捉到的错误。 它提供了一种方式,即以一个单一的组的形式来处理多个不同的IO操作。如果任何一个注册到domain的事件触发器或回调触发了一个‘error’事件,或者抛出一个错误,那么domain对象将会被通知到。而不是直接让这个错误的上下文从`process.on('uncaughtException')'处理程序中丢失掉,也不会致使程序因为这个错误伴随着错误码立即退出。

      如何使用domain 模块呢?看一个例子:

    复制代码
    serverDomain.run(function() {
      // 服务器在serverDomain的作用域内被创建
      http.createServer(function(req, res) {
        // req和res同样在serverDomain的作用域内被创建
        // 但是,我们想对于每一个请求使用一个不一样的域。
        // 所以我们首先创建一个域,然后将req和res添加到这个域上。
        var reqd = domain.create();
        reqd.add(req);
        reqd.add(res);
        reqd.on('error', function(er) {
          console.error('Error', er, req.url);
          try {
            res.writeHead(500);
            res.end('Error occurred, sorry.');
          } catch (er) {
            console.error('Error sending 500', er, req.url);
          }
        });
      }).listen(1337);    
    });
    ```
    复制代码

    说明:首先创建一个域(domain.create()),然后将需要监控的分发器添加到该域上,最后给域绑定一个错误事件,这样就可以监控了。

    再看一个例子:

    复制代码
    var d = domain.create();
    d.on('error', function(er) {
      console.error('Caught error!', er);
    });
    d.run(function() {
      process.nextTick(function() {
        setTimeout(function() { // 模拟几个不同的异步的东西
          fs.open('non-existent file', 'r', function(er, fd) {
            if (er) throw er;
            // 继续。。。
          });
        }, 100);
      });
    });
    复制代码

    说明:首先创建一个域,给域绑定一个错误事件,然后在域的上下文提供可以运行的函数

    如果对于回调呢?可以这么使用

    复制代码
    var d = domain.create();
    
    function readSomeFile(filename, cb) {
      fs.readFile(filename, 'utf8', d.bind(function(er, data) {
        // if this throws, it will also be passed to the domain
        return cb(er, data ? JSON.parse(data) : null);
      }));
    }
    
    d.on('error', function(er) {
      // an error occurred somewhere.
      // if we throw it now, it will crash the program
      // with the normal line number and stack message.
    });
    复制代码

    当然也可以这么使用

    复制代码
    var d = domain.create();
    
    function readSomeFile(filename, cb) {
      fs.readFile(filename, 'utf8', d.intercept(function(data) {
        return cb(null, JSON.parse(data));
      }));
    }
    
    d.on('error', function(er) {
      // an error occurred somewhere.
      // if we throw it now, it will crash the program
      // with the normal line number and stack message
    });
    复制代码

    这个函数与domain.bind(callback)几乎一模一样。但是,除了捕捉被抛出的错误外,它还会拦截作为第一参数被传递到这个函数的Error对象。

      5)使用log4js 模块记录日志

      log4js 是一个非常强大的日志管理工具,在可以看看github这个项目: https://github.com/nomiddlename/log4js-node

      6)使用forever 模块来管理nodejs

      forever 是服务端管理nodejs 的一个模块,一个命令行工具,能够启动,停止app 应用。forever完全是基于命令行操作,在forever进程管理之下,创建node的子进程,通过monitor监控node子进程的运行情况,一旦文件更新,或者进程挂掉,forever会自动重启node服务器,确保应用正常运行。非常的好用.

    可以关注下这个项目:https://github.com/nodejitsu/forever

    但是forever 也不是万能的,也由下面这些问题:

    • 有限的监控和日志功能
    • 进程管理配置的支持差
    • 不支持集群
    • 代码库老化(意味着在升级node.js时频繁的失败)

    附本文测试代码:https://github.com/yupeng528/node-error  

     
     
    分类: nodejs
  • 相关阅读:
    CPP流类库与输入输出
    STL学习之mismatch();
    谷歌浏览器现在点击任何文本都会出现光标
    jQuery删除元素remove和和empty的区别
    jQuery中的鼠标离开事件mouseout和mouseleave区别
    java类中的布尔(boolean&Boolean)类型字段要注意get方法和字段的命名
    Navicat_Premium_v15 激活
    navicat注册过期修改方法
    ClassNotFoundException找不到类异常的原因package 路径eclipse自动给我在路径前面加了一个java变成了java.com.XXX
    我保存一份博客园样式代码
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3473958.html
Copyright © 2011-2022 走看看