node+express+mongodb+art-template

一 node环境使用express

1. 下载安装

npm i express --save
//配置启动服务器
npm i nodemon --save  

2. 配置服务器

 var app = express();
 app.listen(3000, function () {
	console.log('app is running, http://127.0.0.1:3000');
})

3. express默认读取的目录是views文件夹,如果需要修改

  • 第一个参数是修改目录的名字
  • 第二个参数是目录路径
app.set('views',path.join(__dirname,'./views/'));

4. 配置静态开放文件路径

  • 第一个参数读取路径文件前面配置的路径 /public/
  • 第二个参数开放那个目录 使用 express.static()
 app.use('/public/', express.static('./public/'));

5. 解析express环境中传入的post方法

  • express只有解析get的方法,没有解析post的方法需要安装插件body-parser
npm i body-parser --save

6. body-parser使用

  • 配置bodyParser必须在挂载路由之前router
var bodyParser = require('body-parser');
app.use(bodyParser.urlencoded({extends:false}))
app.use(bodyParser.json())

7. 使用express中的Router()方法配置路由

//express中有一个Router方法
var router = express.Router();
//以后配置路由直接
router.get('/', (req, res) => {
    //如果需要ajax或者axios调取需要加上以下代码
    //指定的状态码
     res.status(200)
     //返回的数据
     res.json(data)
})
router.post('/', (req, res) => {})

//把路由router挂载到app中
app.use(router)

二、node中使用 mongodb

1.安装 mongoose
npm i mongoose --save

2.使用

  • 数据库连接,没有创建 使用 mongoose.connect()
  • 设计表集合结构 使用mongoose中的Schema方法
  • mongoose.model 方法将一个架构发布为model
    第一个参数:传入一个大写名词数字字符串,用来表示数据库名称
    mongoose会自动将大写名词字符串生成小写的复数的集合名称
    第二个参数就是架构 userSchema
var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/itcast');
//
var Schema = mongoose.Schema;
var commentsSchema = new Schema({
   name:{
       type:String,
       require:true
   },
   gender:{
       type:Number,
       enum:[0,1],
       default:0
   },
   age:{
       type:Number,
       require:true
   }
})
module.exports = mongoose.model('Student',commentsSchema)

三 node中使用art-template模板

1.安装插件

 npm i art-template --save             //art模板
 npm i express-art-template --save     //art-template依赖模板

2.配置使用 art-template

  • 第一个参数渲染文件的后缀名 .html
  • 第二个参数使用express-art-template
  • 安装art-template 后express为Response对象提供了一个方法render
app.engine('html', require('express-art-template'));
router.get('/students', function (req, res) { 
   res.render('文件的名字', {'所需数据'})
})

四、完整代码

1、配置服务器的代码app.js

	var express = require('express');
	var bodyParser = require('body-parser')
	var router = require('./router');
	var app = express();
	
	//配置开放路径
	app.use('/node_modules/', express.static('./node_modules/'))
	app.use('/public/', express.static('./public/'));
	//配置模板引擎
	app.engine('html', require('express-art-template'));
	
	//配置bodyParser必须在挂载路由之前router
	//parse application/x-www-form-urllencoded
	app.use(bodyParser.urlencoded({extends:false}))
	
	//parse application/json
	app.use(bodyParser.json())
	
	//把路由router挂载到app中国
	app.use(router)
	
	app.listen(3000, () => {
	    console.log('running……  http://127.0.0.1:3000');
	})

2. 配置路由的代码 router.js

var express = require('express')
//express中有一个Router方法
var router = express.Router();
var Student= require('./mongoos.js');
//然后 router.get()使用路由
router.get('/', (req, res) => {
    //readFile第二个参数是可选,传入utf8就是告诉它把读取到的文件转成我们能读取的字符
    //还可以通过data.toString()方式
    res.render('index.html')
})
//最后导出
module.exports = router;
//Express提供了一种更好的方式实现路由

3.配置mongodb的代码mongoos.js

var mongoose = require('mongoose');
//连接数据库
mongoose.connect('mongodb://localhost/itcast');
var Schema = mongoose.Schema;
var commentsSchema = new Schema({
   name:{
       type:String,
       require:true
   },
   gender:{
       type:Number,
       enum:[0,1],
       default:0
   },
   age:{
       type:Number,
       require:true
   }
})

module.exports = mongoose.model('Student',commentsSchema)

五 、密码加密

  1. 安装
npm i md5-node --save
  1. 加载使用
  • 注册和登录都需要加密
var md5 = require('md5-node');
req.body.password = md5(req.body.password)

六 express中Session和Cookie使用

  • express中默认不支持Session和Cookie
  • 但是可以使用第三方中间件:express-session
  1. 安装
 npm i express-session --save
  1. 使用
  • 必须配置router之前
app.use(session({
	secret: 'keyboard cat',  //增加安全性
	resave: false,
	saveUninitialized: true  //无论是否使用都会给浏览器一个session
}))

七、涉及到的链接

  1. art-template模板使用方法
  2. mongodb官网
  3. express官网
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值