百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

重磅推荐github突破7.2k star OpenIM消息推送api支持应用与IM融合

yuyutoo 2024-12-16 17:22 3 浏览 0 评论

OpenIM消息推送api打通了应用和IM系统之间的通知桥梁,让应用消息可以及时触达到目标用户。以办公场景为例,比如员工入职通知,放假通知等业务通知,由oa系统处理具体的业务逻辑,再调用消息推送api,触达到目标用户。

效果示例

以协同办公为例,员工收到系统推送的工作通知,有新任务需要处理。

员工点击工作通知,可以查看具体详情,每条通知有不同的发送者昵称和头像。这种通知类型是一种新的会话类型,全部聚合在同一个会话。

OpenIM简介

OpenIM:从服务端到客户端SDK开源即时通讯整体解决方案。开发者可以轻松替代第三方IM云服务,打造具备聊天、社交功能的app,也可以在自身应用中集成SDK,以提供即时通讯能力。开源IM的价值在于“一切皆可控”“我的信息我做主”,无论是技术,还是信息安全。

整体超过7.2K star,OpenIM作为开源IM的领跑者,持续添加新功能,包括消息推送api,群聊已读。服务端和sdk都是Apache-2.0 License授权协议,可以免费使用。带有UI的产品需要商业授权,有兴趣的客户可以联系我们深度交流。

5X8小时vip专属服务,包括:


(1)一对一技术咨询,微信 电话等各种方式;


(2)sdk使用辅导咨询;


(3)服务端架构及部署答疑;


(4)IM新需求优先排期;


(5)bug优先修复;


(6)系统维护和故障响应;


web端体验: https://open-im-online.rentsoft.cn/

安卓端体验: https://www.pgyer.com/OpenIM

iOS端体验:https://testflight.apple.com/join/o956rTGx

单机性能及容量总结

服务器资源:8核16G内存, 6个机械磁盘,每个磁盘100G, mongo 分片,10MB带宽。

容量:用户同时在线10万以上,消息条数10亿。

性能评估:同时在线用户10万,每秒钟发送消息900条,(从发送者发出消息到接收到消息)消息延时1秒

可靠性总结

每条消息都能被对方精确收到,并成功落地app本地db。对于失败的3条消息,接收方确实没有收到,确保系统消息一致性。

系统具备优秀的平行扩展能力,除存储模块外,其他模块都无状态,支持亿级用户,千亿消息量。

github地址: https://github.com/OpenIMSDK/Open-IM-Server

开发者中心:https://doc.rentsoft.cn/#/

简要描述

  • 管理员通过后台接口发送通知类型消息

请求URL

  • http://x.x.x.x:10000/manager/send_msg

请求方式

  • POST

请求示例

   {
    "operationID": "Oa notification operationID111", 
    "sendID": "openIM123456", 
    "recvID": "18712345678", 
    "senderPlatformID": 2, 
    "senderFaceURL": "http://www.head.com", 
    "senderNickname": "系统通知2", 
    "content": {
        "notificationName": "公文管理", 
        "notificationFaceURL": "http://www.head1.com", 
        "notificationType": 1, 
        "text": "大家好,今天是...", 
        "externalUrl":"",
        "mixType": 0, 
        "pictureElem": {
            "sourcePath": "", 
            "sourcePicture": {
                "uuid": "", 
                "type": "", 
                "size": 0, 
                "width": 0, 
                "height": 0, 
                "url": ""
            }, 
            "bigPicture": {
                "uuid": "", 
                "type": "", 
                "size": 0, 
                "width": 0, 
                "height": 0, 
                "url": ""
            }, 
            "snapshotPicture": {
                "uuid": "", 
                "type": "", 
                "size": 0, 
                "width": 0, 
                "height": 0, 
                "url": ""
            }
        }, 
        "soundElem": {
            "uuid": "", 
            "soundPath": "", 
            "sourceUrl": "", 
            "dataSize": 0, 
            "duration": 0
        }, 
        "videoElem": {
            "videoPath": "", 
            "videoUUID": "", 
            "videoUrl": "", 
            "videoType": "", 
            "videoSize": 0, 
            "duration": 0, 
            "snapshotPath": "", 
            "snapshotUUID": "", 
            "snapshotSize": 0, 
            "snapshotUrl": "", 
            "snapshotWidth": 0, 
            "snapshotHeight": 0
        }, 
        "fileElem": {
            "filePath": "", 
            "uuid": "", 
            "sourceUrl": "", 
            "fileName": "", 
            "fileSize": 0
        }, 
        "ex": ""
    }, 
    "contentType": 1400, 
    "sessionType": 4, 
    "isOnlineOnly": false, 
    "offlinePushInfo": {
        "title": "admin revoke your message", 
        "desc": "", 
        "ex": "", 
        "iOSPushSound": "default", 
        "iOSBadgeCount": false
    }
}Copy to clipboardErrorCopied

