Node.js 实现简单的接口服务器的实例代码
时间:2019-03-30
本文章向大家介绍Node.js 实现简单的接口服务器的实例代码,主要包括Node.js 实现简单的接口服务器的实例代码使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
通过Node.js来实现接口服务器的功能。主要特点为:
1) 增加接口不需要重启
2) 异步执行,但接口阅读的时候是同步的代码(从上而下),或者可以按需求并行,串行
这里只是抛出基本思路,所以使用GET,也没有加密之类的
首先启动监听端口,配置好访问规则。(通过识别特定URL ,动态执行相应的接口脚本)
----- |----HamstrerServlet | ------ command3G | ------ login.js //登录脚本(这里只是简单演示) | --- server.js (主启动脚本) | --- dbutil (数据库操作)
server.js
var $ = require('jquery'); var _ = require('underscore'); var vm = require('vm'); var fs = require('fs'); var journey = require('journey'); var async = require('async'); var dbutil = require('./dbutil'); String.prototype.replaceAll = function(s1, s2) { var demo = this while (demo.indexOf(s1) != - 1) demo = demo.replace(s1, s2); return demo; } // Create a Router var router = new(journey.Router); // Create the routing table router.map(function() { // this.root.bind(function (req, res) { res.send("Welcome") }); this.get(/HamstrerServlet\/(\w*\W*\w*)*/).bind(function(req, res, id) { var runJsPath = this.request.url.pathname.replaceAll("/HamstrerServlet", "") + ".js"; console.log("执行的脚本文件:" + runJsPath); //传入的绑定变量 var sandbox = { req: req, res: res, $: $, dbutil: dbutil, async: async, console: console }; fs.readFile('./HamstrerServlet' + runJsPath, function(err, data) { vm.runInNewContext(data, sandbox, 'myfile.vm'); }); }); this.post('/^HamstrerServlet\/(\w*)$/)').bind(function(req, res, data) { res.send(200); }); }); require('http').createServer(function(request, response) { var body = ""; request.addListener('data', function(chunk) { body += chunk }); request.addListener('end', function() { router.handle(request, body, function(result) { response.writeHead(result.status, result.headers); response.end(result.body); }); }); }).listen(8080);
dbutil.js
var mysql = require('mysql'); //导入mysql Module var pool = mysql.createPool({ host: '192.168.140.237', user: 'root', password: '123456', database: 'command3G' }); //查询sql语句 function query(strSQL, param, callback) { pool.getConnection(function(err, connection) { connection.query(strSQL, param, function(err, rows, fields) { if (err) throw err; callback(rows, fields); connection.end(); // connection.destroy(); }); }); } exports.query = query;
login.js
console.log("beigin"); //并行处理,相当于2个map最后再做一个ReReduce async.parallel([ function(callback){ // 从数据库中获取当前时间 dbutil.query("SELECT CURTIME() AS DATE",null,function(rows,fields){ callback(null, rows[0].DATE); }); }, function(callback){ //随便返回一个值 callback(null, '中文测试'); } ], function(err, results){ console.log(results); var retVal ={ "currentTime": results[0], "desc": results[1] }; res.sendBody(JSON.stringify(retVal)); });
node server.js 启动后通过访问 http://localhost:8080/HamstrerServlet/command3G/login
就会输出:
这个时候修改login.js都会及时生效,不需要重新启动服务器
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- 1819: [JSOI]Word Query电子字典
- 【推荐】C#线程篇---Task(任务)和线程池不得不说的秘密(5.2)
- javascript 事件基础
- 算法模板——sap网络最大流 3(递归+邻接矩阵)
- 从Hash Killer I、II、III论字符串哈希
- angularjs 缓存详解
- 算法模板——线段树7(骰子翻转问题)
- 2729: [HNOI2012]排队
- 算法模板——sap网络最大流 2(非递归+邻接表)
- 算法模板——sap网络最大流 1(非递归+邻接矩阵)
- webpack学习(四)extract-text-webpack-plugin插件
- Codevs2822 爱在心中
- 3098: Hash Killer II
- 1380 没有上司的舞会
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Flutter基础widgets教程-CupertinoAlertDialog篇
- Spring的Controller是单例还是多例?怎么保证并发的安全
- 用TypeScript装饰器实现一个简单的依赖注入
- PING问题解决方法_20190305
- 前端需要掌握的设计模式
- @vue/composition-api速成课(通俗易懂版)
- 新1期视频第14课und异常中断模式的bug以及对应的解决方法
- 第一课:linux设备树的引入与体验(基于linux4.19内核版本)
- 第二课:linux设备树的规范(dts和dtb)
- 二叉树剪枝了解一下~
- 第三课:linux内核对设备树的处理
- 第四课:u-boot对设备树的支持
- 第五课. 内核中断系统中的设备树
- 第六课:在LCD驱动中使用设备树
- 拒绝接口裸奔!开放API接口签名验证!