zoukankan      html  css  js  c++  java
  • Express框架之connect-flash详解

    第一步:我们首先来看看这个插件的使用

    [javascript] view plain copy 在CODE上查看代码片派生到我的代码片
    1. var flash = require('connect-flash');  
    2. app.use(flash());//Express使用这个插件  

    第二步:我们看看其内部是如何实现的

    [javascript] view plain copy 在CODE上查看代码片派生到我的代码片
    1. var format = require('util').format;  
    2. var isArray = require('util').isArray;  

    依赖的模块为node.js的核心模块util

    [javascript] view plain copy 在CODE上查看代码片派生到我的代码片
    1. module.exports = function flash(options) {  
    2.   options = options || {};  
    3.   //如果用户没有指定unsafe参数,那么safe就是true;否则如果用户指定了unsafe为false那么safe就是true  
    4.   //也就是说这个插件只能指定一个配置项就是unsafe,默认不指定为就是安全的!  
    5.   var safe = (options.unsafe === undefined) ? true : !options.unsafe;  
    6.   return function(req, res, next) {  
    7.     //如果req.flash存在,同时是safe的那么直接调用下面一个插件,这个插件就不执行了  
    8.     if (req.flash && safe) { return next(); }  
    9.     //如果上面的条件不满足那么为req指定flash属性,其值为下面的_flash函数  
    10.     req.flash = _flash;  
    11.     next();  
    12.   }  
    13. }  
     

    很显然,我们看到可以传入options参数,如果没有指定unsafe那么unsafe就是true,此时safe就是false。如果用户明确指定了unsafe为false那么safe为true,如果明确指定了unsafe为false那么safe就是true。如果safe为true那么直接调用下面一个中间件。

    我们现在看看req对象的flash方法是怎么样的:

    [javascript] view plain copy 在CODE上查看代码片派生到我的代码片
    1. function _flash(type, msg) {  
    2.   //如果当前req对象没有session域,那么抛出错误  
    3.   if (this.session === undefined) throw Error('req.flash() requires sessions');  
    4.   //为req.session.flash指定一个域,默认为空对象  
    5.   var msgs = this.session.flash = this.session.flash || {};  
    6.   if (type && msg) {  
    7.     // util.format is available in Node.js 0.6+  
    8.     //如果当前是Node.js 0.6+以上的环境,同时传入的参数有两个以上  
    9.     if (arguments.length > 2 && format) {  
    10.       var args = Array.prototype.slice.call(arguments, 1);  
    11.       //获取第二个参数以后的数组  
    12.       msg = format.apply(undefined, args);  
    13.       //msg保存的是第二个参数以后的值,并对这个值进行了format处理  
    14.     } else if (isArray(msg)) {  
    15.       msg.forEach(function(val){  
    16.         (msgs[type] = msgs[type] || []).push(val);  
    17.       });  
    18.       return msgs[type].length;  
    19.       //如果传入的第二个参数是一个数组,那么全部把数据绑定到req.session.flash域里面,其中数据类型为{'info':['school','home']}  
    20.       //然后返回的是特定的长度  
    21.     }  
    22.     //如果参数不多于2,同时msg也不是数组,那么把msg添加到req.session.flash中然后返回  
    23.     return (msgs[type] = msgs[type] || []).push(msg);  
    24.   } else if (type) {  
    25.     //如果没有指定msg,仅仅指定了type,这时候我们获取到req.session.flash中特定类型的数据,同时把数据从req.session.flash中删除  
    26.     var arr = msgs[type];  
    27.     delete msgs[type];  
    28.     return arr || [];  
    29.   } else {  
    30.     //如果调用方式如flash()也就是不传入任何参数,这时候直接清空了req.session.flash中的数据  
    31.     this.session.flash = {};  
    32.     return msgs;  
    33.   }  
    34. }  

    (1)如果传入的参数多于两个,那么首先获取第二个以及以后的参数,然后对第二个以后的参数进行format操作,最后把数据封装到req.session.flash中,同时返回

    [javascript] view plain copy 在CODE上查看代码片派生到我的代码片
    1. req.flash('info', 'email has been sent to %s.', userName);  

    (2)如果传入的第二个参数是一个数组,那么把这个数组每一个元素封装到req.session.flash中,然后返回特定type的数据的长度

    (3)否则如果仅仅传入了type表示获取指定类型的数据然后返回,并把数据从req.session.flash中删除(这样只要我们调用这个方法获取了数据那么就从session中删除了)

    [javascript] view plain copy 在CODE上查看代码片派生到我的代码片
    1. req.flash('info', 'email sent');  
    2.  req.flash('error', 'email delivery failed');  
    3.  req.flash('info', 'email re-sent');  
    4. req.flash('info');  
    5. // => ['email sent', 'email re-sent']  
    6. req.flash('info');  
    7. // => []这时候info已经清空了  

    (4)如果用户没有传入任何参数那么清空req.session.flash域,但是返回的是原来的局部变量保存到的req.session.flash对象

    [javascript] view plain copy 在CODE上查看代码片派生到我的代码片
    1. else {  
    2.     //如果调用方式如flash()也就是不传入任何参数,这时候直接清空了req.session.flash中的数据  
    3.     this.session.flash = {};  
    4.     return msgs;  
    5.   }  

    这个插件一般和redirect一起使用,保证在渲染下一个页面的时候数据可用。

    觉得有用的小伙伴门帮忙扫一下二维码,谢谢!

  • 相关阅读:
    判断二叉树是否BST
    树基础训练(一)
    Trie 简介
    二叉树的一些补充
    红黑树
    平衡二叉树(AVL)介绍及其实现
    二叉查找树(BST)的实现
    二叉树基本知识
    微信小程序提示框
    urllib3使用指南
  • 原文地址:https://www.cnblogs.com/aishangliming/p/6381723.html
Copyright © 2011-2022 走看看