日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

微信小程序與Java后臺(tái)的通信

 wwq圖書(shū)世界 2019-10-10

一、寫(xiě)在前面

最近接觸了小程序的開(kāi)發(fā),后端選擇Java,因?yàn)樾〕绦虻拇a運(yùn)行在騰訊的服務(wù)器上,而我們自己編寫(xiě)的Java代碼運(yùn)行在我們自己部署的服務(wù)器上,所以一開(kāi)始不是很明白小程序如何與后臺(tái)進(jìn)行通信的,然后查找資料發(fā)現(xiàn)結(jié)合了官方提供的api后好像和我們普通的web前后端通信也沒(méi)有多大的區(qū)別,有想法后就寫(xiě)了這個(gè)測(cè)試程序。

二、API文檔

wx.request(OBJECT)

發(fā)起網(wǎng)絡(luò)請(qǐng)求。使用前請(qǐng)先閱讀說(shuō)明。

OBJECT參數(shù)說(shuō)明:

參數(shù)名類型必填默認(rèn)值說(shuō)明
url String   開(kāi)發(fā)者服務(wù)器接口地址
data Object/String   請(qǐng)求的參數(shù)
header Object   設(shè)置請(qǐng)求的 header,header 中不能設(shè)置 Referer。
method String GET (需大寫(xiě))有效值:OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
dataType String json 如果設(shè)為json,會(huì)嘗試對(duì)返回的數(shù)據(jù)做一次 JSON.parse
success Function   收到開(kāi)發(fā)者服務(wù)成功返回的回調(diào)函數(shù)
fail Function   接口調(diào)用失敗的回調(diào)函數(shù)
complete Function   接口調(diào)用結(jié)束的回調(diào)函數(shù)(調(diào)用成功、失敗都會(huì)執(zhí)行)

success返回參數(shù)說(shuō)明:

參數(shù)類型說(shuō)明最低版本
data Object/String 開(kāi)發(fā)者服務(wù)器返回的數(shù)據(jù)  
statusCode Number 開(kāi)發(fā)者服務(wù)器返回的 HTTP 狀態(tài)碼  
header Object 開(kāi)發(fā)者服務(wù)器返回的 HTTP Response Header 1.2.0

data 數(shù)據(jù)說(shuō)明:

最終發(fā)送給服務(wù)器的數(shù)據(jù)是 String 類型,如果傳入的 data 不是 String 類型,會(huì)被轉(zhuǎn)換成 String 。轉(zhuǎn)換規(guī)則如下:

  • 對(duì)于 header['content-type'] 為 application/json 的數(shù)據(jù),會(huì)對(duì)數(shù)據(jù)進(jìn)行 JSON 序列化
  • 對(duì)于 header['content-type'] 為 application/x-www-form-urlencoded 的數(shù)據(jù),會(huì)將數(shù)據(jù)轉(zhuǎn)換成 query string (encodeURIComponent(k)=encodeURIComponent(v)&encodeURIComponent(k)=encodeURIComponent(v)...)

示例代碼

復(fù)制代碼
wx.request({
  url: 'test.php', //僅為示例,并非真實(shí)的接口地址
  data: {
     x: '' ,
     y: ''
  },
  header: {
      'content-type': 'application/json' // 默認(rèn)值
  },
  success: function(res) {
    console.log(res.data)
  }
})
復(fù)制代碼

三、基本思路

將數(shù)據(jù)通過(guò)get方式傳到Java servlet類,servlet得到微信小程序的數(shù)據(jù)打印出來(lái)并返回一個(gè)數(shù)據(jù)給微信小程序,從而實(shí)現(xiàn)一個(gè)最簡(jiǎn)單的前后端通信。

四、關(guān)鍵代碼

微信小程序代碼

index.wxml

  <view>
  <button bindtap='bindtest'>test</button>
  </view>

index.js

復(fù)制代碼
  bindtest: function(){
    wx.request({
      url: 'http://localhost:8080/Demo01/servlet02',
      data:{
        username:'001',
        password:'abc'
      },
      method:'GET',
      header: {
        'content-type': 'application/json' // 默認(rèn)值
      },
      success:function(res){
        console.log(res.data);
      },
      fail:function(res){
        console.log(".....fail.....");
      }
    })
  },
復(fù)制代碼

Java serlvet類代碼

復(fù)制代碼
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        
        response.setContentType("text/html;charset=utf-8");          
        /* 設(shè)置響應(yīng)頭允許ajax跨域訪問(wèn) */  
        response.setHeader("Access-Control-Allow-Origin", "*");  
        /* 星號(hào)表示所有的異域請(qǐng)求都可以接受, */  
        response.setHeader("Access-Control-Allow-Methods", "GET,POST");  
       
        //獲取微信小程序get的參數(shù)值并打印
        String username = request.getParameter("username");
        String password = request.getParameter("password");
        System.out.println("username="+username+" ,password="+password);
        
        //返回值給微信小程序
        Writer out = response.getWriter(); 
        out.write("進(jìn)入后臺(tái)了");
        out.flush();   
    }
復(fù)制代碼

五、效果演示

前端控制臺(tái)

ecplise控制臺(tái)

至此說(shuō)明微信小程序與Java后臺(tái)通信成功!當(dāng)然這是最簡(jiǎn)單的通信,比較復(fù)雜的是需要對(duì)Json數(shù)據(jù)的處理,以后有時(shí)間再總結(jié)下。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多