认证鉴权
调用接口有如下两种认证方式,您可以选择其中一种进行认证鉴权。
- Token认证:通过Token认证调用请求。
通过终端节点和Token调用API。不支持调用“中东-阿布扎比-OP5”Region的对象存储服务(OBS)、数据接入服务(DIS)、自然语言处理(NLP)、文字识别(OCR)和图像识别(Image Recognition)。
- AK/SK认证:通过AK(Access Key ID)/SK(Secret Access Key)加密调用请求。
调用“阿联酋-阿布扎比”Region的对象存储服务(OBS)、数据接入服务(DIS)、自然语言处理(NLP)、文字识别(OCR)或图像识别(Image Recognition)首先需要新建用户并生成AK/SK,再通过AK/SK认证和终端节点(请参考:https://docs.g42cloud.com/zh-cn/endpoint/index.html)调用API,获取“阿联酋-阿布扎比”区域访问密钥AK/SK的操作步骤请参见获取访问密钥AK/SK。
Token认证
Token在计算机系统中代表令牌(临时)的意思,拥有Token就代表拥有某种权限。Token认证就是在调用API的时候将Token加到请求消息头,从而通过身份认证,获得操作API的权限。
- Token的有效期为24小时,需要使用一个Token鉴权时,可以先缓存起来,避免频繁调用。
Token可通过调用“获取用户Token”接口获取,调用本服务API需要project级别的Token,即调用获取用户Token接口时,请求body中“auth.scope”的取值需要选择“project”,请求示例如下所示。
其中username为IAM用户名,domainname为帐号名,********为用户登录密码,project name为项目名称。
POST https://iam.ae-ad-1.g42cloud.com/v3/auth/tokens Content-Type: application/json { "auth": { "identity": { "methods": [ "password" ], "password": { "user": { "name": "username", //IAM用户名 "password": "********", //密码 "domain": { "name": "domainname" //帐号名 } } } }, "scope": { "project": { "name": "project name" //替换为实际的project name } } } }
如下图所示,返回的响应消息头中“x-subject-token”就是需要获取的用户Token。获取Token之后,您就可以使用Token认证调用OCR服务API。
AK/SK认证
AK/SK签名认证方式仅支持消息体大小12M以内,12M以上的请求请使用Token认证。
AK/SK认证就是使用AK/SK对请求进行签名,在请求时将签名信息添加到消息头,从而通过身份认证。
- AK(Access Key ID):访问密钥ID。与私有访问密钥关联的唯一标识符;访问密钥ID和私有访问密钥一起使用,对请求进行加密签名。
- SK(Secret Access Key):与访问密钥ID结合使用的密钥,对请求进行加密签名,可标识发送方,并防止请求被修改。
使用AK/SK认证时,您可以基于签名算法使用AK/SK对请求进行签名,也可以使用专门的签名SDK对请求进行签名。详细的签名方法和SDK使用方法请参见API签名指南。