JAVA实现对阿里云DNS的解析管理

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: JAVA实现对阿里云DNS的解析管理

JAVA实现对阿里云DNS的解析管理

javayouhuiquan.jpg

1、阿里云DNS的SDK依赖

 
         

 

<dependency>

 

<groupId>com.aliyun</groupId>

 

<artifactId>tea-openapi</artifactId>

 

<version>0.0.19</version>

 

</dependency>

 

<dependency>

 

<groupId>com.aliyun</groupId>

 

<artifactId>alidns20150109</artifactId>

 

<version>2.0.1</version>

 

</dependency>
 
         

 

2、第一个方法:创建SDK客户端实例

所有解析记录的操作都要通过这个客户端实例来进行,所以要首先创建这个实例,需要阿里云的AccessKey(AppId和AppSecret)

 
         

 

/**

 

* <p>

 

* 创建客户端实例

 

* </p>

 

*

 

* @return

 

* @throws Exception

 

*/

 

private Client createClient()throws Exception{

 

AliConfig api = APIKit.getAliConfig(); //返回阿里云的AccessKey参数

 

if(api == null) thrownew ErrException("未配置阿里云API参数!");

 

Config config = new Config();

 

config.accessKeyId = api.getAppId();

 

config.accessKeySecret = api.getAppSecret();

 

config.endpoint = "alidns.cn-beijing.aliyuncs.com";

 

returnnew Client(config);

 

}
 
         

3、第二个方法:返回指定的记录ID(RecordId)

在阿里云的SDK中,对解析记录进行修改和删除时,都需要传入 RecordId 这个参数,所以提前写一个获取记录ID的方法。

 
         

 

/**

 

* <p>

 

* 返回指定主机记录的ID,不存在时返回null

 

* </p>

 

*

 

* @param DomainName

 

* @param RR 记录名称

 

* @return

 

*/

 

private String getRecId(Client client, String DomainName, String RR){

 

String recId = null;

 

try {

 

DescribeDomainRecordsRequest request = new DescribeDomainRecordsRequest();

 

request.setDomainName(DomainName);

 

request.setRRKeyWord(RR);

 

DescribeDomainRecordsResponse response = client.describeDomainRecords(request);

 

if(response.getBody().getTotalCount() > 0){

 

List<DescribeDomainRecordsResponseBodyDomainRecordsRecord> recs = response.getBody().getDomainRecords().getRecord();

 

for(DescribeDomainRecordsResponseBodyDomainRecordsRecord rec: recs){

 

if(rec.getRR().equalsIgnoreCase(RR)){

 

recId = rec.getRecordId();

 

break;

 

}

 

}

 

}

 

} catch (Exception e) {

 

}

 

return recId;

 

}
 
         

4、第三个方法:添加或修改指定的记录

方便起见,这里我将添加和修改集成到了一个方法,相当于SaveOrUpdate。

 
         

 

/**

 

* <p>

 

* 添加或修改解析记录

 

* </p>

 

*

 

* @param DomainName 域名

 

* @param RR 记录名称

 

* @param Type 记录类型(A、AAAA、MX、TXT、CNAME)

 

* @param Value 记录值

 

*/

 

publicvoidupdate(String DomainName, String RR, String Type, String Value){

 

try {

 

if(EStr.isEmpty(DomainName)) thrownew RuntimeException("域名(DomainName)为空!");

 

if(EStr.isEmpty(RR)) thrownew RuntimeException("主机记录(RR)为空!");

 

if(EStr.isEmpty(Type)) thrownew RuntimeException("记录类型(Type)为空!");

 

if(EStr.isEmpty(Value)) thrownew RuntimeException("记录值(Value)为空!");

 

Client client = createClient();

 

String recId = getRecId(client, DomainName, RR);

 

if(EStr.isNull(recId)){ //添加

 

AddDomainRecordRequest request = new AddDomainRecordRequest();

 

request.setDomainName(DomainName);

 

request.setRR(RR);

 

request.setType(Type);

 

request.setValue(Value);

 

AddDomainRecordResponse response = client.addDomainRecord(request);

 

recId = response.getBody().getRecordId();

 

}else{ //修改

 

UpdateDomainRecordRequest request = new UpdateDomainRecordRequest();

 

request.setRecordId(recId);

 

request.setRR(RR);

 

request.setType(Type);

 

request.setValue(Value);

 

UpdateDomainRecordResponse response = client.updateDomainRecord(request);

 

recId = response.getBody().getRecordId();

 

}

 

renderJson(Result.success("recId", recId));

 

} catch (Exception e) {

 

renderJson(Result.fail(e.getMessage()));

 

}

 

}
 
         