请求参数

参数名

类型

必选

说明

operationID

string

操作ID,保持唯一,建议用当前时间微秒+随机数,用于后台链路追踪问题使用

sendID

string

管理员ID,为后台config文件中配置的管理员ID中一个,默认openIM123456

recvID

string

接收者userID

senderPlatformID

int

发送者平台号,模拟用户发送时填写, 1->IOS,2->Android,3->Windows,4->OSX,5->Web,5->MiniWeb,7->Linux

senderFaceURL

string

发送者头像,用于客户端通知会话产生

senderNickname

string

发送者昵称,用于客户端通知会话产生

content

object

消息的具体内容,内部是json 对象

notificationName

string

通知标题

notificationFaceURL

string

通知头像

notificationType

int

通知类型,如:1代表入职通知,2代表离职通知

text

string

通知正文e

externalUrl

string

通知点击后需要跳转到的地址链接(不填则无需跳转)

mixType

int

通知混合类型 0:纯文字通知 1:文字+图片通知 2:文字+视频通知 3:文字+文件通知

pictureElem

object

图片元素对象

sourcePicture

object

原图

bigPicture

object

大图

snapshotPicture

object

缩略图

soundElem

object

声音元素对象

videoElem

object

视频元素对象

fileElem

object

文件元素对象

uuid

string

对象唯一ID用于缓存使用

type/videoType/

string

图片类型/视频类型

size/dataSize/videoSize/snapshotSize/fileSize

int

多媒体文件大小,单位字节

width/snapshotWidth

int

图片/视频缩略图宽度

height/snapshotHeight

int

图片/视频缩略图高度

url/sourceUrl/videoUrl

string

图片/文件/视频的URL

sourcePath/soundPath/videoPath/filePath

string

文件路径,可不填写

fileName

string

文件名字

ex

string

扩展字段

contentType

int

消息类型固定为1400

sessionType

int

通知会话类型固定为4

isOnlineOnly

bool

改字段设置为true时候,发送的消息服务器不会存储,接收者在线才会收到,不在线该消息丢失。

offlinePushInfo

object

离线推送的具体内容,如果不填写,使用服务器默认推送标题

title

string

推送的标题

desc

string

推送的具体描述

ex

string

扩展字段

iOSPushSound

string

IOS的推送声音

iOSBadgeCount

bool

IOS推送消息是否计入桌面图标未读数

返回示例

{
  "errCode": 0, 
  "errMsg": "", 
  "data": {
      "serverMsgID": "", 
      "clientMsgID": "", 
      "sendTime": 1645697804432
  }
}Copy to clipboardErrorCopied

返回参数

参数名

类型

说明

errCode

int

0成功,非0失败

errMsg

string

错误信息

sendTime

int

消息发送的具体时间,具体为毫秒的时间戳

serverMsgID

string

服务器生成的消息的唯一ID

clientMsgID

string

客户端生成的消息唯一ID,默认情况使用这个为主键

消息类型格式描述

简要描述

  • 管理员消息发送字段中contentType支持的消息类型说明以及消息content的具体字段说明。

ContentType消息类型说明

ContentType值

类型说明

101

文本消息

102

图片消息

103

音频消息

104

视频消息

105

文件消息

106

群聊中的@类型消息

107

合并转发类型消息

108

名片消息

109

地理位置类型消息

110

自定义消息

111

撤回类型消息

112

已读回执类型消息

114

引用类型消息

Content具体内容

  • content内部为具体的json对象,不同的消息类型是不同的json对象

文本消息

{
  ...,
  "content": {
      "text": "nihao"
  },
  ....
}Copy to clipboardErrorCopied

参数名

必选

类型

说明

text

string

文本消息的具体内容

自定义消息

{
  ...,
  "content": {
      "data": "", 
      "description": "", 
      "extension": ""
  },
  ....
}Copy to clipboardErrorCopied

参数名

类型

必选

说明

data

json string

用户自定义的消息为json对象转换后的string

description

json string

扩展的描述信息为json对象转换后的string,可以不使用

extension

json string

扩展字段,暂时不使用

相关推荐

