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