J-IM 正在参加 2020 年度 OSC 中国开源项目评选,请投票支持!
J-IM 在 2020 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
投票让它出道
已投票
授权协议: Apache
开发语言: Java 查看源码 »
操作系统: 跨平台
收录时间: 2018-05-07
提 交 者: 轨迹_

J-IM 是用JAVA语言,基于t-io开发的轻量、高性能、单机支持几十万至百万在线用户IM,主要目标降低即时通讯门槛,快速打造低成本接入在线IM系统,通过极简洁的消息格式就可以实现多端不同协议间的消息发送如内置(http、websocket、tcp自定义im协议)等,并提供通过http协议的api接口进行消息发送无需关心接收端属于什么协议,一个消息格式搞定一切!

官网地址

http://www.j-im.cn

主要特点

    1、高性能(单机可支持几十万至百万人同时在线)
    2、轻量、可扩展性极强
    3、支持集群多机部署
    4、支持SSL/TLS加密传输
    5、消息格式极其简洁(JSON)
    6、一端口支持多种协议(Socket自定义IM协议、Websocket、Http),可分别独立部署
    7、内置消息持久化(离线、历史、漫游),保证消息可靠性,高性能存储
    8、各种丰富的API接口
    9、零成本部署,一键启动

消息格式

1.聊天请求消息结构

{
   "from": "来源ID",
   "to": "目标ID",
   "cmd":"命令码(11)int类型",
   "createTime": "消息创建时间long类型",
   "msgType": "消息类型int类型(0:text、1:image、2:voice、3:vedio、4:music、5:news)",
   "chatType":"聊天类型int类型(0:未知,1:公聊,2:私聊)",
   "groupId":"群组id仅在chatType为(1)时需要,String类型",
   "content": "内容"
}
请求:COMMAND_CHAT_REQ(11) 响应:COMMAND_CHAT_RESP(12)

2.鉴权请求消息结构

{
    "cmd":"命令码(3)int类型",
    "token": "校验码"
}
请求:COMMAND_AUTH_REQ(3) 响应:COMMAND_AUTH_RESP(4)

3.握手请求消息结构

{
    "cmd":"命令码(1)int类型",
    "hbyte":"握手1个字节"
}
说明:请求:COMMAND_HANDSHAKE_REQ(1) 响应:COMMAND_HANDSHAKE_RESP(2)

4.登录请求消息结构

{
    "cmd":"命令码(5)int类型",
    "userId": "用户账号",
    "password": "密码",
    "token": "校验码(此字段可与userId、password共存,也可只选一种方式)"
}
请求:COMMAND_LOGIN_REQ(5) 响应:COMMAND_LOGIN_RESP(6)

5.心跳请求消息结构

{
    "cmd":"命令码(13)int类型",
    "hbbyte":"心跳1个字节"
}
请求:COMMAND_HEARTBEAT_REQ(13) 响应:COMMAND_HEARTBEAT_REQ(13)

6.关闭、退出请求消息结构

{
    "cmd":"命令码(14)int类型",
    "userId":"用户Id"
}
请求:COMMAND_CLOSE_REQ(14) 响应:无

7.获取用户信息请求消息结构

{
     "cmd":"命令码(17)int类型",
     "userId":"用户id(必填项)",
     "type":"获取类型(0:所有在线用户,1:所有离线线用户,2:所有用户[在线+离线])"
}
请求:COMMAND_GET_USER_REQ(17) 响应:COMMAND_GET_USER_RESP(18)

8.获取用户消息请求结构

{
     "cmd":"命令码(19)int类型",
     "fromUserId":"消息发送用户id(此字段必须与userId一起使用,获取双方聊天消息),非必填",
     "userId":"当前用户id(必填字段),当只有此字段时,type必须为0,意思是获取当前用户所有离线消息(好友+群组)",
     "groupId":"群组id(此字段必须与userId一起使用,获取当前用户指定群组聊天消息),非必填",
     "beginTime":"消息区间开始时间Date毫秒数double类型,非必填",
     "endTime":"消息区间结束时间Date毫秒数double类型,非必填",
     "offset":"分页偏移量int类型,类似Limit 0,10 中的0,非必填",
     "count":"显示消息数量,类似Limit 0,10 中的10,非必填",
     "type":"消息类型(0:离线消息,1:历史消息)"
}
请求:COMMAND_GET_MESSAGE_REQ(19) 响应:COMMAND_GET_MESSAGE_RESP(20)

使用

- 服务端(快速开发自己的高性能IM服务器):引入jim-server,在你的pom.xml中加入如下代码片段:

<dependency>
    <groupId>org.j-im</groupId>
    <artifactId>jim-server</artifactId>
    <version>3.0.0.v20200501-RELEASE</version>
</dependency>


- 客户端(快速开发自己的IM客户端):引入jim-client,在你的pom.xml中加入如下代码片段:

<dependency>
    <groupId>org.j-im</groupId>
    <artifactId>jim-client</artifactId>
    <version>3.0.0.v20200501-RELEASE</version>
</dependency>

新版官网界面截图

Http协议api调用地址:http://localhost:8888/api/message/send

近期发布

支持Https、Wss (已完成)
支持J-PUSH消息推送
支持图片、语音、视频发送等
官网开发

 

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

J-IM 的相关博客

IM

防骗提醒 应用皆由第三方提供,与本平台无关。 点击查看「APP防骗指南」 我已了解 不再提醒

DE-9IM

Dimensionally Extended nine-Intersection Model

IM总结

发送消息UDP打洞,登录的时候HTTP。 登录成功后,会有一个TCP连接来保持在线状态。这个TCP连接的远程端口一般是80,采用UDP方式...

IM之Socket

IM之Socket 说到即时通讯,就会让人想到socket,然而现在三方的即时通讯SDK也是数不胜数。本文就简单说一下github上非常火热的...

IM开发快速入门(一):什么是IM系统?

本文在编写时参考了博客作者“鹿呦呦”和在线课程“即时消息技术剖析与实战”的相关资料,一并表示感谢。 1、系列文章引言 IM...

J-IM 的相关问答

1
回答

评论 (35)

加载中
你们有遇到经常莫名其妙被踢下线的问题吗?
10/19 17:30
回复
举报
官网打不开啊
07/23 09:37
回复
举报
轨迹_软件作者
J-IM 3.0.0.v20200501-RELEASE强势来袭@J-IM
05/05 12:53
回复
举报
现在支持视频功能吗?
2019/09/05 09:35
回复
举报
不是说t-io要收费吗,使用这个有影响吗?
2019/03/05 16:02
回复
举报

引用来自“轨迹_”的评论

J-IM v2.1.0 新特性增加SSL/TLS安全加密传输支持 #J-IM#
怎么发送语音和图片?
2018/12/26 17:17
回复
举报
吓得我赶紧发表一下评论
2018/11/17 14:20
回复
举报
打分: 力荐
牛得一塌糊涂!
2018/11/14 16:51
回复
举报
导入报错,报错,报错
2018/11/13 10:06
回复
举报
厉害了,很好很强大,感谢大神共享~, 对于一楼大哥呀,你用人家代码,就别嫌弃了,得了好,还说人家不是。
2018/07/13 09:02
回复
举报
更多评论
35 评论
319 收藏
分享
返回顶部
顶部