Skip to content

LeoHughes/InterfaceProxy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

82 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

InterfaceProxy

Build Status npm version 996.icu

NPM

 Need nodejs >= 7.6.0

How to use

1.在json文件或js中定义请求的服务器地址和与接口相关的配置

2.实例化ProxyModel类,然后调用

const path = require('path');
const InterfaceProxy = require('interfaceproxy');

let pm = new InterfaceProxy(path.resolve(__dirname, './interface.json'));

//let pm = new InterfaceProxy(path.resolve(__dirname, './interface.js'));

API

InterfaceProxy.mount(filePath)

根据文件路径挂载新配置,并将其添加到实例化的InterfaceProxy对象中

InterfaceProxy.getHttpOption(interfaceId)

根据接口ID在配置文件中获取相应的http请求选项

InterfaceProxy.request(url)

根据URL地址发起的请求
  let resData = await pm.request('http://www.baidu.com')
  • url:[String] Url address

InterfaceProxy.send(option[,param])

根据参数发起单个请求
  • option:[String | Object] 接口ID或完整的http请求参数(httpOption)
  • param: [Object] 请求接口所需的相关参数
  • headers: [Object] 额外的headers参数
  let resData = await pm.send('getBaiduHTML')

  let resData = await pm.send('getZhiHuData', null, { token: '123456' })

  let resData = await pm.send({
    protocol: 'http:',
    hostname: "www.baidu.com",
    port: 80,
    path: "/",
    method: "GET",
    headers: {
      "Content-Type": "text/html;charset=utf-8"
    }
  })

InterfaceProxy.url(id, path)

根据接口ID和路径拼接httpOption路径参数,然后请求
  • id: [String] 接口id
  • path: [String] 需要拼接的地址
  • param: [Object] 请求接口所需的相关参数
  • headers: [Object] 额外的headers参数

InterfaceProxy.all(oprionArr)

根据配置数组同时获得多接口数据
  • oprionArr: [Array] 接口配置数组
  • type:[String] all:promise.all,race:promise.race
  let multiData = await pm.all([
    { 'id': 'getZhiHuData', 'param': {}, 'headers': { 'token': '123' } },
    { 'id': 'getBaiduHTML', 'param': { 'name': '1eo', 'age': 26 }, 'headers': { 'token': '456' } }
  ])

Interface Configuration Format Reference

module.exports = {
  project: "Interface-proxy",
  version: "1.0.0",
  servers: [{ //Server address config
      id: "localhost",
      name: "localhost",
      timeOut: 2000, //The number of milliseconds the request times out
      protocol: 'http:',
      hostname: "127.0.0.1",
      port: 3000
    }
  ],
  interfaces: [{ //Request interface address and related configuration
      id: "test",
      name: "testPath",
      path: "/test",
      serverId: "localhost",
      method: "GET",
      headers: {
        "Content-Type": "application/x-www-form-urlencoded;charset=utf-8"
      }
    }
  ]
};

About

NodeJS Interface Configuration Forwarding Tool.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published