前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Android WebSocket】Android 端 WebSocket 基本用法 ( 添加依赖和权限 | 创建 WebSocketClient 客户端类 | 建立连接并发送消息 )

【Android WebSocket】Android 端 WebSocket 基本用法 ( 添加依赖和权限 | 创建 WebSocketClient 客户端类 | 建立连接并发送消息 )

作者头像
韩曙亮
发布2023-03-30 13:26:06
3.3K0
发布2023-03-30 13:26:06
举报
文章被收录于专栏:韩曙亮的移动开发专栏

文章目录

使用 https://github.com/TooTallNate/Java-WebSocket 框架 ;

一、添加依赖和权限


在 build.gradle 构建脚本中 , 添加依赖 :

代码语言:javascript
复制
implementation 'org.java-websocket:Java-WebSocket:1.5.2'

在 AndroidManifest.xml 清单文件中 , 添加网络权限 :

代码语言:javascript
复制
<uses-permission android:name="android.permission.INTERNET" />

二、创建 WebSocketClient 客户端类


创建 org.java_websocket.client.WebSocketClient 子类 ;

代码语言:javascript
复制
package kim.hsl.websocketdemo

import android.util.Log
import org.java_websocket.client.WebSocketClient
import org.java_websocket.handshake.ServerHandshake
import java.lang.Exception
import java.net.URI

open class MyWebSocketClient(serverUri: URI?) : WebSocketClient(serverUri) {

    val TAG = "MyWebSocketClient"

    override fun onOpen(handshakedata: ServerHandshake?) {
        Log.i(TAG, "onOpen handshakedata=$handshakedata")
    }

    override fun onMessage(message: String?) {
        Log.i(TAG, "onMessage message=$message")
    }

    override fun onClose(code: Int, reason: String?, remote: Boolean) {
        Log.i(TAG, "onClose code=$code reason=$reason remote=$remote")
    }

    override fun onError(ex: Exception?) {
        Log.i(TAG, "onError ex=$ex")
    }
}

三、建立连接并发送消息


创建 客户端 对象 : 设置 WebSocket 地址 , 使用匿名内部类的方式实现 , 主要是为了在本类中获取 onMessage 方法中接收的来自服务器端的消息 ;

代码语言:javascript
复制
var uri: URI? = URI.create("ws://***自己实现服务器端***")
var client: MyWebSocketClient = object : MyWebSocketClient(uri){
    override fun onMessage(message: String?) {
        super.onMessage(message)
    }
}

连接服务器 : 调用 org.java_websocket.client.WebSocketClient 的 connectBlocking() 函数 , 即可连接远程服务器并阻塞该线程 , 服务器连接成功后 , 会回调该类的 onOpen 方法 , 并解除阻塞 ;

代码语言:javascript
复制
client.connectBlocking()

向服务器发送数据 : 调用 org.java_websocket.client.WebSocketClient 的 send() 函数 , 即可向远程服务器发送消息 , 回送的消息在 onMessage 回调方法中的 message: String? 参数可以获取到 ;

代码语言:javascript
复制
client.send("**自定义消息**")

完整代码如下 :

代码语言:javascript
复制
package kim.hsl.websocketdemo

import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import java.net.URI

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

		// 服务器端 WebSocket 地址
        var uri: URI? = URI.create("ws://***自己实现服务器端***")

		// 创建客户端对象
        var client: MyWebSocketClient = object : MyWebSocketClient(uri){
            override fun onMessage(message: String?) {
                super.onMessage(message)
            }
        }

		// 连接远程服务器
        client.connectBlocking()
			
		// 发送消息
        client.send("**自定义消息**")
    }
}

执行结果如下 :

在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、添加依赖和权限
  • 二、创建 WebSocketClient 客户端类
  • 三、建立连接并发送消息
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档