日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

微信小程序与Java后台的通信

發布時間:2023/12/13 java 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 微信小程序与Java后台的通信 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、寫在前面

最近接觸了小程序的開發,后端選擇Java,因為小程序的代碼運行在騰訊的服務器上,而我們自己編寫的Java代碼運行在我們自己部署的服務器上,所以一開始不是很明白小程序如何與后臺進行通信的,然后查找資料發現結合了官方提供的api后好像和我們普通的web前后端通信也沒有多大的區別,有想法后就寫了這個測試程序。

二、API文檔

wx.request(OBJECT)

發起網絡請求。使用前請先閱讀說明。

OBJECT參數說明:

參數名類型必填默認值說明
urlString?開發者服務器接口地址
dataObject/String?請求的參數
headerObject?設置請求的 header,header 中不能設置 Referer。
methodStringGET(需大寫)有效值:OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
dataTypeStringjson如果設為json,會嘗試對返回的數據做一次 JSON.parse
successFunction?收到開發者服務成功返回的回調函數
failFunction?接口調用失敗的回調函數
completeFunction?接口調用結束的回調函數(調用成功、失敗都會執行)

success返回參數說明:

參數類型說明最低版本
dataObject/String開發者服務器返回的數據?
statusCodeNumber開發者服務器返回的 HTTP 狀態碼?
headerObject開發者服務器返回的 HTTP Response Header1.2.0

data 數據說明:

最終發送給服務器的數據是 String 類型,如果傳入的 data 不是 String 類型,會被轉換成 String 。轉換規則如下:

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

示例代碼

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

三、基本思路

將數據通過get方式傳到Java servlet類,servlet得到微信小程序的數據打印出來并返回一個數據給微信小程序,從而實現一個最簡單的前后端通信。

四、關鍵代碼

微信小程序代碼

index.wxml

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

index.js

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

Java serlvet類代碼

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

五、效果演示

前端控制臺

ecplise控制臺

至此說明微信小程序與Java后臺通信成功!當然這是最簡單的通信,比較復雜的是需要對Json數據的處理,以后有時間再總結下。

轉載于:https://www.cnblogs.com/dichuan/p/7932442.html

總結

以上是生活随笔為你收集整理的微信小程序与Java后台的通信的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。