java与微信小程序通讯_微信小程序與Java后台的通信

一、寫在前面

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

二、API文檔

wx.request(OBJECT)

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

OBJECT參數說明:

參數名

類型

必填

默認值

說明

url

String

開發者服務器接口地址

data

Object/String

請求的參數

header

Object

設置請求的 header,header 中不能設置 Referer。

method

String

GET

(需大寫)有效值:OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT

dataType

String

json

如果設為json,會嘗試對返回的數據做一次 JSON.parse

success

Function

收到開發者服務成功返回的回調函數

fail

Function

接口調用失敗的回調函數

complete

Function

接口調用結束的回調函數(調用成功、失敗都會執行)

success返回參數說明:

參數

類型

說明

最低版本

data

Object/String

開發者服務器返回的數據

statusCode

Number

開發者服務器返回的 HTTP 狀態碼

header

Object

開發者服務器返回的 HTTP Response Header

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

test

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) throwsServletException, IOException {

// TODO Auto-generated method stub

response.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();

}

五、效果演示

前端控制台

6a40ddc7f088d95f2d685c03fee119e1.png

ecplise控制台

d524a411de71439f41bd208587477e18.png

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值