express 入门

npm install express

npm install ejs

npm install superagent

npm install log4js


express是必须要安装的,用他可以启动一个node的web服务。ejs是服务端页面渲染引擎。superagent是一个服务端的http请求工具,对node原生的http请求的封装,是的在服务端写http请求变得简单。log4js是一个日志工具,是一个node中间件。


app.js如下:

var express = require("express");
var search = require("./search");
var bodyParser = require("body-parser");

var log = require("./tool/log");

var app = express();

app.set("view engine","ejs");
app.set("views",__dirname+"/views");
app.set("view options", { layout: false });

app.use(bodyParser.urlencoded({extended: false}));
app.use(bodyParser.json());

app.use(log.log4js.connectLogger(log.infoLogger, {level:log.log4js.levels.INFO}));
app.use(log.log4js.connectLogger(log.errorLogger, {level:log.log4js.levels.ERROR}));

app.use(require('./controller/search'));
app.use(require('./controller/index'));

app.listen(3000);


日志记录放在tool下面的log.js

var log4js = require('log4js');
log4js.configure({
  appenders: [
    {
      type: 'file', //文件输出
      filename: 'logs/access.log', 
      maxLogSize: 524288000,
      backups:3,
      category: 'info' 
    },
    {
      type: 'file', //文件输出
      filename: 'logs/error.log', 
      maxLogSize: 104857600,
      backups:3,
      category: 'error' 
    }
  ]
});

var infoLogger = log4js.getLogger('info');
infoLogger.setLevel('INFO');

var errorLogger = log4js.getLogger('error');
errorLogger.setLevel('ERROR');

module.exports = {
    log4js:log4js,
    infoLogger:infoLogger,
    errorLogger:errorLogger
}

这里需要事先创建好logs目录


控制器,亦即处理请求和返回页面的内容在controller下面,有index.js跟search.js

index.js

var router = require("express").Router();
var log = require("../tool/log");


router.get("/",function(req, res){
res.render("index");
});


module.exports = router;


search.js

var router = require("express").Router();
var request = require("superagent");
var log = require("../tool/log");


router.post("/search",function(req, res, next){
console.log("recieve keyword search post");
next();
});


router.post("/search",function(req, res){
request.post("http://localhost:8081/search.php")
.type("form")
.send(req.query)
.accept("json")
.end(function(err,req_res){
if(err){
res.send("error found");
log.errorLogger.error(err);
}
if(req_res && req_res.text){
res.render("search", JSON.parse(req_res.text));
return ;
}
log.errorLogger.error("bad request");
});
});


router.get("/search/:keyword",function(req, res, next){
console.log("recieve keyword search");
next();
});


router.get("/search/:keyword",function(req, res){
console.log(req.params.keyword)
res.send("get");
});


module.exports = router;


在router的请求处理中,回调函数有的有next参数有的是没有的,最终处理的函数必须没有next参数。而其他的带next的参数的都表示当前执行的只是中间部分,还需要交给下一步去处理。也可以理解为一个filter,可以做过滤,如果过滤失败,则不回调next

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值