内容审核场景实践
场景 1:社交应用中的聊天内容审核
通过融云的审核服务,您可以防止社交场景中的色情诱导、广告引流以及涉政涉暴内容,详见审核能力概述。
内容审核服务
开通位置
您可以通过融云控制台开通内容审核服务。

计费说明
开发环境:免费试用 30 天; 生产环境:首次开通可免费体验 7 天,免费额度用尽后服务将关停。如需再次开启需预存 600 元并开始计费。
每日结算前一天统计用量费用,月底按整体使用量核算月度费用,费用按最小条数计算,不足一分钱不计费。
详细计费规则请参考知识库:IM 审核计费说明
常规审核方案
融云内容审核产品中的 IM 审核服务,为 IM 内容提供全面保障与支持,支持审核文本、图片、语音片段和小视频,精准识别敏感信息。 使用该服务无需额外代码集成,只需开通服务即可实现消息自动审核。如需调整审核力度或有其他审核需求,可联系商务经理沟通。
自定义事件审核方案
在您的实际业务中,根据用户的级别、性别、地域等背景信息,可以执行不同的审核策略。
实现步骤
- 审核方根据客户的业务需求,分配不同的审核事件 ID(eventId)。例如:根据性别进行审核时,数美需要分别提供男性和女性的审核事件 ID(eventId)。在实际操作前,可联系商务经理创建审核群进行对接。
- 开通内容审核支持自定义事件审核功能。此功能暂不支持自助开通,请提交工单申请。
- 在通过融云 SDK 发送消息时,根据发送消息用户的不同,携带相应的事件 ID。融云服务端在送审时会将事件 ID 同步给数美,数美会根据传入的事件 ID 执行相应的审核策略。
计费说明
免费
客户端集成代码示例
- Android
- iOS
- Web
从 5.6.8 版本开始支持,发送消息时,设置消息对象中的 auditInfo
内容,如下:
MessageAuditInfo messageAuditInfo =
new MessageAuditInfo(
MessageAuditType.ALLOW,
"",
"strategy");
textMessage.setAuditInfo(messageAuditInfo);
Message message = Message.obtain("targetId", Conversation.ConversationType.PRIVATE, textMessage);
属性说明:
- auditType:审核类型,需要设置为审核
MessageAuditType.ALLOW
。 - strategy:对应为数美审核的事件 ID(
eventId
)。
注:使用默认审核逻辑时可不设置 auditInfo
从 5.6.8 版本开始支持,发送消息时,设置消息对象中的 auditInfo
内容,如下:
RCMessageAuditInfo *auditInfo = [[RCMessageAuditInfo alloc] init];
auditInfo.auditType = enableAudit ? RCMessageAuditTypeAllow : RCMessageAuditTypeDisallow;
auditInfo.project = auditProject;
auditInfo.strategy = auditStrategy;
messageContent.auditInfo = auditInfo;
auditType 类型说明:
typedef NS_ENUM(NSInteger, RCMessageAuditType) {
/// 不需要审核
RCMessageAuditTypeDisallow = 0,
/// 需要审核
RCMessageAuditTypeAllow = 1,
};
属性说明:
- auditType:审核类型,需设置为审核。
- strategy:对应数美审核的事件 ID(
eventId
)。 - project:无需设置。
注:使用默认审核逻辑时可不设置 auditInfo
。
从 5.9.3 版本开始支持,发送消息时,设置消息对象中的 auditInfo
内容,如下:
new RongIMLib.TextMessage({
content: '',
audit?: {
/**
* 发送方指定是否送审, 1:送审(默认值),0:不送审
*/
auditType?: MessageAuditType,
/**
* 项目名称, 默认为空字符串
*/
project?: string,
/**
* 策略映射字段
*/
strategy?: string,
}
})
属性说明:
- auditType:审核类型,需要设置为审核。
- strategy:对应为数美审核的事件 ID(
eventId
)。
如果使用默认审核逻辑,则无需设置 auditInfo
。
Server API 接口
通过 Server API 发送消息时,可以在消息体中添加 audit
属性内容来实现:
{
"content":"Hello world! 单聊消息 ",
.....
"audit":
{
"auditType" : 1,
"strategy" : "message_restrict", // 例子,实际与数美的事件值一致。
},
"extra":""
}
属性说明:
- auditType:审核类型,需要设置为 1(表示需要审核)。
- strategy:对应数美审核的事件 ID(
eventId
)。
如果使用默认审核逻辑,则无需设置 audit
。
自定义消息审核方案
融云支持自定义消息的审核功能,但目前暂不支持自助配置。您可以通过提交工单申请开通。在提交工单时,请提供以下信息:
- 应用的 App Key。
- 会话类型:需要审核的自定义消息所属的会话类型(如单聊、群聊、聊天室、超级群)。
- 自定义消息的消息类型(
ObjectName
),例如:融云内置消息类型RC:TxtMsg
。 - 自定义消息中 Content 的 JSON 结构内容。目前仅支持 JSON 结构。以下是文本消息的示例结构:
{
"content":"Hello world!",
"user":
{
"id":"4242",
"name":"Robin",
"portrait":"http://example.com/p1.png",
"extra":"extra"
},
"extra":""
}
- 需要审核的 JSON 结构中的属性名称,例如客户的自定义消息结构如下,需要审核
msg
的内容:
{
"msg":"需要审核的内容",
"user":
{
"id":"4242",
"name":"Robin",
"portrait":"http://example.com/p1.png"
}
}
计费说明
免费
获取 IM 审核结果
- 开通 IM 审核服务后,您可以在风控后台查询,具体操作请参考:风控后台常见功能操作文档。
- 通过审核结果回调,您可以实时接收审核结果详情,详见审核结果回调。
开通位置
登录融云控制台, 在 IM 与音视频审核页面中配置回调地址。请确保您提供的回调地址能够在公网正常访问。
计费说明
免费
服务端回调请求示例
POST review_result.php HTTP/1.1
Host: example.com
RC-App-Key: uwd1c0sxdlx2
RC-Timestamp: 1408710653491
RC-Nonce: 14314
RC-Signature: 45beb7cc7307889a8e711219a47b7cf6a5b000e8
Content-Type: application/json
{
"result":10000,
"content":“{****}”,//审核的消息结构 JSON
"serviceProvider":"ShuMei",
"msgUID":"596E-P5PG-4FS2-7OJK",
"resultDetail":"{****}";//审核结果详细 JSON 结构
}
- 只要返回 HTTP 200 OK 响应,服务端会认为状态已同步,无需返回任何参数。
- 如果响应超时超过 5 秒,服务端会重试推送 3 次;若仍然失败,即时通讯服务将默认下发该消息。
- 如果短时间内出现大面积超时,服务端会暂时停止请求您的服务器,并在 90 秒后重新尝试发送回调请求。
消息回调服务
消息回调服务会根据您在控制台配置的路由规则拦截发送中的消息。被拦截的消息副本会先行发送至您指定的应用服务器(App 后端), 然后即时通讯服务端会根据 App 后端返回的响应结果,决定是否将消息下发、是否替换消息中的内容,以及如何进行内容替换。 详见消息回调 。
开通位置
登陆 融云控制台,参考截图位置开通审核服务并配置路由规则:
计费说明
开发环境免费使用;生产环境功能使用费 1000 元/月。
服务端回调请求和回调响应示例
POST /receive_message.php?timestamp=1408710653491&nonce=14314&signature=45beb7cc7307889a8e711219a47b7cf6a5b000e8 HTTP/1.1
Host: example.com
Content-Type: application/x-www-form-urlencoded
appKey=123&content={"content":"123"}&fromUserId=fid123&targetId=tid123&msgType=RC:TxtMsg&messageId=596E-P5PG-4FS2-7OJK&msgTimeStamp=1408710653491&channelType=ULTRAGROUP&os=Server&busChannel=basketball
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
{ "pass": 1 }
替换消息提示
替换消息内容对发送端、接收端的本地与服务端的历史消息记录有不同的影响。请谨慎使用此功能。
- 单聊和群聊消息替换后,发送方的本地和服务端历史消息中存储的是替换前的内容,而接收方本地和服务端存储的是经过替换后的内容。
- 聊天室消息替换后,发送方本地是替换前的内容,接收方本地是经过替换后的内容;服务端存储的是替换后的内容。(退出聊天室重新进入后拉取消息时为替换后的内容)。
- 超级群消息替换后,发送方本地是替换前的内容,接收方本地是经过替换后的内容;服务端存储的是替换后的内容。(换端登录后拉取历史消息时为替换后的内容)。
常见问题
- 消息回调默认不会对 Server API 接口发送的消息生效。如需将 IM Server API 发送的消息按照您配置的路由规则过滤并发送到应用服务器,需要在控制台的免费基础功能页面开启 Server API 发送消息过滤敏感词功能。
- 如字段中数据大小超出限制、数据格式错误会导致消息下发失败。
- 如果应答超时 5 秒,服务端会再尝试推送 3 次,如果仍然失败,即时通讯服务默认将下发此条消息。如需希望不下发,请提交工单申请开通异常模板消息不下发功能。
- 如短时间内有大面积超时,将暂时停止请求您的服务器,90 秒后会继续发送回调请求。
- 非违规类消息为什么被拦截了?消息回调的审核结果完全由您服务端把控,可先排除下 2 和 3 的情况,然后看下是否是服务端返回了 pass:0。
融云内置敏感词服务
即时通讯(IM)服务已内置敏感词机制。注意,敏感词机制仅是一种基础保护机制,且仅限于文本内容。具体请参考文档说明:敏感词机制。
开通位置
登陆 融云控制台,参考截图位置配置过滤词或替换词。如需增加词量可设置敏感词上限数调整。
计费说明
默认支持 50 个免费词;增加词量计费标准为1000 词 / 600 元。
服务端添加敏感词请求示例
- Server SDK in Java
- Server SDK in PHP
- Server SDK in GO
RongCloud rongCloud = RongCloud.getInstance("AppKey", "AppSecret");
//自定义 Api 地址方式
//RongCloud rongCloud = RongCloud.getInstance(appKey, appSecret,api);
SensitiveWord sensitiveWord = rongCloud.sensitiveword;
SensitiveWordModel sentiveWord = new SensitiveWordModel()
.setType(0)
.setKeyword("黄赌毒")
.setReplace("***");
ResponseResult addesult = sensitiveWord.add(sentiveWord);
System.out.println("sentiveWord add: " + addesult.toString());
require "./../../RongCloud.php";
define("APPKEY", '');
define('APPSECRET', '');
use RongCloud\RongCloud;
use RongCloud\Lib\Utils;
/**
* Add sensitive words
*/
function add()
{
$RongSDK = new RongCloud(APPKEY, APPSECRET);
$sensitive = [
'replace' => '***',// Sensitive word replacement, maximum length not exceeding 32 characters, sensitive word filtering can be empty
'keyword' => "abc",// Sensitive word
'type' => 0// 0: Sensitive word substitution 1: Sensitive word filtering
];
$result = $RongSDK->getSensitive()->add($sensitive);
Utils::dump("Add sensitive words", $result);
}
func TestRongCloud_SensitiveBatchAdd(t *testing.T) {
rc := NewRongCloud(
os.Getenv("APP_KEY"),
os.Getenv("APP_SECRET"),
)
ret, err := rc.SensitiveBatchAdd(
[]SensitiveWord{
{
Type: "0",
Word: "replaceStr1",
ReplaceWord: "replace1",
},
{
Type: "1",
Word: "blockStr1",
ReplaceWord: "",
},
})
t.Log(err)
t.Log(ret)
}