微信小程序的服务器中可以设置四种网络访问域名,每一种类型的网络请求需要设置一个对应的域名,并且要注意的是,在设置域名的时候,如果将其设置为https://example.com/api/,那么https://example.com/api的话,结果会是无法调用的,必须加上后面/。下面我们讲一下几种网络访问请求的相关内容。
1、http请求
(1)使用wx.request可以发起一个http请求,一个微信小程序最多只能同时有5个网请求。下述的代码会发送http get请求,打印出返回结果。
function queryRequest(data){
wx.request({
url:"https://example.com/api/",
data:data,
header:{
// "Content-Type":"application/json"
},
success:function(res){
console.log(res.data)
},
fail:function(err){
console.log(err)
}
})
}
(2)参数说明
参数 | 说明 |
url | 服务器的url地址 |
data | 请求的参数可以采用String data:"xxx=xxx&xxx=xxx"的形式或者Object data:{"userId":1}的形式 |
header | 设置请求的header |
success | 接口成功的回调 |
fail | 接口失败的回调 |
2、上传文件
上传文件的api为wx.uploadFile,该api会发起一个http post请求,其中的Content-type为multipart/form-data。服务器端需要按照该Content-type类型接收文件,示例代码如下所示。
function uploadFile(file,data) {
wx.uploadFile({
url: 'http://example.com/upload',
filePath: file,
name: 'file',
formData:data,
success:function(res){
console.log(res.data)
},
fail:function(err){
console.log(err)
}
})
}
3、下载文件
下载文件的api为wx.downloadFile,该api发起http get请求,并在下载成功之后会返回文件的临时路径,示例代码如下。其中的url、header、fail、complete和wx.uploadFile的参数使用与第一点一致,有区别的参数是:
(1)type:下载资源的类型,用于客户端自动识别,可以使用的参数image/audio/video。
(2)success:下载成功后的回调,以tempFilePath的参数返回文件的临时目录为res={tempFilePath:'文件路径'}。
function downloadFile(url,typ,success){
wx.downloadFile({
url:url,
type:typ,
success:function(res){
if(success){
success(res.tempFilePath)
}
},
fail:function(err){
console.log(err)
}
})
}
4、文件保存
下载成功后只是临时文件,只能在程序本次运行期间使用,如果需要长期使用,需要调用方法wx.saveFile主动持久化文件,示例代码如下。
function svaeFile(tempFile,success){
wx.saveFile({
tempFilePath:tempFile,
success:function(res){
var svaedFile=res.savedFilePath
if(success){
success(svaeFile)
}
}
})
}
5、超时设置
在app.js中设置networkTimeout,可以设置四种类型网络访问的超时时间,代码如下。
"networkTimeout":{
"request": 10000,
"connectSocket": 10000,
"uploadFile": 10000,
"downloadFile": 10000
}