本文介绍Java SDK集成纯服务端认证方案的操作方法。
SDK使用说明
如果需要其他语言的SDK示例代码,您可以通过OpenAPI 开发者门户在线调试工具调试API接口。该工具会自动生成相应API的SDK调用示例代码,详细信息,请参见调试ContrastSmartVerify接口。
前提条件
- 需要使用的Java版本在1.8版本及以上。
- 已添加认证场景,并获取对应的场景ID。具体操作,请参见添加认证场景。
使用Maven引入SDK
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>cloudauth20200618</artifactId>
<version>1.0.5</version>
</dependency>
调用示例
- 方式一:不使用本地图片示例
import java.util.Arrays; import java.util.List; import com.aliyun.cloudauth20200618.models.ContrastSmartVerifyRequest; import com.aliyun.cloudauth20200618.models.ContrastSmartVerifyResponse; import com.aliyun.tea.TeaException; import com.aliyun.tea.TeaUnretryableException; import com.aliyun.tearpc.models.Config; import com.aliyun.teautil.models.RuntimeOptions; public class ContrastSmartVerify { public static void main(String[] args) throws Exception { // 通过以下代码创建API请求并设置参数。 ContrastSmartVerifyRequest request = new ContrastSmartVerifyRequest(); // 请输入场景ID+L。 request.setSceneId(xxxL); request.setOuterOrderNo("xxx"); // 增强版实人认证的业务场景类型。取值: // CERT_SAFE:纯认证模式。 // CERT_PHOTO_SAFE:认证及照片防翻拍检测模式。 // MARKET_SAFE:营销安全(包含认证、防翻拍和营销风险识别功能)。 // FINANCE_SAFE:金融安全(包含认证、防翻拍和金融风险识别功能)。 // ACCOUNT_SAFE:注册安全(包含认证、防翻拍和注册风险识别功能)。 request.setMode("CERT_SAFE"); request.setCertType("IDENTITY_CARD"); request.setCertName("xxx"); request.setCertNo("xxx"); // 当Mode取值为MARKET_SAFE、FINANCE_SAFE或ACCOUNT_SAFE时,Mobile为必填字段。 request.setMobile("137xxxxxxxx"); // 公网可以访问的HTTP、HTTPS链接。 request.setFacePicUrl("http://image-demo.img-cn-hangzhou.aliyuncs.com/example.jpg"); // 使用图片Base64编码方式。 // request.setFacePicString("xxxxx"); // 用户网络IP。 // request.setIp("xx.xx.xxx.xxx"); // 您业务中自定义的用户ID,请保持唯一。 // request.setUserId("xxx"); // 推荐,支持服务路由。 ContrastSmartVerifyResponse response = contrastSmartVerifyAutoRoute(request); // 不支持服务自动路由。 //ContrastSmartVerifyResponse response = contrastSmartVerify("cloudauth.cn-shanghai.aliyuncs.com", request); System.out.println(response.getRequestId()); System.out.println(response.getCode()); System.out.println(response.getMessage()); System.out.println( response.getResultObject() == null ? null : response.getResultObject().getPassed()); System.out.println( response.getResultObject() == null ? null : response.getResultObject().getSubCode()); System.out.println(response.getResultObject() == null ? null : response.getResultObject().getVerifyInfo()); System.out.println(response.getResultObject() == null ? null : response.getResultObject().getRiskInfo()); } private static ContrastSmartVerifyResponse contrastSmartVerifyAutoRoute(ContrastSmartVerifyRequest request) { // 第一个为主区域Endpoint,第二个为备区域Endpoint。 List<String> endpoints = Arrays.asList("cloudauth.cn-shanghai.aliyuncs.com", "cloudauth.cn-beijing.aliyuncs.com"); ContrastSmartVerifyResponse lastResponse = null; for (String endpoint : endpoints) { try { ContrastSmartVerifyResponse response = contrastSmartVerify(endpoint, request); lastResponse = response; // 服务端错误,切换到下个区域调用。 if ("500".equals(response.getCode())) { continue; } return response; } catch (Exception e) { // 网络异常,切换到下个区域调用。 if (e.getCause() instanceof TeaException) { TeaException teaException = ((TeaException)e.getCause()); if (teaException.getData() != null && "ServiceUnavailable".equals( teaException.getData().get("Code"))) { continue; } } if (e.getCause() instanceof TeaUnretryableException) { continue; } } } return lastResponse; } private static ContrastSmartVerifyResponse contrastSmartVerify(String endpoint, ContrastSmartVerifyRequest request) throws Exception { // 阿里云账号AccessKey拥有所有API的访问权限,建议您使用RAM用户进行API访问或日常运维。 // 强烈建议不要把AccessKey ID和AccessKey Secret保存到工程代码里,否则可能导致AccessKey泄露,威胁您账号下所有资源的安全。 // 本示例通过阿里云Credentials工具从环境变量中读取AccessKey,来实现API访问的身份验证。如何配置环境变量,请参见https://help.aliyun.com/document_detail/378657.html。 com.aliyun.credentials.Client credentialClient = new com.aliyun.credentials.Client(); Config config = new Config(); config.setCredential(credentialClient); config.setEndpoint(endpoint); // 设置http代理。 //config.setHttpProxy("http://127.x.x.x:xxxx"); // 设置https代理。 //config.setHttpsProxy("https://127.x.x.x:xxxx"); com.aliyun.cloudauth20200618.Client client = new com.aliyun.cloudauth20200618.Client(config); // 创建RuntimeObject实例并设置运行参数。 RuntimeOptions runtime = new RuntimeOptions(); runtime.readTimeout = 10000; runtime.connectTimeout = 10000; return client.contrastSmartVerify(request, runtime); } }
- 方式二:使用本地图片示例
import java.io.FileInputStream; import java.io.InputStream; import java.util.Arrays; import java.util.List; import com.aliyun.cloudauth20200618.models.ContrastSmartVerifyAdvanceRequest; import com.aliyun.cloudauth20200618.models.ContrastSmartVerifyResponse; import com.aliyun.tea.TeaException; import com.aliyun.tea.TeaUnretryableException; import com.aliyun.tearpc.models.Config; import com.aliyun.teautil.models.RuntimeOptions; public class ContrastSmartVerify { public static void main(String[] args) throws Exception { // 通过以下代码创建API请求并设置参数。 ContrastSmartVerifyAdvanceRequest request = new ContrastSmartVerifyAdvanceRequest(); // 请输入场景ID+L。 request.setSceneId(xxxL); request.setOuterOrderNo("xxx"); // 增强版实人认证的业务场景类型。取值: // CERT_SAFE:纯认证模式。 // CERT_PHOTO_SAFE:认证及照片防翻拍检测模式。 // MARKET_SAFE:营销安全(包含认证、防翻拍和营销风险识别功能)。 // FINANCE_SAFE:金融安全(包含认证、防翻拍和金融风险识别功能)。 // ACCOUNT_SAFE:注册安全(包含认证、防翻拍和注册风险识别功能)。 request.setMode("CERT_PHOTO_SAFE"); request.setCertType("IDENTITY_CARD"); request.setCertName("xxx"); request.setCertNo("xxx"); // 当Mode取值为MARKET_SAFE、FINANCE_SAFE或ACCOUNT_SAFE时,Mobile为必填字段。 request.setMobile("137xxxxxxxx"); // 用户网络IP。 // request.setIp("xx.xx.xxx.xxx"); // 您业务中自定义的用户ID,请保持唯一。 // request.setUserId("xxx"); InputStream inputStream = null; try { // 本地文件。 inputStream = new FileInputStream("/xxx.png"); request.setFacePicFileObject(inputStream); // 推荐,支持服务路由。 ContrastSmartVerifyResponse response = contrastSmartVerifyAdvanceAutoRoute(request); // 不支持服务自动路由。 //ContrastSmartVerifyResponse response = contrastSmartVerifyAdvance("cloudauth.cn-shanghai.aliyuncs.com", request); System.out.println(response.getRequestId()); System.out.println(response.getCode()); System.out.println(response.getMessage()); System.out.println( response.getResultObject() == null ? null : response.getResultObject().getPassed()); System.out.println( response.getResultObject() == null ? null : response.getResultObject().getSubCode()); System.out.println(response.getResultObject() == null ? null : response.getResultObject().getVerifyInfo()); System.out.println(response.getResultObject() == null ? null : response.getResultObject().getRiskInfo()); } finally { if(inputStream != null){ inputStream.close(); } } } private static ContrastSmartVerifyResponse contrastSmartVerifyAdvanceAutoRoute(ContrastSmartVerifyAdvanceRequest request) { // 第一个为主区域Endpoint,第二个为备区域Endpoint。 List<String> endpoints = Arrays.asList("cloudauth.cn-shanghai.aliyuncs.com", "cloudauth.cn-beijing.aliyuncs.com"); ContrastSmartVerifyResponse lastResponse = null; for (String endpoint : endpoints) { try { ContrastSmartVerifyResponse response = contrastSmartVerifyAdvance(endpoint, request); lastResponse = response; // 服务端错误,切换到下个区域调用。 if ("500".equals(response.getCode())) { continue; } return response; } catch (Exception e) { // 网络异常,切换到下个区域调用。 if (e.getCause() instanceof TeaException) { TeaException teaException = ((TeaException)e.getCause()); if (teaException.getData() != null && "ServiceUnavailable".equals( teaException.getData().get("Code"))) { continue; } } if (e.getCause() instanceof TeaUnretryableException) { continue; } } } return lastResponse; } private static ContrastSmartVerifyResponse contrastSmartVerifyAdvance(String endpoint, ContrastSmartVerifyAdvanceRequest request) throws Exception { // 阿里云账号AccessKey拥有所有API的访问权限,建议您使用RAM用户进行API访问或日常运维。 // 强烈建议不要把AccessKey ID和AccessKey Secret保存到工程代码里,否则可能导致AccessKey泄露,威胁您账号下所有资源的安全。 // 本示例通过阿里云Credentials工具从环境变量中读取AccessKey,来实现API访问的身份验证。如何配置环境变量,请参见https://help.aliyun.com/document_detail/378657.html。 com.aliyun.credentials.Client credentialClient = new com.aliyun.credentials.Client(); Config config = new Config(); config.setCredential(credentialClient); config.setEndpoint(endpoint); // 设置http代理。 //config.setHttpProxy("http://127.x.x.x:xxxx"); // 设置https代理。 //config.setHttpsProxy("https://127.x.x.x:xxxx"); com.aliyun.cloudauth20200618.Client client = new com.aliyun.cloudauth20200618.Client(config); // 创建RuntimeObject实例并设置运行参数。 RuntimeOptions runtime = new RuntimeOptions(); runtime.readTimeout = 10000; runtime.connectTimeout = 10000; return client.contrastSmartVerifyAdvance(request, runtime); } }