当前位置:首页 > 前端 > 正文内容

【原创】api接口模拟器(NodeJS版)

Z先生6年前 (2019-11-28)前端671

最近遇到一个项目,内网的APP,后端数据和前段开发属于异地,没法直接做接口数据测试。因此用NodeJs简单写了个API模拟器,只要将响应的数据放在对应目录下json.json文件中即可。

请求地址全静态话,暂未考虑参数问题。

具体代码如下:

main.js文件

'use strict';

var
	fs = require('fs'),
	url = require('url'),
	path = require('path'),
	http = require('http'),
	port = process.argv.splice(2);

port = parseInt(port, 10);
port = isNaN(port) || port == 0 ? 8111 : port;

// 创建http server,并传入回调函数:
var server = http.createServer(function(request, response) {
	// 跨域请求
	let origin = request.headers.origin;
	origin = origin ? origin : "*";
	response.setHeader("Access-Control-Allow-Origin", origin);
	response.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS");
	response.setHeader("Access-Control-Allow-Headers",
		"Origin, X-Requested-With, Content-Type, Accept,X-Tag,authKey,vtoken,sessionID");
	response.setHeader("Access-Control-Allow-Credentials", true);

	var pathname = url.parse(request.url).pathname;
	
	// 关闭nodejs 默认访问 favicon.ico
	if (!pathname.indexOf('/favicon.ico')) {
		return;
	};

	if (pathname == "/") {
		//默认首页
		response.end('It`s Work!');
	} else {
		var filepath = path.join(__dirname, pathname);
		fs.stat(filepath, function(err, stats) {
			if (!err && stats.isFile()) {
				// 没有出错并且文件存在:
				console.log('200 ' + request.url);
				// 发送200响应:
				response.writeHead(200);
				// 将文件流导向response:
				fs.createReadStream(filepath).pipe(response);
			} else {
				var fileArr = pathname.split(".");
				if (fileArr.length === 2) {
					if (fileArr[1].length <= 4) {
						console.log('404 ' + request.url);
						// 发送404响应:
						response.writeHead(404);
						response.end('404 Not Found');
					}
				}
				var _filepath = path.join(filepath, "/json.json");
				fs.stat(_filepath, function(_err, _stats) {
					if (!_err && _stats.isFile()) {
						// 没有出错并且文件存在:
						console.log('200 ' + request.url);
						// 发送200响应:
						response.writeHead(200);
						// 将文件流导向response:
						fs.createReadStream(_filepath).pipe(response);
					} else {
						console.log('404 ' + _filepath);
						response.writeHead(404);
						response.write('<head><meta charset="utf-8"/></head>');

						response.end('请将相应结果写入[' + _filepath + "]文件中");
					}
				})
			}
		})
	}
});

// 让服务器监听端口:
server.listen(port);

console.log('Server is running at http://127.0.0.1:' + port + '/');

运行的时候只需要执行

node main.js 8811

其中8811为端口号,如果不写默认则是8111端口。

请求地址:http://127.0.0.1:8811/App/login

响应文件则是:\App\login\json.json


分享给朋友:

相关文章

npm如何使用国内镜像源?

通过命令配置1. 命令淘宝源npm config set registry https://registry.npmmirror.com腾讯源npm ...

ColorUI色系

ColorUI色系

                          ...

uniapp无缝滚动核心代码

1、页面代码核心代码<scroll-view class="scoll-warp">     <view&nb...

一个很漂亮的404页面

一个很漂亮的404页面

下载地址:404.zip...

截至2020年6月PC显示器分辨率占比

截至2020年6月PC显示器分辨率占比

做一个项目汇报,需要用到这个数据;首先想到的数据源是cnzz的统计,去看了半天,没有抽这个数据层面出来。然后又去找51la,很可惜没有类似的大数据报告;又去百度统计里面,看到有这个数据,但是比较抽象,...

antd vue版一些小细节

复选框默认选择复选框选择默认选择,但是不要使用属性手上的checked,否则渲染后无法动态修改,有defaultChecked方法,但是测试无效,所以使用valuePropName: <pre...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。
请先 登录 再评论,若不是会员请先 注册