Mysql和Oracle实现序列自增(oracle创建序列的sql)

Mysql和Oracle实现序列自增/*ORACLE设置自增序列oracle本身不支持如mysql的AUTO_INCREMENT自增方式,我们可以用序列加触发器的形式实现,假如有一个表T_WORKM...

关于Oracle数据库12c 新特性总结(oracle数据库19c与12c)

概述今天主要简单介绍一下Oracle12c的一些新特性,仅供参考。参考:http://docs.oracle.com/database/121/NEWFT/chapter12102.htm#NEWFT...

MySQL CREATE TABLE 简单设计模板交流

推荐用MySQL8.0(2018/4/19发布,开发者说同比5.7快2倍)或同类型以上版本....

mysql学习9:创建数据库(mysql5.5创建数据库)

前言:我也是在学习过程中,不对的地方请谅解showdatabases;#查看数据库表createdatabasename...

MySQL面试题-CREATE TABLE AS 与CREATE TABLE LIKE的区别

执行"CREATETABLE新表ASSELECT*FROM原表;"后,新表与原表的字段一致,但主键、索引不会复制到新表,会把原表的表记录复制到新表。...

Nike Dunk High Volt 和 Bright Spruce 预计将于 12 月推出

在街上看到的PandaDunk的超载可能让一些球鞋迷们望而却步,但Dunk的浪潮仍然强劲,看不到尽头。我们看到的很多版本都是为女性和儿童制作的,这种新配色为后者引入了一种令人耳目一新的新选择,而...

美国多功能舰载雷达及美国海军舰载多功能雷达系统技术介绍

多功能雷达AN/SPY-1的特性和技术能力,该雷达已经在美国海军服役了30多年,其修改-AN/SPY-1A、AN/SPY-1B(V)、AN/SPY-1D、AN/SPY-1D(V),以及雷神...

汽车音响怎么玩,安装技术知识(汽车音响怎么玩,安装技术知识视频)

全面分析汽车音响使用或安装技术常识一:主机是大多数人最熟习的音响器材,有关主机的各种性能及规格,也是耳熟能详的事,以下是一些在使用或安装时,比较需要注意的事项:LOUDNESS:几年前的主机,此按...

【推荐】ProAc Response系列扬声器逐个看

有考牌(公认好声音)扬声器之称ProAcTablette小音箱,相信不少音响发烧友都曾经,或者现在依然持有,正当大家逐渐掌握Tablette的摆位设定与器材配搭之后,下一步就会考虑升级至表现更全...

#本站首晒# 漂洋过海来看你 — BLACK&DECKER 百得 BDH2000L无绳吸尘器 开箱

作者:初吻给了烟sco混迹张大妈时日不短了,手没少剁。家里有了汪星人,吸尘器使用频率相当高,偶尔零星打扫用卧式的实在麻烦(汪星人:你这分明是找借口,我掉毛是满屋子都有,铲屎君都是用卧式满屋子吸的,你...

专题|一个品牌一件产品(英国篇)之Quested(罗杰之声)

Quested(罗杰之声)代表产品:Q212FS品牌介绍Quested(罗杰之声)是录音监听领域的传奇品牌,由英国录音师RogerQuested于1985年创立。在成立Quested之前,Roger...

常用半导体中英对照表(建议收藏)(半导体英文术语)

作为一个源自国外的技术,半导体产业涉及许多英文术语。加之从业者很多都有海外经历或习惯于用英文表达相关技术和工艺节点,这就导致许多英文术语翻译成中文后,仍有不少人照应不上或不知如何翻译。为此,我们整理了...

Fyne Audio F502SP 2.5音路低音反射式落地音箱评测

FyneAudio的F500系列,有新成员了!不过,新成员不是新的款式,却是根据原有款式提出特别版。特别版产品在原有型号后标注了SP字样,意思是SpecialProduction。Fyne一共推出...

有哪些免费的内存数据库(In-Memory Database)

以下是一些常见的免费的内存数据库:1.Redis:Redis是一个开源的内存数据库,它支持多种数据结构,如字符串、哈希表、列表、集合和有序集合。Redis提供了快速的读写操作,并且支持持久化数据到磁...

RazorSQL Mac版(SQL数据库查询工具)

RazorSQLMac特别版是一款看似简单实则功能非常出色的SQL数据库查询、编辑、浏览和管理工具。RazorSQLformac特别版可以帮你管理多个数据库,支持主流的30多种数据库,包括Ca...

取消回复欢迎 发表评论: