摘要:前言大家可以看看上一篇用構建一個簡單的聊天室在上一篇文章中我們已經實現了自我對話好友交流群聊離線消息等的功能。系統通知恭喜您連續登錄超過天,獎勵積分。
本文首發公眾號與個人博客:Java貓說 & 貓叔的博客 | MySelf,轉載請申明出處。前言
大家可以看看上一篇:用Java構建一個簡單的WebSocket聊天室
在上一篇文章中我們已經實現了:自我對話、好友交流、群聊、離線消息等的功能。
而本篇,我們的框架升級了,并且開通了幾個新的HTTP接口功能,同時也把原先框架的一些異常做了處理。
我們將使用更少的代碼完成功能更加完善的聊天項目!
采用框架我們整個Demo基本不需要大家花費太多時間,就可以實現以下的功能。
用戶token登錄校驗
自我聊天
點對點聊天
群聊
獲取在線用戶數與用戶標簽列表
發送系統通知
首先,我們需要介紹一下我們今天打算采用的框架,InChat : 一個輕量級、高效率的支持多端(應用與硬件Iot)的異步網絡應用通訊框架,采用這個框架,我們基本上只需要兩三個類就可以實現我們今天需要的功能了。
先看看效果 需要了解SSM & SpringBoot 嗎?InChat ,本身不依賴于任何的底層框架,所以大家只要會基本的Java語言就可以實現一套自己的WebSocket聊天室。
框架使用手冊(新版V1.1.2剛剛發布)關于詳細的手冊說明,大家可以看看官網的介紹:
V1.1.2版本使用說明
V1.1.2版本視頻教學
開始Demo搭建 構建一個空的Maven項目com.github.UncleCatMySelf InChat 1.1.2
我們不需要依賴其他的Maven包,只要本文提及的框架即可。
InChat啟動參數可以自配置com.github.UncleCatMySelf InChat 1.1.2
你只需要繼承InChat的默認配置類InitNetty即可,如下
public class MyInit extends InitNetty { /** 自定義啟動監聽端口 */ @Override public int getWebport() { return 8090; } }獲取聊天消息數據
此接口與原先一樣,僅修改了方法名
public class DataBaseServiceImpl implements InChatToDataBaseService { @Override public Boolean writeMessage(InChatMessage message) { System.out.println(message.toString()); return true; } }登錄校驗與群聊消息
此接口沒有做過多的修改
public class VerifyServiceImpl implements InChatVerifyService { @Override public boolean verifyToken(String token) { return true; } @Override public JSONArray getArrayByGroupId(String groupId) { JSONArray jsonArray = JSONArray.parseArray("["1111","2222","3333"]"); return jsonArray; } }服務端發送通知消息枚舉類
此接口具有Demo模板,用戶需要繼承InChat框架的FromServerService接口,同時該接口注釋也有實例demo,我們需要實現一個自定義的枚舉,你可以這樣寫:
public enum FromServerServiceImpl implements FromServerService { //你可以自定義自己的系統消息,請以Integer-String的形式 TYPE1(1,"【系統通知】您的賬號存在異常,請注意安全保密信息。"), TYPE2(2,"【系統通知】恭喜您連續登錄超過5天,獎勵5積分。"); private Integer code; private String message; FromServerServiceImpl(Integer code, String message){ this.code = code; this.message = message; } public Integer getCode() { return code; } //實現接口的方法,遍歷本枚舉的code,獲取對應的消息,作為系統消息發送 public String findByCode(Object code) { Integer codes = (Integer)code; for (FromServerServiceImpl item: FromServerServiceImpl.values()) { if (item.code == codes){ return item.message; } } return null; } public void setCode(Integer code) { this.code = code; } public String getMessage() { return message; } public void setMessage(String message) { this.message = message; } }啟動項目
1.1.2版本的啟動項目變得異常的簡單,你只需要配置啟動的配置工廠即可。
public class application { public static void main(String[] args) { //配置你的自定義配置 ConfigFactory.initNetty = new MyInit(); //配置校驗類 ConfigFactory.inChatVerifyService = new VerifyServiceImpl(); //配置消息接收處理類 ConfigFactory.inChatToDataBaseService = new DataBaseServiceImpl(); //配置服務端系統消息枚舉,這里的值無所謂 TYPE1或者TYPE2或者TYPEN均可以 ConfigFactory.fromServerService = FromServerServiceImpl.TYPE1; //啟動InChat InitServer.open(); } }項目效果
啟動成功
DEBUG - -Dio.netty.threadLocalDirectBufferSize: 0 DEBUG - -Dio.netty.maxThreadLocalCharBufferSize: 16384 INFO - 服務端啟動成功【192.168.56.1:8090】
當聊天連接未注冊情況下,客戶端自動斷開后,服務會自動包對應的異常
INFO - [Handler:channelInactive]/192.168.56.1:8090關閉成功 ERROR - [捕獲異常:NotFindLoginChannlException]-[Handler:channelInactive] 關閉未正常注冊鏈接!
原先的自我發送,點對點發送,群聊均與原來一樣新功能添加 HTTP原先的接口說明可以看上一版本: v1.1.0-alpha版本使用說明
新增HTTP接口三個,在你啟動Inchat的時候,默認啟動,對于你的其他web API并無任何影響,它是一個IM的輔助作用。本版本不支持用戶自定義相關的InChat HTTP接口
獲取在線用戶數
地址:[ip:端口]/get_size GET
返回值
{ "code": 200, "data": { "online": 1,//當前在線數 "time": "Jan 3, 2019 10:06:45 PM"http://查詢時間 } }
獲取在線用戶標識
地址:[ip:端口]/get_list GET
返回值
{ "code": 200, "data": { //返回在線用戶列表 "tokens": [ "1111" ] } }
根據用戶標簽,發送系統指定消息
地址:[ip:端口]/send_from_server POST
參數:token(你可以從get_list中得到在線用戶標簽)、value(你在系統中添加枚舉的code值,這里不接受字符串)
返回值
{ "code": 400, "data": { "message": "通知發送成功" } }
(有個小BUG,返回值code應該是200)
關于前端InChat : 一個輕量級、高效率的支持多端(應用與硬件Iot)的異步網絡應用通訊框架,大家可以直接來這個項目下獲取前端頁面,或者直接訪問這個地址:https://github.com/UncleCatMy...
對于這個前端頁面,我們需要更改一下IP地址。
運行調試項目接下來直接啟動后端項目,當我們看到以下的信息,則項目啟動成功。
INFO - 服務端啟動成功【192.168.1.121:8090】
這里的IP需要更換以下讀者啟動后的IP地址。
接著直接用瀏覽器打開chat.html的頁面即可,關于js的方法,大家可以看看InChatV1.1.0版本使用說明。
運行效果已經提前展示啦!
公眾號:Java貓說現架構設計(碼農)兼創業技術顧問,不羈平庸,熱愛開源,雜談程序人生與不定期干貨。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/72820.html
摘要:會話管理一直是企業級應用的重要部分。傳統會話管理技術的問題的目的是解決傳統的會話管理技術的各種問題。對如和之類的閉源產品,找到適合它們的會話管理技術的替代實現則通常是不可能的。典型的應用會將當前用戶的身份及其安全級別或角色存儲在會話里面。 歡迎大家前往騰訊云+社區,獲取更多騰訊海量技術實踐干貨哦~ 本文來自云+社區翻譯社,由Tnecesoc編譯。 會話管理一直是 Java 企業級應用的...
摘要:開公眾號差不多兩年了,有不少原創教程,當原創越來越多時,大家搜索起來就很不方便,因此做了一個索引幫助大家快速找到需要的文章系列處理登錄請求前后端分離一使用完美處理權限問題前后端分離二使用完美處理權限問題前后端分離三中密碼加鹽與中異常統一處理 開公眾號差不多兩年了,有不少原創教程,當原創越來越多時,大家搜索起來就很不方便,因此做了一個索引幫助大家快速找到需要的文章! Spring Boo...
摘要:官網地址聊天機器人插件開發實例教程一創建插件在系統技巧使你的更加專業前端掘金一個幫你提升技巧的收藏集。我會簡單基于的簡潔視頻播放器組件前端掘金使用和實現購物車場景前端掘金本文是上篇文章的序章,一直想有機會再次實踐下。 2道面試題:輸入URL按回車&HTTP2 - 掘金通過幾輪面試,我發現真正那種問答的技術面,寫一堆項目真不如去刷技術文章作用大,因此刷了一段時間的博客和掘金,整理下曾經被...
閱讀 917·2023-04-25 18:51
閱讀 1870·2021-09-09 11:39
閱讀 3283·2019-08-30 15:53
閱讀 2099·2019-08-30 13:03
閱讀 1310·2019-08-29 16:17
閱讀 582·2019-08-29 11:33
閱讀 1884·2019-08-26 14:00
閱讀 2124·2019-08-26 13:41