微信小程序 实现与JAVA后台 数据交互(详解简单易懂)

效果展示
Java端:
在这里插入图片描述
小程序端
在这里插入图片描述

方法介绍:先建立一个小程序,完成wxml和js代码部分,再创建一个*java web *项目,配置好web.xml文件,然后创建servlet.java文件,进行编程。
这个可以同时完成传数据和接收数据,
小程序中

data:{
          name:"卡尔·弗兰兹",
          weapon:'WarHammer'
        },

是发送的数据
res.data
是接收的数据

JAVA端中

        String   name1 = request.getParameter("name");
        String   name= new String(name1.getBytes("ISO-8859-1"), "UTF-8");
        //对微信小程序编码方式进行转化
        String   weapon1 = request.getParameter("weapon");
        String   weapon= new String(weapon1.getBytes("ISO-8859-1"), "UTF-8");

是接收数据

        Writer out = response.getWriter();
        out.write("Victory");
        out.flush();

是发送数据
或者写成

        Writer out = response.getWriter();
        out.write(name);
        out.flush();
        out.write(weapon);
        out.flush();

即可返回数据到小程序端

wxml代码

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

js代码


  Page({
    bindtest: function(){
      wx.request({
        url: 'http://localhost:8080/XCXTEST/demo',//填Servelet运行后的地址
        data:{
          name:"卡尔·弗兰兹",
          weapon:'WarHammer'
        },
        method:'GET',
        header: {
          'Content-Type': 'application/x-www-form-urlencoded',
          "Accept": "application/json;charset=utf-8"
        },
        success:function(res){
          console.log(res.data);
        },
        fail:function(res){
          console.log("Failure");
        }
      })
    }
    }) 

java端代码

package servlet;

import java.io.IOException;
import java.io.Writer;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


public class Servlet extends javax.servlet.http.HttpServlet {
	
    protected void doPost(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        /*设置响应头允许ajax跨域访问*/
        response.setHeader("Access-Control-Allow-Origin", "*");
        /* 星号表示所有的异域请求都可以接受, */
        response.setHeader("Access-Control-Allow-Methods", "GET,POST");
        //获取微信小程序get的参数值并打印
        String   name1 = request.getParameter("name");
        String   name= new String(name1.getBytes("ISO-8859-1"), "UTF-8");
        //对微信小程序编码方式进行转化
        String   weapon1 = request.getParameter("weapon");
        String   weapon= new String(weapon1.getBytes("ISO-8859-1"), "UTF-8");
        System.out.println("name:"+ name+"weapon"+weapon);
        //返回值给微信小程序
        
        Writer out = response.getWriter();
        out.write("Victory");
        out.flush();
    }

    protected void doGet(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException, IOException {
        this.doPost(request, response);       
    }
}

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0">
  <display-name>XCXTEST</display-name>
  /*只要动这中间的*/
  <!-- 配置Servlet信息 -->
  <servlet>
  <!-- 配置Servlet名称,名称必须唯一 -->
  <servlet-name>dingpiao</servlet-name>
  <!-- 配置Servlet完全路径(包名+类名) -->
		<servlet-class>servlet.Servlet</servlet-class>
	</servlet>
	<!-- 配置Servlet映射(访问路径) -->
	<servlet-mapping>
			<!-- 配置Servlet名称,必须和上面的相同 -->
			<servlet-name>dingpiao</servlet-name>
			<!-- 配置虚拟路径(访问路径) -->
			<url-pattern>/demo</url-pattern>
	</servlet-mapping>
/*只要动这中间的*/
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
</web-app>

这个是通过绑定事件点击按钮完成数据交互,当然也可以用 onLoad() {}方法,在页面加载时就完成数据的交互~

  • 14
    点赞
  • 71
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值