用阿里云内容安全处理OSS的违禁图片

简介: 原文档,https://help.aliyun.com/document_detail/2400149.html 基于官方的文档做的一些拓展
  1. 1、登录函数计算控制台,选择服务地域,创建服务和函数。具体操作,请参见管理服务管理函数。创建函数时,选择使用内置运行时创建的方式,核心字段配置如下:
  • 基本设置区域,选择请求处理程序类型处理事件请求
  • 函数代码区域,根据实际业务选择运行环境,设置代码上传方式使用示例代码方式,并选择对象存储OSS触发函数
  • 触发器配置区域,选择触发器类型对象存储OSS,指定Bucket名称osstest-20文件前缀img文件后缀png触发事件选择oss:ObjectCreated:PutObjectoss:ObjectCreated:PostObject事件,角色名称AliyunOSSEventNotificationRole
    首次创建函数时,您可以根据页面提示授予事件源访问函数计算权限。更多内容,请参见授予事件源访问函数计算的权限
    关于OSS触发器事件的详细信息,请参见OSS触发器概述

2、通过函数调用内容安全图片审核增强版服务。


官方提供了一种通过函数计算来触发内容安全增量扫描的方案,但是该方案没有处理文件的示例,业务方的需求是把检测到的违规文件直接禁止公共读,需要置为PRIVATE权限,加完处理后的示例代码如下:

# -*- coding: utf-8 -*-importjson, uuidimportconfigparserfromaliyunsdkcore.clientimportAcsClientfromaliyunsdkcore.requestimportCommonRequestimportoss2# 需要自行根据检测内容确定好bucket路径及object名称defoss_acl_private(bucket_name, object_name):
auth=oss2.Auth("accessKeyId", "accessSecret")
bucket=oss2.Bucket(auth, 'https://oss-cn-shanghai.aliyuncs.com', bucket_name)
# yourObjectName填写Object完整路径,完整路径中不能包含Bucket名称。bucket.put_object_acl(object_name, oss2.OBJECT_ACL_PRIVATE)
defhandler(event, context):
config=configparser.ConfigParser()
config.read("config.ini", encoding="GB18030")
# AccessKey ID和AccessKey Secret写入的配置文件。evt=json.loads(event)
evt=evt['events'][0]
bucket_name=evt['oss']['bucket']['name']
object_name=evt['oss']['object']['key']
ossRegionId=evt['region']
client=AcsClient(config.get("config", "accessKeyId"), config.get("config", "accessSecret"), 'cn-shanghai')
request=CommonRequest()
request.set_read_timeout(6000)  # 读超时时间配置request.set_connect_timeout(3000)  # 连接超时时间配置request.set_accept_format('json')
request.set_method('POST')
request.set_protocol_type('https')  # https | httprequest.set_domain('green-cip.cn-shanghai.aliyuncs.com')
request.set_version('2022-03-02')
request.set_action_name('ImageModeration')
request.add_query_param("Service", "baselineCheck")
request.add_query_param("ServiceParameters",
                            {
# 'imageUrl': 'https://www.aliyun.com/1.jpg','dataId': str(uuid.uuid4()),
'ossObjectName': object_name,
'ossRegionId': ossRegionId,
'ossBucketName': bucket_name,
                            })
response=client.do_action_with_exception(request)
# print(str(response, encoding='utf-8'))response_json=json.loads(response)
ifresponse_json.get("Code") ==200:
foriteminresponse_json.get("Data", {}).get("Result", []):
print('item', item)
ifitem["Label"] =="nonLabel":
print("nonLabel 无命中标签")
elif"pornographic"initem["Label"] andint(item["Confidence"]) >80:
print("疑似含有色情内容")
# oss_acl_private(bucket_name, object_name)elif"political"initem["Label"] andint(item["Confidence"]) >80:
print("疑似含有涉政内容")
# oss_acl_private(bucket_name, object_name)elif"violent"initem["Label"] andint(item["Confidence"]) >80:
print("疑似含有暴恐内容")
# oss_acl_private(bucket_name, object_name)elif"fraud"initem["Label"] andint(item["Confidence"]) >80:
print("疑似含有风险内容")
else:
print("请求失败,错误码:", response_json.get("Code"))


相关实践学习
对象存储OSS快速上手——如何使用ossbrowser
本实验是对象存储OSS入门级实验。通过本实验,用户可学会如何用对象OSS的插件,进行简单的数据存、查、删等操作。
相关文章
|
4月前
|
云安全 人工智能 安全
Dify平台集成阿里云AI安全护栏,构建AI Runtime安全防线
阿里云 AI 安全护栏加入Dify平台,打造可信赖的 AI
3050 166
|
4月前
|
云安全 人工智能 自然语言处理
阿里云x硅基流动:AI安全护栏助力构建可信模型生态
阿里云AI安全护栏:大模型的“智能过滤系统”。
2034 120
|
4月前
|
存储 人工智能 Cloud Native
阿里云渠道商:OSS与传统存储系统的差异在哪里?
本文对比传统存储与云原生对象存储OSS的架构差异,涵盖性能、成本、扩展性等方面。OSS凭借高持久性、弹性扩容及与云服务深度集成,成为大数据与AI时代的优选方案。
|
6月前
|
云安全 机器学习/深度学习 人工智能
阿里云安全Black Hat技术开源大揭秘,AI安全检测的工程化实践
阿里云安全 LLMDYara框架开源核心思路,赋能云安全产品!
2076 15
|
6月前
|
存储 运维 安全
阿里云国际站OSS与自建存储的区别
阿里云国际站对象存储OSS提供海量、安全、低成本的云存储解决方案。相比自建存储,OSS具备易用性强、稳定性高、安全性好、成本更低等优势,支持无限扩展、自动冗余、多层防护及丰富增值服务,助力企业高效管理数据。
|
6月前
|
存储 域名解析 前端开发
震惊!不买服务器,还可以用阿里云国际站 OSS 轻松搭建静态网站
在数字化时代,利用阿里云国际站OSS可低成本搭建静态网站。本文详解OSS优势及步骤:创建Bucket、上传文件、配置首页与404页面、绑定域名等,助你快速上线个人或小型业务网站,操作简单,成本低廉,适合初学者与中小企业。
|
5月前
|
云安全 人工智能 自然语言处理
|
5月前
|
人工智能 安全

相关产品

  • 对象存储