当前位置: 首页 > 工具软件 > SuperAgent > 使用案例 >

在node中使用request模块和superagent请求接口

谭正谊
2023-12-01

1.通过request请求接口
首先是get请求的使用,如下:

request({
  url: 'address',
  method: 'GET'		//get大小写都可以
}, (err, res, data) => {
    if (err) {
        console.log(err)
    } else {
        const obj = JSON.parse(data);
    }
})

这里的回调有三个参数,第一个是错误信息,第二个是响应信息的集合,第三个是返回的信息,并且data返回的是json字符串,需要通过JSON.parse处理一下。

post请求方法根据content-type的不同又有所区别

POST application/json

request({
    url: 'address',
    method: 'POST',
    headers: {
      'content-type': 'application/json',
      'Cookie': 'cookie'
    },
    body: JSON.stringify({ cate_id: '6809637767543259144' }),
  },(err, res, data) => {
    if (err) {
      console.log(err);
    } else {
      const obj = JSON.parse(data);
    }
  }
);

这里通过填写headers的信息来实现有登录权限来请求接口,需要发送的参数是放在body中,并且需要处理成JSON字符串的形式,同样返回的内容再处理一次。

POST application/x-www-form-urlencoded

request.post({url:'http://service.com/upload', form:{key:'value'}}, function(error, response, body) {
    if (!error && response.statusCode == 200) {
    }
})

POST multipart/form-data

var formData = {
    // Pass a simple key-value pair
    my_field: 'my_value',
    // Pass data via Buffers
    my_buffer: new Buffer([1, 2, 3]),
    // Pass data via Streams
    my_file: fs.createReadStream(__dirname + '/unicycle.jpg'),
};
request.post({url:'http://service.com/upload', formData: formData}, function (error, response, body) {  
    if (!error && response.statusCode == 200) {
    }
})

2.通过superagent来访问接口
之前只是用来写脚本时会用到superagent的请求一些页面,后来发现也可以通过它来请求接口,实现request同样的功能,并且用起来也是很方便的。
首先来看get请求写法,如下:

superagent.get('address').end((req, res) => {
  console.log(res.text)
})

还是很方便的,end方法就是请求成功之后的回调,需要注意的是它的返回值内容都是放在res.text中的。
再看post请求接口,如下:

superagent.post('address')
  .set('Cookie','cookie')
  .send({ key: value })
  .end((req, res) => {
    let obj = JSON.parse(res.text);
  });

需要带cookie请求的,可以通过set方法来种植cookie,send方法是要传递的参数,end是请求成功之后的回调。

 类似资料: