Skip to content

Files

Latest commit

0941107 · Sep 27, 2023

History

History
104 lines (77 loc) · 3.62 KB

README.md

File metadata and controls

104 lines (77 loc) · 3.62 KB
head

基于websocket的实时通信服务


madeWithKotlin
buildState KtV license jvm

目录

使用

$ java -jar kwsify.jar --help  # 获取帮助

Release中下载最新版本的jar使用以下命令运行

$ # 默认的监听地址为: 0.0.0.0:5050
$ java -jar kwsify.jar [--host 0.0.0.0] [--port 6060]

订阅

使用Websocket连接到服务器

返回的数据中的msgType表示的是消息还是通知如果是Message则表明这个返回值是发布者发布的消息 如果是Notify则标明是系统通知

$ # 订阅者
$ wscat -c ws://localhost:5050/subscribe
$ > {"action":"Subscribe", "channel":"channel-1"}
$ # {"action":"Subscribe", "channel":"channel-1", "clientId":"this is a client id"}
$ < {"timestamp":...,"msgType":"Notify","msgBody":"..."}
$ # 取消订阅
$ > {"action":"Unsubscribe", "channel":"channel-1"}
$ < {"timestamp":...,"msgType":"Notify","msgBody":"..."}
  • 如果不指定clientId则会自动生成一个配置文件长度的随机字符串并返回
  • 订阅者发送最少参数为 {"action":"subscribe", "channel":"test"}你可以在此基础添加clientId
  • 如果你忘记了随机生成的clientId那么你可以在订阅者模式action设置为 clientid (不区分大小写)

发布

$ # 发布者
$ wscat -c ws://localhost:5050/publish
$ > {"action":"Publish", "channel":"channel-1", "payload":"this is a test message", "clientId":"this is a client id"}
$ < {"timestamp":...,"msgType":"Notify","msgBody":"Successfully sent to the client!"}
$ # 如果没有用户订阅你指定的 `channel` 和 `clientId`那么服务器将不会返回任何消息

然后就会在订阅者的消息列表中找到this is a test message

开发

使用 git clone https://github.com/RTAkland/kwsify.git 克隆到本地然后使用IDEA任意版本打开项目文件夹 然后就可以开发了, 写好你的代码中后提交PR吧~ 贡献代码请注意代码规范, 低质量、不遵循Kotlin代码规规范PR请求将会直接被关闭

构建

Linux

你需要先将gradlew授予可执行权限: chmod +x ./gradlew 使用 ./gradlew shadowJar 来进行构建, 产出物在build/libs/*-all.jar (文件名需要包含-all字样的jar文件才可以运行)

Windows

同上不过不需要提前将gradlew.bat 授予权限 打开cmd或者powershell使用 .\gradlew.bat shadowJar进行构建

开源

  • 本项目以Apache-2.0许可开源, 即:
    • 你可以直接使用该项目提供的功能, 无需任何授权
    • 你可以在注明来源版权信息的情况下对源代码进行任意分发和修改以及衍生

鸣谢