node express 登陸攔截器 request接口請求

1.攔截器express

攔截器能夠根據須要 作權限攔截 登陸只是權限的一種,npm

思路是req.session.user判斷用戶session是否存在,是不是須要攔截的地址,json

若是是就跳轉登陸頁,或其餘頁,cookie

若是非需攔截頁,則執行 next(); 放行session

由於是順序執行的因此 app.all('/*', function(req, res, next){   這個方法需放在定義的路由之上app

具體寫法以下:函數

//登陸攔截器
app.all('/*', function(req, res, next){
  if (req.session.user) {
    next();
  }else {
    var arr = req.url.split('/');// 解析用戶請求的路徑

    for (var i = 0, length = arr.length; i < length; i++) {// 去除 GET 請求路徑上攜帶的參數
      arr[i] = arr[i].split('?')[0];
    }
    if (arr.length > 1 && arr[1] == '') {// 判斷請求路徑是否爲根、登陸、註冊、登出,若是是不作攔截
      next();
    } else if (arr.length > 2 && arr[1] == 'user' && (arr[2] == 'register' || arr[2] == 'login' || arr[2] == 'logout' || arr[2].indexOf('login') > 0 )) {
      next();
    } else {  // 登陸攔截
      req.session.originalUrl = req.originalUrl ? req.originalUrl : null;  // 記錄用戶原始請求路徑
      req.flash('error', '請先登陸');
      res.redirect('/user/login');  // 將用戶重定向到登陸頁面
    }
  }
});

 結尾附上個人app.js:post

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var session = require('express-session');
var bodyParser = require('body-parser');
var hbs = require('hbs');
var flash = require('connect-flash');

var index = require('./routes/index');
var users = require('./routes/users');
var about = require('./routes/about');
var list_ = require('./routes/product/list');
var login = require('./routes/user/login');
var login_post = require('./routes/user/login_post');

var app = express();

app.use(cookieParser());
app.use(session({
  secret: '123456',
  cookie: {maxAge: 60 * 1000 * 30},
  resave: false,
  saveUninitialized: true
}));

app.use(flash());

hbs.registerPartials(path.join(__dirname, 'views', 'partials' ));
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hbs');

var blocks = {};

hbs.registerHelper('extend', function(name, context) {
  var block = blocks[name];
  if (!block) {
    block = blocks[name] = [];
  }

  block.push(context.fn(this)); // for older versions of handlebars, use block.push(context(this));
});

hbs.registerHelper('block', function(name) {
  var val = (blocks[name] || []).join('\n');

  // clear the block
  blocks[name] = [];
  return val;
});

// uncomment after placing your favicon in /public
app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

//登陸攔截器
app.all('/*', function(req, res, next){
  if (req.session.user) {
    next();
  }else {
    var arr = req.url.split('/');// 解析用戶請求的路徑

    for (var i = 0, length = arr.length; i < length; i++) {// 去除 GET 請求路徑上攜帶的參數
      arr[i] = arr[i].split('?')[0];
    }
    if (arr.length > 1 && arr[1] == '') {// 判斷請求路徑是否爲根、登陸、註冊、登出,若是是不作攔截
      next();
    } else if (arr.length > 2 && arr[1] == 'user' && (arr[2] == 'register' || arr[2] == 'login' || arr[2] == 'logout' || arr[2].indexOf('login') >= 0 )) {
      next();
    } else {  // 登陸攔截
      req.session.originalUrl = req.originalUrl ? req.originalUrl : null;  // 記錄用戶原始請求路徑
      req.flash('error', '請先登陸');
      res.redirect('/user/login');  // 將用戶重定向到登陸頁面
    }
  }
});

app.use('/', index);
app.use('/users', users);
app.use('/about', about);
app.use('/product/list', list_);
app.use('/user/login', login);
app.use('/user/loginPost', login_post);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

 

2.request接口請求ui

request模塊安裝:$npm install request --save-devthis

引入模塊:var request = require('request');

能夠傳入一個callback回調函數 執行 請求後數據

 var url = "https://xxxxxx/login";
  //var md5 = crypto.createHash('md5');//md5加密模塊
  //pwd = md5.update(pwd).digest('hex');

  var formData = {
    user_name: userName,
    passwd: pwd,
    access_token: "1"
  };
  request.post({url:url, formData: formData}, function(err, httpResponse, body) {
    if (err) {
      console.error('failed:', err);
      callback && callback(err);
    }else{
      var data = eval('(' + body + ')');
      if (data.errorCode == 0) {
        var userInfo = data.data;
        callback && callback(userInfo);
      }
    }
  });
相關文章
相關標籤/搜索