Node后台开发

前言
  • 有时需要实现对公网接口进行转发的操作,使用Java + SpringBoot可能会变得简单需求变得更加繁琐,针对这种轻量级后台开发,Node.js不失为一种优秀的解决方案。
  • 对于前端开发人员,使用原生JS + Node.js即可实现简单的后台开发,上手速度快,也可以锻炼自己成为全干(栈)工程师。
开发环境
  • Node.js环境(v7.6.0+)
  • Koa2框架(Koa 依赖 node v7.6.0 或 ES2015及更高版本和 async 方法支持)
  • 原生JS语法(ES6+ 较好)
起步

以自己来说,较喜欢将项目标准化,一方面加深对项目运行的理解,另一方面使后续开发更加便捷、易于扩展。

工程目录

开发简单标准化后台可遵循以下步骤(针对简单Node起步项目):

  • 创建package.json(引入项目所需依赖库,配置项目基本信息)
  • 创建app.js启动文件(项目入口文件)
  • 创建controller.js及controllers目录下index.js(实现对前端访问接口映射,以调用对应方法返回数据)
  • 创建axiosHttp.js(该项目需要实现接口转发,采用axios库来发起http请求)
  • 实现现有文件的相关功能(可根据实际需求继续扩展功能模块)
具体实现
  • package.json
{
  "name": "hello-koa2",
  "version": "1.0.0",
  "description": "Hello Koa 2 example with async",
  "main": "app.js",
  "scripts": {
    "start": "node app.js"
  },
  "author": "Da Jiangyou",
  "dependencies": {
    "koa": "^2.7.0",
    "koa2-cors": "^2.0.6",
    "koa-router": "7.0.0",
    "koa-bodyparser": "3.2.0",
    "axios": "^0.19.0"
  }
}
koa             Koa框架基础核心组件库
koa2-cors       Koa跨域等参数设置组件库
koa-router      Koa处理URL映射组件库
koa-bodyparser  Koa解析Post携带表单、JSON组件库
  • app.js
const Koa = require('koa')
const Cors = require('koa2-cors')
const controller = require('./controller');
const app = new Koa()
// 允许跨域
app.use(Cors({
  origin: function (ctx) {
    return "*" //允许所有跨域
  },
  maxAge: 5,
  // credentials: true,
  allowMethods: ['GET', 'POST'] // 允许请求方法
}))
// 使用控制器
app.use(controller())
// 监听端口
app.listen(3000)
console.log('app started at port 3000...')
  • index.js
const axiosHttp = require('../axios/axiosHttp')
// 处理URL请求,返回结果
const getPicture_infinity = async (ctx, next) => {
  const res = await axiosHttp.getInfinityPicture()
  ctx.response.body = res.data
};

module.exports = {
  'POST /winter/infinity/getPictures': getPicture_infinity
}
  • controller.js
const fs = require('fs'); // 文件操作库
// 处理请求种类
function addMapping(router, mapping) {
    for (var url in mapping) {
        if (url.startsWith('GET ')) {
            var path = url.substring(4);
            router.get(path, mapping[url]);
            console.log(`register URL mapping: GET ${path}`);
        } else if (url.startsWith('POST ')) {
            var path = url.substring(5);
            router.post(path, mapping[url]);
            console.log(`register URL mapping: POST ${path}`);
        } else {
            console.log(`invalid URL: ${url}`);
        }
    }
}

function addControllers(router) {
    var files = fs.readdirSync(__dirname + '/controllers');
    var js_files = files.filter((f) => {
        return f.endsWith('.js');
    });

    for (var f of js_files) {
        console.log(`process controller: ${f}...`)
        let mapping = require(__dirname + '/controllers/' + f)
        addMapping(router, mapping);
    }
}

module.exports = function (dir) {
    let
        controllers_dir = dir || 'controllers', // 如果不传参数,扫描目录默认为'controllers'
        router = require('koa-router')();
    addControllers(router, controllers_dir);
    return router.routes();
};
  • axiosHttp.js
const axios = require('axios')

// Infinity相关
const infinityPictureUrl = 'https://infinity-api.infinitynewtab.com/get-wallpaper?page=0&source=Infinity'

// 获取Infinity图片
function getInfinityPicture () {
  return axios.get(infinityPictureUrl)
}

module.exports = {
  'getInfinityPicture': getInfinityPicture
}
测试
  • 在项目目录下运行 node app.js或npm run start(package.json中可配置)运行项目


    运行项目
  • 使用Postman发送post请求,测试是否可正常返回数据


    Postman测试
总结

简单上手后,发现node.js实现后台开发比较便捷、轻巧。对简单后台需求(尤其对于前端人员)比较友好,值得学习。

Tip
  • 理解原生JS中require的使用
  • 掌握 async awiat 异步请求方式的使用
  • 后续可加入权限校验等优化功能
  • 使用Node.js进行企业级web后台开发,可参考egg.js
参考资料

Koa官网
廖雪峰Koa教程

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,425评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,058评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,186评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,848评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,249评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,554评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,830评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,536评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,239评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,505评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,004评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,346评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,999评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,060评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,821评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,574评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,480评论 2 267