通过安卓SDK使用HTTPDNS服务
更新时间:2022-12-01
概览
本文介绍如何使用 HTTPDNS 服务访问 BOS。
需求场景
-
基于 BOS 的使用情况来看,目前移动端上传的问题主要集中在如下几个方面:
(1)DNS 解析失败,请求出错;
(2)域名劫持,数据在传输中有篡改,给用户带来诸如网络钓鱼、隐私窃取等网络访问风险;
(3)弱网下,速度慢,上传数据可能有超时。
-
若使用 HTTPDNS 服务访问 BOS,有以下优势:
(1)安全防劫持,可有效降低由域名劫持引起的成功率下降问题;
(2)精准调度可提供最优接入点,降低用户访问时延;
(3)域名解析结果变更时,HTTPDNS服务没有传统DNS服务多级缓存的影响,能够更快的令移动端获取新的解析结果,避免多层缓存的影响,可有效缩短域名切换的生效时间。
因此,如果您对 BOS 的请求成功率、延迟、故障止损效速度较为敏感,您可以使用 HTTPDNS 服务访问 BOS。
方案概述
使用 HTTPDNS 服务访问 BOS,您需要开通 HTTPDNS 服务,并添加项目依赖,重载 OkHttpDns,并调整 Bosclient 配置。
注意事项:
- HTTPDNS 虽然有一定免费额度(目前每自然月有 300 万次免费域名解析次数),超过初始额度后会产生一定的费用,通过 d 的参数配置,可以减少对httpdns server的访问,例如:缓存过期处理策略、使用https协议或http协议等。
- APP刚启动时,默认HTTPDNS降级标志为是。SDK、网络库自动使用DNS解析的方式发起请求。这属于正常情况,不会影响后续使用HTTPDNS服务来访问BOS。
实践操作
1.开通HTTPDNS服务
- 进入 HTTPDNS 官方文档,完成服务的开通;
- 在【配置管理】的域名管理中添加
*.bcebos.com
,或者业务使用的自定义域名或者 CDN 域名; - 测试 HTTPDNS。
2.添加项目依赖
我们提供了方便的远程依赖便于用户使用 httpdns。
- 打开需要引用该 sdk 的 module 的 build.gradle,在最后增加:
Java
1repositories{
2 jcenter()
3 maven {
4 url "https://raw.githubusercontent.com/bdhttpdns/BDHttpDnsSDK/master"
5 }
6}
- 在dependencies下增加:
Java
1dependencies{
2 compile 'com.baidu:httpdns:1.3'
3}
3.重载OkHttpDns
设置刚刚开通 HTTPDNS 服务的账号和密码,对常用域名进行预加载,避免初次请求时缓存不命中。同时,还可以设置多种处理策略,以更好地完成业务需要,参考移动域名解析 Android_SDK 设置接口。
Java
1static class OkHttpDns implements Dns {
2 private static OkHttpDns instance = null;
3 private BDHttpDns httpDns;
4
5 private OkHttpDns(Context context) {
6 this.httpDns = BDHttpDns.getService(context);
7 this.httpDns.setAccountID(account);
8 this.httpDns.setSecret(secret);
9 // 预加载域名
10 ArrayList<String> preResolveHosts = new ArrayList<String>();
11 preResolveHosts.add("bj.bcebos.com");
12 this.httpDns.setPreResolveHosts(preResolveHosts);
13 }
14
15 public static OkHttpDns getInstance(Context context) {
16 if(instance == null) {
17 instance = new OkHttpDns(context);
18 }
19 return instance;
20 }
21
22 @Override
23 public List<InetAddress> lookup(final String hostname) throws UnknownHostException {
24 // 通过同步解析接口获取ip
25 final BDHttpDnsResult httpDnsResult = httpDns.syncResolve(hostname, false);
26 Log.v("dns", "HttpDns resolve type: " + httpDnsResult.getResolveType());
27 // 优先使用ipv6结果,对于ipv6结果,需要在ip前后增加[]字符
28 // 若不存在ipv6结果,则使用ipv4结果
29 ArrayList<String> ipv6List = httpDnsResult.getIpv6List();
30 ArrayList<String> ipv4List = httpDnsResult.getIpv4List();
31 String ip = null;
32 if (ipv6List != null && !ipv6List.isEmpty()) {
33 ip = "[" + ipv6List.get(0) + "]";
34 } else if (ipv4List != null && !ipv4List.isEmpty()) {
35 ip = ipv4List.get(0);
36 } else {
37 Log.v("DNS", "Get empty iplist from httpdns, use origin url");
38 }
39 if(ip != null) {
40 final String finalIp = ip;
41 //如果ip不为null,直接使用该ip进行网络请求
42 List<InetAddress> inetAddresses = Arrays.asList(InetAddress.getAllByName(ip));
43 Log.d("DNS", "inetAddresses:" + inetAddresses);
44 return inetAddresses;
45 }
46 //如果返回null,走系统DNS服务解析域名
47 return Dns.SYSTEM.lookup(hostname);
48 }
49}
4.调整Bosclient配置
使用 setDns。
Java
1BosClientConfiguration config = new BosClientConfiguration();
2config.setCredentials(new DefaultBceCredentials(accessKeyId, secretAccessKey));
3config.setEndpoint(bos_endpoint);
4config.setProtocol(Protocol.HTTP);
5config.setDns(OkHttpDns.getInstance(getApplicationContext()));
5.立即体验
以上流程完成后,正常使用BOS就可以体验HTTPDNS域名解析服务了。