NIMSDK-AOS  10.9.10
ServerAddresses.java
浏览该文件的文档.
1 package com.netease.nimlib.sdk;
2 
3 import android.util.Pair;
4 import androidx.annotation.Nullable;
5 import com.netease.nimlib.push.net.lbs.IPVersion;
6 import com.netease.nimlib.push.packet.asymmetric.AsymmetricType;
7 import com.netease.nimlib.push.packet.symmetry.SymmetryType;
8 import com.netease.nimlib.util.CollectionUtil;
9 import java.io.Serializable;
10 import java.util.ArrayList;
11 import java.util.Arrays;
12 import java.util.HashSet;
13 import java.util.List;
14 import java.util.Set;
15 import org.json.JSONException;
16 import org.json.JSONObject;
17 
18 /**
19  * 云信私有化服务器配置项
20  */
21 @SuppressWarnings("java:S1104")
22 public class ServerAddresses implements Serializable {
23  public static final String KEY_MODULE = "KEY_MODULE";
24  public static final String KEY_PUBLIC_KEY_VERSION = "KEY_PUBLIC_KEY_VERSION";
25  public static final String KEY_LBS = "KEY_LBS";
26  public static final String KEY_LBS_BACKUP = "KEY_LBS_BACKUP";
27  public static final String KEY_CHATROOM_LBS = "KEY_CHATROOM_LBS";
28  public static final String KEY_DEFAULT_LINK = "KEY_DEFAULT_LINK";
29  public static final String KEY_DEFAULT_LINK_BACKUP = "KEY_DEFAULT_LINK_BACKUP";
30  public static final String KEY_NOS_UPLOAD_LBS = "KEY_NOS_UPLOAD_LBS";
31  public static final String KEY_NOS_UPLOAD_DEFAULT_LINK = "KEY_NOS_UPLOAD_DEFAULT_LINK";
32  public static final String KEY_NOS_UPLOAD = "KEY_NOS_UPLOAD";
33  public static final String KEY_NOS_SUPPORT_HTTPS = "KEY_NOS_SUPPORT_HTTPS";
34  public static final String KEY_NOS_DOWNLOAD_URL_FORMAT = "KEY_NOS_DOWNLOAD_URL_FORMAT";
35  public static final String KEY_NOS_DOWNLOAD = "KEY_NOS_DOWNLOAD";
36  public static final String KEY_NOS_ACCESS = "KEY_NOS_ACCESS";
37  public static final String KEY_NT_SERVER_ADDRESS = "KEY_NT_SERVER_ADDRESS";
38  public static final String KEY_BD_SERVER_ADDRESS = "KEY_BD_SERVER_ADDRESS";
39  public static final String KEY_TEST = "KEY_TEST";
40  public static final String KEY_DEDICATED_CLUSTE_FLAG = "KEY_DEDICATED_CLUSTE_FLAG";
41  public static final String KEY_NEGO_KEY_NECA = "KEY_NEGO_KEY_NECA";
42  public static final String KEY_NEGO_KEY_ENCA_KEY_VERSION = "KEY_NEGO_KEY_ENCA_KEY_VERSION";
43  public static final String KEY_NEGO_KEY_ENCA_KEY_PARTA = "KEY_NEGO_KEY_ENCA_KEY_PARTA";
44  public static final String KEY_NEGO_KEY_ENCA_KEY_PARTB = "KEY_NEGO_KEY_ENCA_KEY_PARTB";
45  public static final String KEY_COMM_ENCA = "KEY_COMM_ENCA";
46  public static final String KEY_LINK_IPV6 = "KEY_LINK_IPV6";
47  public static final String KEY_IP_PROTOCOL_VERSION = "KEY_IP_PROTOCOL_VERSION";
48  public static final String KEY_PROBE_IPV4_URL = "KEY_PROBE_IPV4_URL";
49  public static final String KEY_PROBE_IPV6_URL = "KEY_PROBE_IPV6_URL";
50  public static final String KEY_HANDSHAKE_TYPE = "KEY_HANDSHAKE_TYPE";
51  public static final String KEY_NOS_CDN_ENABLE = "KEY_NOS_CDN_ENABLE";
52  public static final String KEY_NOS_DOWNLOAD_SET = "KEY_NOS_DOWNLOAD_SET";
53  public static final String KEY_COMPASS_DATA_ENDPOINT = "KEY_COMPASS_DATA_ENDPOINT";
54 
55  /**
56  * 连接云信服务器加密数据通道的公钥参数1 rsaModulus
57  */
58  public String module;
59 
60  /**
61  * 连接云信服务器加密数据通道的公钥的版本号(默认0)
62  */
63  public int publicKeyVersion = 0;
64 
65  /**
66  * IM LBS服务器地址,通过它获取IM link 地址信息
67  * 填http/https地址
68  *
69  * @see ServerAddresses#lbsBackup
70  */
71  public String lbs;
72 
73  /**
74  * 备用IM LBS服务器地址,通过它获取IM link 地址信息
75  * 填http/https地址
76  *
77  * @see ServerAddresses#lbs
78  */
79  public List<String> lbsBackup;
80 
81  /**
82  * ChatRoom LBS服务器地址,通过它获取ChatRoom link 地址信息
83  * 填http/https地址
84  *
85  */
86  public List<String> chatRoomLbsList;
87 
88  /**
89  * IM 默认的link服务器地址,当IM LBS不可用时先连接该地址
90  * 填"IP/Host:PORT"
91  */
92  public String defaultLink;
93 
94  /**
95  * IM 默认的link服务器地址不可用时,连接这些地址
96  * 填"IP/Host:PORT"
97  */
98  public List<String> defaultLinkBackup;
99 
100  /**
101  * NOS上传LBS服务器地址
102  * 填http/https地址
103  */
104  public String nosUploadLbs;
105 
106  /**
107  * NOS上传默认的link服务器地址,当NOS LBS不可用时先连接该地址
108  * 填http/https地址
109  */
110  public String nosUploadDefaultLink;
111 
112  /**
113  * NOS上传服务器主机地址(仅nosSupportHttps=true时有效,用作https上传时的域名校验及http header host字段填充)
114  * 填host地址
115  */
116  public String nosUpload;
117 
118  /**
119  * NOS上传是否需要支持https。SDK 3.2版本后默认支持https,同时需要配置 nosUpload!
120  */
121  public boolean nosSupportHttps = true;
122 
123  /**
124  * [4.6.0版本新增] NOS下载地址拼接模板,用于拼接最终得到的下载地址。
125  * 默认是 {bucket}.nosdn.127.net/{object},SDK 上传资源后生成的下载地址为 https://bucket.nosdn.127.net/object
126  */
127  public String nosDownloadUrlFormat;
128 
129  /**
130  * NOS下载地址的host,用于拼接最终获得的文件URL地址,也支持该host替换成下载加速域名/地址 nosAccess.
131  * 填host地址, 默认是 nos.netease.com
132  */
133  public String nosDownload;
134 
135  /**
136  * NOS下载加速域名/地址,用于替换NOS下载url中的 nosDownload。
137  * 提供两种方式:
138  * 1) [4.4.0+开始支持]模板方式:填写云信规定的两种模板:{bucket}.nosdn.127.net/{object} 或者 nosdn.127.net/{bucket}/{object},其中 {bucket} 和 {object} 作为标识符,必须填写。域名部分可以替换为您申请的加速域名。
139  * 2) [所有版本支持]非模板方式:填写用于加速的 http/https地址,例如:http://111.222.111.22:9090
140  */
141  public String nosAccess;
142 
143  /**
144  * 云信运行时异常统计服务器地址
145  */
146  public String ntServerAddress;
147 
148  /**
149  * 云信数据统计服务器地址
150  */
151  public String bdServerAddress;
152 
153  /**
154  * 是否是测试服
155  */
156  public boolean test = false;
157 
158  /**
159  * 是否为专属集群{1(是), 0(否)}
160  */
162 
163  /**
164  * "交换密钥"协议加密算法 {1(RSA),2(SM2)}, def:1(RSA) 非对称加密
165  */
166  public AsymmetricType negoKeyNeca = AsymmetricType.RSA;
167 
168  /**
169  * "交换密钥"协议加密算法密钥版本 version 自定义时则必填
170  */
172 
173  /**
174  * "交换密钥"协议加密算法密钥 part A 自定义时则必填 BigNumHex string 不含0x RSA: module, SM2: X
175  */
176  public String negoKeyEncaKeyParta;
177 
178  /**
179  * "交换密钥"协议加密算法密钥 part B 自定义时则必填 BigNumHex string 不含0x RSA: EXP, SM2: Y
180  */
181  public String negoKeyEncaKeyPartb;
182 
183  /**
184  * 通信加密算法 {1(RC4), 2(AES128), 4(SM4)}
185  * 默认: 1(RC4) 对称加密
186  */
187  public SymmetryType commEnca = SymmetryType.RC4;
188 
189  /**
190  * ipv6的缺省连接地址
191  */
192  public String linkIpv6;
193 
194  /**
195  * IP协议版本{0(IPV4), 1(IPV6), 2(Auto, SDK测试后自行选择, 存在性能损耗)}。
196  * 默认: 0(IPV4) 非对称加密
197  */
198  public IPVersion ipProtocolVersion = IPVersion.IPV4;
199 
200  /**
201  * 探测ipv4地址类型使用的url, IPProtVersion == 2或3 时生效
202  */
203  public String probeIpv4Url;
204 
205  /**
206  * 探测ipv6地址类型使用的url, IPProtVersion == 2或3 时生效
207  */
208  public String probeIpv6Url;
209 
210  /**
211  * 握手协议选择字段
212  */
213  public NimHandshakeType handshakeType = NimHandshakeType.V1;
214 
215  /**
216  * 是否优先使用Cdn域名进行NOS下载
217  */
218  public boolean nosCdnEnable = true;
219 
220  /**
221  * 每个元素为使用过的NOS下载地址的特征以及桶名是否在host中组成的{@link Pair}对象
222  * 如new Pair("nim.nos.netease.com", true), new Pair("nos.netease.com/nim", false)等
223  */
224  public Set<String> nosDownloadSet;
225 
226  /**
227  * 数据上报端点
228  */
229  public String compassDataEndpoint;
230 
231 
232  public JSONObject toJson() {
233  JSONObject object = new JSONObject();
234  try {
235  object.putOpt(KEY_MODULE, module);
236  object.putOpt(KEY_PUBLIC_KEY_VERSION, publicKeyVersion);
237  object.putOpt(KEY_LBS, lbs);
238  object.putOpt(KEY_LBS_BACKUP, CollectionUtil.toString(lbsBackup, ";"));
239  object.putOpt(KEY_CHATROOM_LBS, CollectionUtil.toString(chatRoomLbsList, ";"));
240  object.putOpt(KEY_DEFAULT_LINK, defaultLink);
241  object.putOpt(KEY_DEFAULT_LINK_BACKUP, CollectionUtil.toString(defaultLinkBackup, ";"));
242  object.putOpt(KEY_NOS_UPLOAD_LBS, nosUploadLbs);
243  object.putOpt(KEY_NOS_UPLOAD_DEFAULT_LINK, nosUploadDefaultLink);
244  object.putOpt(KEY_NOS_UPLOAD, nosUpload);
245  object.putOpt(KEY_NOS_SUPPORT_HTTPS, nosSupportHttps);
246  object.putOpt(KEY_NOS_DOWNLOAD_URL_FORMAT, nosDownloadUrlFormat);
247  object.putOpt(KEY_NOS_DOWNLOAD, nosDownload);
248  object.putOpt(KEY_NOS_ACCESS, nosAccess);
249  object.putOpt(KEY_NT_SERVER_ADDRESS, ntServerAddress);
250  object.putOpt(KEY_BD_SERVER_ADDRESS, bdServerAddress);
251  object.putOpt(KEY_TEST, test);
252  object.putOpt(KEY_DEDICATED_CLUSTE_FLAG, dedicatedClusteFlag);
253  object.putOpt(KEY_NEGO_KEY_NECA, negoKeyNeca == null ? AsymmetricType.RSA.getValue(): negoKeyNeca.getValue());
254  object.putOpt(KEY_NEGO_KEY_ENCA_KEY_VERSION, negoKeyEncaKeyVersion);
255  object.putOpt(KEY_NEGO_KEY_ENCA_KEY_PARTA, negoKeyEncaKeyParta);
256  object.putOpt(KEY_NEGO_KEY_ENCA_KEY_PARTB, negoKeyEncaKeyPartb);
257  object.putOpt(KEY_COMM_ENCA, commEnca == null ? SymmetryType.RC4.getValue() : commEnca.getValue());
258  object.putOpt(KEY_LINK_IPV6, linkIpv6);
259  object.putOpt(KEY_IP_PROTOCOL_VERSION, ipProtocolVersion == null ? IPVersion.IPV4.getValue() :ipProtocolVersion.getValue());
260  object.putOpt(KEY_PROBE_IPV4_URL, probeIpv4Url);
261  object.putOpt(KEY_PROBE_IPV6_URL, probeIpv6Url);
262  object.putOpt(KEY_HANDSHAKE_TYPE, handshakeType == null ? NimHandshakeType.V1.getValue() : handshakeType.getValue());
263  object.putOpt(KEY_NOS_CDN_ENABLE, nosCdnEnable);
264  object.putOpt(KEY_NOS_DOWNLOAD_SET, CollectionUtil.toString(nosDownloadSet, ";"));
265  object.putOpt(KEY_COMPASS_DATA_ENDPOINT, compassDataEndpoint);
266  } catch (JSONException e) {
267  e.printStackTrace();
268  }
269  return object;
270  }
271 
272  public static ServerAddresses fromJson(@Nullable JSONObject object) {
273  if (object == null) {
274  return null;
275  }
276  ServerAddresses serverAddresses = new ServerAddresses();
277 
278  serverAddresses.module = object.optString(KEY_MODULE);
279  serverAddresses.publicKeyVersion = object.optInt(KEY_PUBLIC_KEY_VERSION);
280  serverAddresses.lbs = object.optString(KEY_LBS);
281  serverAddresses.lbsBackup = new ArrayList<>(Arrays.asList(object.optString(KEY_LBS_BACKUP).split(";")));
282  serverAddresses.chatRoomLbsList = new ArrayList<>(Arrays.asList(object.optString(KEY_CHATROOM_LBS).split(";")));
283  serverAddresses.defaultLink = object.optString(KEY_DEFAULT_LINK);
284  serverAddresses.defaultLinkBackup = new ArrayList<>(Arrays.asList(object.optString(KEY_DEFAULT_LINK_BACKUP).split(";")));
285  serverAddresses.nosUploadLbs = object.optString(KEY_NOS_UPLOAD_LBS);
286  serverAddresses.nosUploadDefaultLink = object.optString(KEY_NOS_UPLOAD_DEFAULT_LINK);
287  serverAddresses.nosUpload = object.optString(KEY_NOS_UPLOAD);
288  serverAddresses.nosSupportHttps = object.optBoolean(KEY_NOS_SUPPORT_HTTPS);
289  serverAddresses.nosDownloadUrlFormat = object.optString(KEY_NOS_DOWNLOAD_URL_FORMAT);
290  serverAddresses.nosDownload = object.optString(KEY_NOS_DOWNLOAD);
291  serverAddresses.nosAccess = object.optString(KEY_NOS_ACCESS);
292  serverAddresses.ntServerAddress = object.optString(KEY_NT_SERVER_ADDRESS);
293  serverAddresses.bdServerAddress = object.optString(KEY_BD_SERVER_ADDRESS);
294  serverAddresses.test = object.optBoolean(KEY_TEST);
295  serverAddresses.dedicatedClusteFlag = object.optInt(KEY_DEDICATED_CLUSTE_FLAG);
296  serverAddresses.negoKeyNeca = AsymmetricType.value(object.optInt(KEY_NEGO_KEY_NECA));
297  serverAddresses.negoKeyEncaKeyVersion = object.optInt(KEY_NEGO_KEY_ENCA_KEY_VERSION);
298  serverAddresses.negoKeyEncaKeyParta = object.optString(KEY_NEGO_KEY_ENCA_KEY_PARTA);
299  serverAddresses.negoKeyEncaKeyPartb = object.optString(KEY_NEGO_KEY_ENCA_KEY_PARTB);
300  serverAddresses.commEnca = SymmetryType.value(object.optInt(KEY_COMM_ENCA));
301  serverAddresses.linkIpv6 = object.optString(KEY_LINK_IPV6);
302  serverAddresses.ipProtocolVersion = IPVersion.value(object.optInt(KEY_IP_PROTOCOL_VERSION));
303  serverAddresses.probeIpv4Url = object.optString(KEY_PROBE_IPV4_URL);
304  serverAddresses.probeIpv6Url = object.optString(KEY_PROBE_IPV6_URL);
305  serverAddresses.handshakeType = NimHandshakeType.value(object.optInt(KEY_HANDSHAKE_TYPE));
306  serverAddresses.nosCdnEnable = object.optBoolean(KEY_NOS_CDN_ENABLE);
307  serverAddresses.nosDownloadSet = new HashSet<>(Arrays.asList(object.optString(KEY_NOS_DOWNLOAD_SET).split(";")));
308  serverAddresses.compassDataEndpoint = object.optString(KEY_COMPASS_DATA_ENDPOINT);
309  return serverAddresses;
310  }
311 
312 }
int negoKeyEncaKeyVersion
"交换密钥"协议加密算法密钥版本 version 自定义时则必填
String ntServerAddress
云信运行时异常统计服务器地址
NimHandshakeType handshakeType
握手协议选择字段
String nosDownloadUrlFormat
[4.6.0版本新增] NOS下载地址拼接模板,用于拼接最终得到的下载地址。 默认是 {bucket}.nosdn.127.net/{object},SDK 上传资源后生成的下载地址为 https://bucket.nosdn.127.net/object
String negoKeyEncaKeyPartb
"交换密钥"协议加密算法密钥 part B 自定义时则必填 BigNumHex string 不含0x RSA: EXP, SM2: Y
String lbs
IM LBS服务器地址,通过它获取IM link 地址信息 填http/https地址
int dedicatedClusteFlag
是否为专属集群{1(是), 0(否)}
String nosDownload
NOS下载地址的host,用于拼接最终获得的文件URL地址,也支持该host替换成下载加速域名/地址 nosAccess...
IPVersion ipProtocolVersion
IP协议版本{0(IPV4), 1(IPV6), 2(Auto, SDK测试后自行选择, 存在性能损耗)}。 默认: 0(IPV4) 非对称加密 ...
static ServerAddresses fromJson(@Nullable JSONObject object)
Set< String > nosDownloadSet
每个元素为使用过的NOS下载地址的特征以及桶名是否在host中组成的Pair对象 如new Pair("nim.nos.netease.com", true), new Pair("nos.netease.com/nim", false)等
AsymmetricType negoKeyNeca
"交换密钥"协议加密算法 {1(RSA),2(SM2)}, def:1(RSA) 非对称加密
String nosAccess
NOS下载加速域名/地址,用于替换NOS下载url中的 nosDownload。 提供两种方式: 1) [4.4.0+开始支持]模板方式:填写云信规定的两种模板:{bucket}.nosdn.127.net/{object} 或者 nosdn.127.net/{bucket}/{object},其中 {bucket} 和 {object} 作为标识符,必须填写。域名部分可以替换为您申请的加速域名。 2) [所有版本支持]非模板方式:填写用于加速的 http/https地址,例如:http://111.222.111.22:9090.
String module
连接云信服务器加密数据通道的公钥参数1 rsaModulus
String nosUploadDefaultLink
NOS上传默认的link服务器地址,当NOS LBS不可用时先连接该地址 填http/https地址
boolean nosCdnEnable
是否优先使用Cdn域名进行NOS下载
String compassDataEndpoint
数据上报端点
String probeIpv6Url
探测ipv6地址类型使用的url, IPProtVersion == 2或3 时生效
String probeIpv4Url
探测ipv4地址类型使用的url, IPProtVersion == 2或3 时生效
SymmetryType commEnca
通信加密算法 {1(RC4), 2(AES128), 4(SM4)} 默认: 1(RC4) 对称加密
String negoKeyEncaKeyParta
"交换密钥"协议加密算法密钥 part A 自定义时则必填 BigNumHex string 不含0x RSA: module, SM2: X
String nosUpload
NOS上传服务器主机地址(仅nosSupportHttps=true时有效,用作https上传时的域名校验及http header host字段...
List< String > defaultLinkBackup
IM 默认的link服务器地址不可用时,连接这些地址 填"IP/Host:PORT".
String nosUploadLbs
NOS上传LBS服务器地址 填http/https地址
云信私有化服务器配置项
String bdServerAddress
云信数据统计服务器地址
String linkIpv6
ipv6的缺省连接地址
int publicKeyVersion
连接云信服务器加密数据通道的公钥的版本号(默认0)
String defaultLink
IM 默认的link服务器地址,当IM LBS不可用时先连接该地址 填"IP/Host:PORT".
List< String > chatRoomLbsList
ChatRoom LBS服务器地址,通过它获取ChatRoom link 地址信息 填http/https地址
List< String > lbsBackup
备用IM LBS服务器地址,通过它获取IM link 地址信息 填http/https地址
boolean nosSupportHttps
NOS上传是否需要支持https。SDK 3.2版本后默认支持https,同时需要配置 nosUpload!