新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍如何搭建Koa项目,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
为寿光等地区用户提供了全套网页设计制作服务,及寿光网站建设行业解决方案。主营业务为网站建设、成都网站设计、寿光网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
Java中的Spring MVC加MyBatis基本上已成为Java Web的标配。Node JS上对应的有Koa、Express、Mongoose、Sequelize等。Koa一定程度上可以说是Express的升级版。许多Node JS项目已开始使用非关系型数据库(MongoDB)。Sequelize对非关系型数据库(MSSQL、MySQL、SQLLite)做了支持。
Koa项目构建
cnpm install -g koa-generator // 这里一定要用koa2 koa2 /foo
Koa常用中间件介绍
koa-generator生成的应用已经包含常用中间件了,这里仅说它里面没有用到的。
koa-less
app.use(require('koa-less')(__dirname + '/public'))
必须在static前use,不然会无效。
stylesheets文件夹下新建styles.less,并引入所有模块化less文件。
@import 'foo.less'; @import 'bar.less';
这样所有的样式会被编译成一个style.css。在模板(pug)中引用style.css就行了。
koa-session
// 设置app keys,session会根据这个进行加密 app.keys = ['some secret hurr']; // 配置session config const CONFIG = { key: 'bougie:session', /** (string) cookie key (default is koa:sess) */ maxAge: 1000 * 60 * 60 * 24 * 7, overwrite: true, /** (boolean) can overwrite or not (default true) */ httpOnly: true, /** (boolean) httpOnly or not (default true) */ signed: true, /** (boolean) signed or not (default true) */ rolling: true, /** (boolean) Force a session identifier cookie to be set on every response. The expiration is reset to the original maxAge, resetting the expiration countdown. (default is false) */ renew: false, /** (boolean) renew session when session is nearly expired, so we can always keep user logged in. (default is false)*/ }; // 应用中间件 app.use(session(CONFIG, app));
这个必须在router前use,不然会无效。
基本使用,可以当成一个普通对象
// 赋值 ctx.session.statu = value // 取值 ctx.session.statu // 删除 ctx.session.statu = null
koa-proxies
用于代理配置
const proxy = require('koa-proxies') app.use(proxy('/octocat', { target: 'https://api.github.com/users', changeOrigin: true, agent: new httpsProxyAgent('http://1.2.3.4:88'), rewrite: path => path.replace(/^\/octocat(\/|\/\w+)?$/, '/vagusx'), logs: true }))
路由控制
开发主要集中在路由控制这里,包括restful接口和模板渲染
获取参数(request)
查询参数(?param=a)
ctx.query.param
路由参数(/:id)
ctx.params.id
POST参数(JSON或Form)
ctx.request.body
请求回应(response)
服务器响应给客户端的数据
restful
ctx.body = yourData
模板渲染
默认从views目录开始,不许加文件后缀
ctx.render('layout', yourData)
路由拦截
未登录时拒绝请求,这样会返回404
const userAuth = (ctx, next) => { let isLogin = ctx.session.isLogin if(isLogin) return next() } router.use('/', userAuth)
此操作会包含在路由,如"/a"、"/b"等,需在子路由之前use,不然会无效
以上是“如何搭建Koa项目”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!