当前位置:首页 > 前端

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

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

最近遇到一个项目,内网的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


分享给朋友:

相关文章

H5模拟微信菜单下拉菜单

H5模拟微信菜单下拉菜单

核心HTML代码:核心点:外层类“submenu-warp”子菜单类:“submenu”<div data-href="#mainurl" class=&…

IE11,Chrome粘贴图片上传的JS实现方法和逻辑

核心代码如下://处理IE11,Chrome粘贴图片上传 function pasteUpload() { var file = null;…

记vue/uniapp本地调试以及部署代理服务器设置哪些事

接触vue差不多也一年有余,很多概念性的东西都不懂,逐步已经习惯了npm来安装,之前其他同事做的一些项目,npm自己拿过来也踩了很多坑,比如换个环境再npm就跑不起来了等等之类的,遇到最多的就是scs…

VUE/UNIAPP事件传参

第一种方式使用data<view @click="handleClick" data-info="大家好">点击按钮</v…

vue踩坑记20201027

elemeui/antd等框架,再使用复选框、下拉选择框时,如果通过v-model绑定了值,那么选择时,界面不会改变。方法一:使用default-value指定默认值,@change去改变本该v-mo…

UNIAPP内容区域高度定义

代码如下height: calc(100vh - var(--window-top) - var(--window-bottom));CSS变量uni…

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。