我们为您提供了智能对话分析Java SDK以及阿里云核心库的Maven项目依赖及JAR包,您可以编写代码调用SDK来实现智能对话分析服务的访问。
注意事项
如果您还未开通或者还不了解阿里云智能对话分析服务,请前往产品主页获取更多信息。
以下文档适用于版本号大于3.0.0的SDK。
本文向您介绍智能对话分析Java SDK的安装、使用及注意事项。
关于Java SDK的更多说明,请参见阿里云SDK文档。
如果您还未创建AccessKeyID和AccessKeySecret,请到阿里云Access Key管理来创建AccessKey。
阿里云账号AccessKey拥有所有API的访问权限,如泄露会影响。强烈建议您创建并使用RAM用户进行API访问或日常运维。相关操作,请参见创建RAM用户。
各API详细出入参说明请查看左侧目录中的开发指南 > API参考文档,例如上传音频质检。
下载SDK
推荐使用Maven管理依赖,当前SDK最新版本号可在https://github.com/aliyun/aliyun-openapi-java-sdk/blob/master/aliyun-java-sdk-qualitycheck/ChangeLog.txt中查看。
在pom.xml中添加如下依赖:
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-qualitycheck</artifactId>
<version>3.0.7</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>4.0.6</version>
</dependency>
配置访问凭证
配置环境变量SCA_AK_ENV
和SCA_SK_ENV
。
Linux和macOS系统配置方法
执行以下命令:
export SCA_AK_ENV=<access_key_id> export SCA_SK_ENV=<access_key_secret>
<access_key_id>替换为已准备好的AccessKey ID,<access_key_secret>替换为AccessKey Secret。
Windows系统配置方法
新建环境变量,添加环境变量
SCA_AK_ENV
和SCA_SK_ENV
,并写入已准备好的AccessKey ID和AccessKey Secret。重启Windows系统。
调用示例
import com.aliyuncs.http.FormatType;
import com.aliyuncs.qualitycheck.model.v20190115.UploadDataRequest;
import com.aliyuncs.qualitycheck.model.v20190115.UploadDataResponse;
import org.junit.Before;
import org.junit.Test;
import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.exceptions.ClientException;
import com.aliyuncs.exceptions.ServerException;
import com.aliyuncs.http.HttpResponse;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.profile.IClientProfile;
public class TestApi {
IAcsClient client = null;
@Before
public void init() throws ClientException {
// 阿里云账号AccessKey拥有所有API的访问权限,建议您使用RAM用户进行API访问或日常运维。
// 强烈建议不要把AccessKey ID和AccessKey Secret保存到工程代码里,否则可能导致AccessKey泄露,威胁您账号下所有资源的安全。
// 本示例以将AccessKey ID和AccessKey Secret保存在环境变量为例说明。您也可以根据业务需要,保存到配置文件里。
String accessKeyId = System.getenv("SCA_AK_ENV");
String accessKeySecret = System.getenv("SCA_SK_ENV");
// 构建Aliyun Client, 用于发起请求
// 智能对话分析API的服务接入地址为华东 1(杭州), 此处Region值固定填写"cn-hangzhou"
IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret);
//指定服务接入地址,以下为固定值
DefaultProfile.addEndpoint("HZ", "cn-hangzhou", "Qualitycheck", "qualitycheck.cn-hangzhou.aliyuncs.com");
client = new DefaultAcsClient(profile);
}
/**
* 取得反序列化的实例对象,当http status>=200且<300,表示API调用成功
* 当http status>=300且<500,报错ClientException
* 当http status>=500 SDK,报错ServerException
* Request和Response会成对出现,其前缀会根据调用的相关接口进行变更
* 例如调用获取结果接口时,使用GetResultRequest/GetResultResponse
*/
@Test
public void uploadDataSample(String aliUid) {
UploadDataRequest req = new UploadDataRequest();
req.setJsonStr("<Upload Data Json>");
try {
UploadDataResponse response = client.getAcsResponse(req);
// do something.
System.out.println(response.getCode());
System.out.println(response.getMessage());
System.out.println(com.alibaba.fastjson.JSON.toJSONString(response));
} catch (ServerException e) {
e.printStackTrace();
} catch (ClientException e) {
e.printStackTrace();
}
}
/**
* 取得原始的API调用结果
* Request/Response,其前缀会根据调用的相关接口进行变更
* 例如调用获取结果接口时,使用GetResultRequest/GetResultResponse
*/
@Test
public void uploadDataActionSample(String aliUid) {
UploadDataRequest req = new UploadDataRequest();
//定义返回的报文格式
//req.setAcceptFormat(FormatType.JSON);
req.setJsonStr("<Upload Data Json>");
// describeRegionsRequest.setRegionId("cn-hangzhou");//指定要访问的Region,仅对当前请求生效,不改变Client的默认设置
try {
HttpResponse httpResponse = client.doAction(req);
System.out.println(req.getUrl());
System.out.println(httpResponse.getUrl());
byte[] content = httpResponse.getHttpContent();
System.out.println(new String(content));
} catch (ServerException e) {
e.printStackTrace();
} catch (ClientException e) {
e.printStackTrace();
}
}
}