您当前的位置: 首页 > 知识百科 > 微信小程序后端JAVA的使用代码详解

微信小程序后端JAVA的使用代码详解

时间:2023-07-01 14:05 阅读数:16 人阅读 分类:知识百科

  微信小程序后端JAVA能够在小程序开发过程中起到至关重要的作用,但是很多小程序开发者对它还不太了解,如果要让后端JAVA实现websocket与微信小程序端连接要怎么操作呢?以下是实现代码:

  后端JAVA实现websocket与微信小程序端连接代码:

  import java.io.IOException;

  import java.util.concurrent.CopyOnWriteArraySet;

  import javax.websocket.OnClose;

  import javax.websocket.OnError;

  import javax.websocket.OnMessage;

  import javax.websocket.OnOpen;

  import javax.websocket.Session;

  import javax.websocket.server.ServerEndpoint;

  //该注解用来指定一个URI,客户端可以通过这个URI来连接到WebSocket。类似Servlet的注解mapping。无需在web.xml中配置。

  @ServerEndpoint("/websocket")

  public class MyWebSocket {

  //静态变量,用来记录当前在线连接数。应该把它设计成线程安全的。

  private static int onlineCount = 0;

  //concurrent包的线程安全Set,用来存放每个客户端对应的MyWebSocket对象。若要实现服务端与单一客户端通信的话,可以使用Map来存放,其中Key可以为用户标识

  private static CopyOnWriteArraySet webSocketSet = new CopyOnWriteArraySet();

  //与某个客户端的连接会话,需要通过它来给客户端发送数据

  private Session session;

  /**

  * 连接建立成功调用小程序接口的方法

  * @param session 可选的参数。session为与某个客户端的连接会话,需要通过它来给客户端发送数据

  */

  @OnOpen

  public void onOpen(Session session){

  this.session = session;

  webSocketSet.add(this); //加入set中

  addOnlineCount(); //在线数加1

  System.out.println("有新连接加入!当前在线人数为" + getOnlineCount());

  }

  /**

  * 连接关闭调用的方法

  */

  @OnClose

  public void onClose(){

  webSocketSet.remove(this); //从set中删除

  subOnlineCount(); //在线数减1

  System.out.println("有一连接关闭!当前在线人数为" + getOnlineCount());

  }

  /**

  * 收到客户端消息后调用的方法

  * @param message 客户端发送过来的消息

  * @param session 可选的参数

  */

  @OnMessage

  public void onMessage(String message, Session session) {

  System.out.println("来自客户端的消息:" + message);

  //群发消息

  for(MyWebSocket item: webSocketSet){

  try {

  item.sendMessage(message);

  } catch (IOException e) {

  e.printStackTrace();

  continue;

  }

  }

  }

  /**

  * 发生错误时调用

  * @param session

  * @param error

  */

  @OnError

  public void onError(Session session, Throwable error){

  System.out.println("发生错误");

  error.printStackTrace();

  }

  /**

  * 这个方法与上面几个方法不一样。没有用注解,是根据自己需要添加的方法。

  * @param message

  * @throws IOException

  */

  public void sendMessage(String message) throws IOException{

  this.session.getBasicRemote().sendText(message);

  //this.session.getAsyncRemote().sendText(message);

  }

  public static synchronized int getOnlineCount() {

  return onlineCount;

  }

  public static synchronized void addOnlineCount() {

  MyWebSocket.onlineCount++;

  }

  public static synchronized void subOnlineCount() {

  MyWebSocket.onlineCount--;

  }

  }

  以上是网上的前端及后端的代码。utm_source=tuicool&utm_medium=referral),jdk版本要求是在jdk1.7.0以上,tomcat版本也需要在tomcat7.0版本以上。另外有个需要注意的点就是websocket的api包要用tomcat自带的(websocket-api.jar),一开始本人采用的是非tomcat自带的javax.websocket-api-1.0.jar包,在配置了正确的环境之后总是连接不上,会报错:Error during WebSocket handshake: Unexpected response code: 404。

  进入页面

  输入内容,点击send

  微信小程序端发起请求:

  请求代码:

  connectWebSocket:function(){

  console.log("创建webSocket连接");

  wx.connectSocket({

  url:'ws://localhost:8080/myWebSocket/websocket',

  // url:'eservicesit.prlife:7001',

  data:{

  x: '',

  y: ''

  },

  header:{

  'content-type': 'application/json'

  },

  method:"GET",

  success: function(res){

  console.log("创建连接成功");

  //do something

  },

  fail:function(res){

  console.log("创建连接失败,原因因::"+res.errMsg);

  },

  complete:function(){

  console.log("创建连接complete");

  }

  })

  以上就是微信小程序后端JAVA的使用实例了,复制上述代码就可以使用微信小程序后端JAVA连接websocket与微信小程序端,是不是很简单?更多相关资料请关注微信小程序商店。

  

  java富有创意的小程序怎么编写?

  关于java的逻辑小程序编写教程

  微信小程序怎么链接java服务端接口?