Node.js SDK调用示例
本文介绍金融级人脸比对的Node.js SDK调用示例。
SDK使用说明
如果需要其他语言的SDK示例代码,您可以通过OpenAPI 开发者门户在线调试工具调试API接口,该工具会自动生成相应API的SDK调用示例代码。您可以单击以下接口链接进行调试:
前提条件
需要使用的Node.js为8.0及以上版本。
已添加认证场景,并获取对应的场景ID。具体操作,请参见添加认证场景。
安装SDK
关于Node.js SDK源代码,请参见Node.js SDK。
建议您使用npm管理依赖包:
npm install @alicloud/tea-util
npm install @alicloud/openapi-client
npm install @alicloud/cloudauth20190307@2.0.3
npm install @alicloud/credentials
说明
Credentials工具配置方法,请参见身份验证配置。
调用示例
CompareFaceVerify接口调用示例
关于参数的具体描述,请参见纯服务端(API)接入。
const Config = require("@alicloud/openapi-client");
const CloudAuth = require("@alicloud/cloudauth20190307");
const CloudAuthClient = CloudAuth.default;
const {RuntimeOptions} = require("@alicloud/tea-util");
const { default: Credential } = require('@alicloud/credentials');
const fs = require("fs");
function createClient(endpoint) {
// 阿里云账号AccessKey拥有所有API的访问权限,建议您使用RAM用户进行API访问或日常运维。
// 强烈建议不要把AccessKey ID和AccessKey Secret保存到工程代码里,否则可能导致AccessKey泄露,威胁您账号下所有资源的安全。
// 本示例通过阿里云Credentials工具从环境变量中读取AccessKey,来实现API访问的身份验证。
const cred = new Credential();
const config = new Config.Config({
credential: cred,
// 设置Endpoint。
endpoint: endpoint,
// 设置HTTP代理。
// httpProxy: "http://xxx.xxx.xxx.xxx:9999",
// 设置HTTPS代理。
// httpsProxy: "https://username:password@xxx.xxx.xxx.xxx:9999",
});
return new CloudAuthClient(config)
}
async function compareFaceVerify(endpoint, request) {
const client = createClient(endpoint);
// 创建RuntimeObject实例并设置运行参数。
const runtime = new RuntimeOptions([]);
runtime.readTimeout=10000;
runtime.connectTimeout=10000;
return await client.compareFaceVerifyWithOptions(request, runtime);
}
async function compareFaceVerifyAutoRoute(request) {
const endpoints = [
"cloudauth.cn-shanghai.aliyuncs.com",
"cloudauth.cn-beijing.aliyuncs.com"
];
for (const endpoint of endpoints) {
try {
const response = await compareFaceVerify(endpoint, request);
if (response.statusCode === 500) {
continue;
}
if(response.body !== null){
if(response.body.code === "500"){
continue;
}
}
return response;
} catch (err) {
console.log(err);
continue;
}
}
return null;
}
async function main(){
// 通过以下代码创建API请求并设置参数。
const request = new CloudAuth.CompareFaceVerifyRequest({
// 请输入场景ID。
sceneId: xxx,
// 设置商户请求的唯一标识。
outerOrderNo: "xxx",
// 要接入的认证方案。
productCode: "PV_FC",
// 方式一:照片Base64。
// sourceFaceContrastPicture: "人脸照片Base64编码",
// 方式二:照片OSS bucket名和文件名。
// sourceOssBucketName: "cn-shanghai-aliyun-cloudauth-xxxxx",
// sourceOssObjectName: "verify/xxxxx/xxxxxx.jpeg",
// 方式三:照片OSS的URL地址,公网可访问。
sourceFaceContrastPictureUrl: "https://cn-shanghai-aliyun-cloudauth-xxxxxx.oss-cn-shanghai.aliyuncs.com/verify/xxxxx/xxxxx.jpeg",
// 方式四:已经实人认证通过的CertifyId。
// sourceCertifyId: "0bfa7c493f850e5178b9f8613634c9xx",
// 请在以下四种传入底库人脸照片方式中,选择一种
// 1.照片Base64编码。
// 2.照片OSS bucket名和文件名。
// 3.照片OSS的URL地址。
// 4.已经实人认证通过的CertifyId。
// 方式一:照片Base64。
// targetFaceContrastPicture: "人脸照片Base64编码",
// 方式二:照片OSS bucket名和文件名。
// targetOssBucketName: "cn-shanghai-aliyun-cloudauth-xxxxx",
// targetOssObjectName: "verify/xxxxx/xxxxxx.jpeg",
// 方式三:照片OSS的URL地址,公网可访问。
targetFaceContrastPictureUrl: "https://cn-shanghai-aliyun-cloudauth-xxxxxx.oss-cn-shanghai.aliyuncs.com/verify/xxxxx/xxxxx.jpeg",
// 方式四:已经实人认证通过的CertifyId。
// targetCertifyId: "0bfa7c493f850e5178b9f8613634c9xx"
});
// 推荐,支持服务路由。
const response = await compareFaceVerifyAutoRoute(request);
// 不支持服务自动路由。
// const response = await compareFaceVerify("cloudauth.cn-shanghai.aliyuncs.com", request);
if (response){
console.log(response.body.requestId);
console.log(response.body.code);
console.log(response.body.message);
console.log(response.body.resultObject.verifyScore);
console.log(response.body.resultObject.passed);
}
}
main().then(function (response) {});