更新时间:2019-01-08 10:40
为了访问AXN隐私号服务,您需要有一个阿里云账号。如果没有,可首先按照如下步骤创建阿里云账号:
为了使用AXN隐私号绑定API-.NET SDK,您必须申请阿里云的访问密钥。
阿里云访问秘钥是阿里云为用户使用 API(非控制台)来访问其云资源设计的“安全口令”。您可以用它来签名 API 请求内容以通过服务端的安全验证。
该访问秘钥成对(AccessKeyId 与 AccessKeySecret)生成和使用。每个阿里云用户可以创建多对访问秘钥,且可随时启用(Active)、禁用(Inactive)或者删除已经生成的访问秘钥对。
您可以通过阿里云控制台的 秘钥管理页面 创建、管理所有的访问秘钥对,且保证它处于“启用”状态。由于访问秘钥是阿里云对 API 请求进行安全验证的关键因子,请妥善保管你的访问秘钥。如果某些秘钥对出现泄漏风险,建议及时删除该秘钥对并生成新的替代秘钥对。
AXN三元组中 A号码如果是客户的话,X号码就是为A客户分配的隐私号码,其他的任何号码拨打X号码都会转接到A号码,在创建AXN绑定关系时可以设定一个默认的B号码,假如A拨打X就会转接到这个B号码,如果B号码没有设置A就会被提示拨打的X号码是空号。
请到SDK&DEMO下载页面获取相应的SDK和DEMO程序,参照代码样例进行接口开发和调试。
参数名称 | 参数类型 | 必填与否 | 样例取值 | 参数说明 |
---|---|---|---|---|
PoolKey | String | 必须 | FC12345 | 号池Key |
PhoneNoA | String | 必须 | 15000000000 | AXN中的A号码,A号码支持固话(区号后面不需要连字符”-“) |
PhoneNoB | String | 可选 | 15800000000 | AXN中的默认的B号码,B号码支持固话(区号后面不需要连字符”-“) |
PhoneNoX | String | 可选 | 17000000000 | 指定X号码进行绑定 |
ExpectCity | String | 可选 | 北京(不需要带地市的后缀) | 指定城市进行X号码的选号,如果当前号池中没有该城市的可用号码将随机分配其他城市的号码,也可以配置成严格模式,不存在符合条件的号码时提示分配错误 |
Expiration | Date | 必须 | 2017-09-05 12:00:00 | 绑定关系的过期时间 |
IsRecordingEnabled | Boolean | 可选 | true和false | 是否需要针对该绑定关系产生的所有通话录制通话录音 |
OutId | String | 可选 | abcdef | 外部业务扩展字段 |
出参名称 | 出参类型 | 样例取值 | 参数说明 |
---|---|---|---|
RequestId | String | 8906582E-6722 | 请求ID |
Code | String | OK | 状态码-返回OK代表请求成功,其他错误码详见错误码列表 |
Message | String | 请求成功 | 状态码的描述 |
SecretBindDTO | Object | 结构体 | 绑定成功后返回的结构体,结构体的属性详见demo和SDK |
SDK工具包中一共包含了2个类库,一个aliyun-.net-sdk-core包,另外一个是alicom-dypls-api包,将这两个包执行mvn package命令或者mvn deploy命令打包出相应的jar包,添加到工程类库中依赖使用。(net3.5和net2.0的用户请使用/api_demo/net2.0目录下的;core2.0的用户请使用、api_demo/core2.0/目录下的)
SDK&DEMO【下载地址】
using System;
using System.Collections.Generic;
using System.Text;
using Aliyun.Acs.Core;
using Aliyun.Acs.Core.Exceptions;
using Aliyun.Acs.Core.Profile;
using Aliyun.Acs.Dyplsapi.Model.V20170525;
using System.Security.Cryptography;
using System.Threading;
namespace ConsoleApplication1
{
class Program
{
//产品名称:云通信隐私保护API产品,开发者无需替换
const String product = "Dyplsapi";
//产品域名,开发者无需替换
const String domain = "dyplsapi.aliyuncs.com";
// TODO 此处需要替换成开发者自己的AK(在阿里云访问控制台寻找)
const String accessKeyId = "yourAccessKeyId";
const String accessKeySecret = "yourAccessKeySecret";
public static BindAxnResponse bindAxn()
{
IClientProfile profile = DefaultProfile.GetProfile("cn-hangzhou", accessKeyId, accessKeySecret);
DefaultProfile.AddEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
IAcsClient client = new DefaultAcsClient(profile);
BindAxnRequest request = new BindAxnRequest();
//必填:号池Key
request.setPoolKey("FC133455");
request.PhoneNoA = "15010101010";
request.PhoneNoB = "15020202020";
request.Expiration = "2017-09-18 17:00:00";
//可选:是否需要录制音频-默认是false
request.IsRecordingEnabled = false;
//外部业务自定义ID属性
request.OutId = "yourOutId";
BindAxnResponse response = null;
try
{
response = client.GetAcsResponse(request);
}
catch (ServerException e)
{
}
catch (ClientException e)
{
}
return response;
}
static void Main(string[] args)
{
BindAxnResponse axnResponse = bindAxn();
Console.Write("AXN绑定接口返回的结果----------------");
Console.Write("Code=" + axnResponse.Code);
Console.Write("Message=" + axnResponse.Message);
Console.Write("RequestId=" + axnResponse.RequestId);
String axnSubsId = axnResponse.SecretBindDTO == null ? null : axnResponse.SecretBindDTO.SubsId;
String axnSecretNo = axnResponse.SecretBindDTO == null ? null : axnResponse.SecretBindDTO.SecretNo;
Console.Write("subsId=" + axnSubsId);
Console.Write("secretNo=" + axnSecretNo);
Console.WriteLine();
}
}
}
Code | 描述 |
---|---|
OK | 请求成功 |
isp.RAM_PERMISSION_DENY | RAM权限DENY |
isv.OUT_OF_SERVICE | 业务停机 |
isv.PRODUCT_UN_SUBSCRIPT | 未开通云通信产品的阿里云客户 |
isv.PRODUCT_UNSUBSCRIBE | 产品未开通 |
isv.ACCOUNT_NOT_EXISTS | 账户不存在 |
isv.ACCOUNT_ABNORMAL | 账户异常 |
isp.SYSTEM_ERROR | 系统错误 |
isp.UNKNOWN_ERR_CODE | 运营商未知错误 |
isv.PARTNER_NOT_EXIST | 未知合作伙伴 |
isv.NO_NOT_EXIST | 号码不存在 |
isv.ILLEGAL_ARGUMENT | 参数非法 |
isp.DAO_EXCEPTION | 数据库异常 |
isv.NO_AVAILABLE_NUMBER | 无可用号码 |
isp.VENDOR_UNAVAILABLE | 运营商降级 |
isv.FLOW_LIMIT | 业务流控 |
isv.PARTNER_IS_CLOSED | partner被关停 |
isv.FORBIDDEN_ACTION | 无权操作 |
isv.NO_USED_BY_OTHERS | 码被其他业务方占用 |
isv.VENDOR_BIND_FAILED | 运营商绑定失败 |
isv.EXPIRE_DATE_ILLEGAL | 过期时间非法 |
isv.MOBILE_NUMBER_ILLEGAL | 号码格式非法 |
isv.BIND_CONFLICT | 绑定冲突 |
在文档使用中是否遇到以下问题
更多建议
匿名提交