5、第四个方法:删除指定的记录

这个很简单,根据查找到的RecordId直接删除即可。

 
         

 

/**

 

* <p>

 

* 删除记录

 

* </p>

 

*

 

* @param DomainName

 

* @param RR

 

*/

 

publicvoidremove(String DomainName, String RR){

 

try {

 

if(EStr.isEmpty(DomainName)) thrownew RuntimeException("域名(DomainName)为空!");

 

if(EStr.isEmpty(RR)) thrownew RuntimeException("主机记录(RR)为空!");

 

Client client = createClient();

 

String recId = getRecId(client, DomainName, RR);

 

if(EStr.isNull(recId)){

 

renderJson(Result.success("recId", null));

 

}else{

 

DeleteDomainRecordRequest request = new DeleteDomainRecordRequest();

 

request.setRecordId(recId);

 

DeleteDomainRecordResponse response = client.deleteDomainRecord(request);

 

renderJson(Result.success("recId", response.getBody().getRecordId()));

 

}

 

} catch (Exception e) {

 

renderJson(Result.fail(e.getMessage()));

 

}

 

}
 
         

 

6、完整代码

查看代码

转载地址https://www.cnblogs.com/netWild/p/15815757.html

相关文章
|
6天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
54 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
13天前
|
存储 缓存 Java
Java 并发编程——volatile 关键字解析
本文介绍了Java线程中的`volatile`关键字及其与`synchronized`锁的区别。`volatile`保证了变量的可见性和一定的有序性,但不能保证原子性。它通过内存屏障实现,避免指令重排序,确保线程间数据一致。相比`synchronized`,`volatile`性能更优,适用于简单状态标记和某些特定场景,如单例模式中的双重检查锁定。文中还解释了Java内存模型的基本概念,包括主内存、工作内存及并发编程中的原子性、可见性和有序性。
Java 并发编程——volatile 关键字解析
|
5天前
|
存储 物联网 大数据
探索阿里云 Flink 物化表:原理、优势与应用场景全解析
阿里云Flink的物化表是流批一体化平台中的关键特性,支持低延迟实时更新、灵活查询性能、无缝流批处理和高容错性。它广泛应用于电商、物联网和金融等领域,助力企业高效处理实时数据,提升业务决策能力。实践案例表明,物化表显著提高了交易欺诈损失率的控制和信贷审批效率,推动企业在数字化转型中取得竞争优势。
38 14
|
11天前
|
Java 数据库连接 Spring
反射-----浅解析(Java)
在java中,我们可以通过反射机制,知道任何一个类的成员变量(成员属性)和成员方法,也可以堆任何一个对象,调用这个对象的任何属性和方法,更进一步我们还可以修改部分信息和。
|
1月前
|
Java 编译器
Java 泛型详细解析
本文将带你详细解析 Java 泛型,了解泛型的原理、常见的使用方法以及泛型的局限性,让你对泛型有更深入的了解。
49 2
Java 泛型详细解析
|
19天前
|
运维 安全 Cloud Native
阿里云云安全中心全面解析
阿里云云安全中心作为一款集持续监测、深度防御、全面分析、快速响应能力于一体的云上安全管理平台,为企业提供了全方位的安全保障。本文将详细介绍阿里云云安全中心的功能、应用场景、收费标准以及购买建议,帮助您更好地了解和利用这一强大的安全工具。
阿里云云安全中心全面解析
|
1月前
|
存储 算法 Java
Java内存管理深度解析####
本文深入探讨了Java虚拟机(JVM)中的内存分配与垃圾回收机制,揭示了其高效管理内存的奥秘。文章首先概述了JVM内存模型,随后详细阐述了堆、栈、方法区等关键区域的作用及管理策略。在垃圾回收部分,重点介绍了标记-清除、复制算法、标记-整理等多种回收算法的工作原理及其适用场景,并通过实际案例分析了不同GC策略对应用性能的影响。对于开发者而言,理解这些原理有助于编写出更加高效、稳定的Java应用程序。 ####
|
1月前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
1月前
|
Java 数据库连接 开发者
Java中的异常处理机制:深入解析与最佳实践####
本文旨在为Java开发者提供一份关于异常处理机制的全面指南,从基础概念到高级技巧,涵盖try-catch结构、自定义异常、异常链分析以及最佳实践策略。不同于传统的摘要概述,本文将以一个实际项目案例为线索,逐步揭示如何高效地管理运行时错误,提升代码的健壮性和可维护性。通过对比常见误区与优化方案,读者将获得编写更加健壮Java应用程序的实用知识。 --- ####
|
11天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者

相关产品

  • 云解析DNS