微信小程序开发教程之http请求

2018/4/10 22:02:37
摘要: 微信小程序的服务器中可以设置四种网络访问域名,每一种类型的网络请求需要设置一个对应的域名,并且要注意的是,在设置域名

微信小程序的服务器中可以设置四种网络访问域名,每一种类型的网络请求需要设置一个对应的域名,并且要注意的是,在设置域名的时候,如果将其设置为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

}


声明:文章"微信小程序开发教程之http请求"为互诚科技—微信小程序开发公司的原创文章,转载请注明出处,谢谢合作!
标签:小程序干货
电话咨询:18011971195(黄先生)
在线留言:
微信扫码,关注我们
相关文章
  • 微信小程序开发难不难,广州互诚科技告诉你

    在百度网页上,很多人在询问微信小程序开发难不难,小编也一样用这样的文字去搜寻答案

  • 微信小程序商城开发报价问题

    定制开发微信小程序商城,就会面对报价的问题,怎样的报价才是准确的、符合市场现状的?这是想要开发小程序商城的商家需要去了解的问题。站在外包开发公司的立场,小编跟大家说说一些与开发报价相关的东西。

  • 品牌电商公司如何借力微信小程序开发来促进发展

    虽然微信小程序刚开始的定位是为用户提供线下工具性服务,但却也因为这个定位限制了小程序的发展以致带来不满意的用户体验与开发体验。在后续的调整后,小程序也可以用作线上服务使用,

  • 微信小程序开发市场,真的有免费模板吗?

    现在去网页上搜索微信小程序开发模板,都会出现很多文案或者链接都在说免费模板、免费模板跟免费模板。可是,现在的市场上,真的有免费的小程序开发模板吗?其实还真有,不过好不好用、会不会骗人就是另外一回事了。

  • 微信小程序开发涉及到电商领域后为什么更受企业欢迎?

    微信小程序在开发前期,由于定位原因,更加偏向于线下方面的发展而忽略了对线上流量的攫取

  • 开发微信小程序时需要注意基本点有哪些

    虽说微信小程序的开发比App开发要简单得多,但是该注意的东西还是得注意,一些最基本的方面更是要注重,避免一些最基本但具有毁灭性的情况出现。那么,这些所谓的基本注意点有哪些?现在小编可以来分点述说一下。