问题发生背景:
由于正式环境的机器,无法直接访问外网,需要通过正向代理来实现钉钉自定义机器人发送消息的功能。 很简单的一个需求,但是实现的时候发现钉钉自定义机器人提供的SDK有个bug,无法使用proxy。
代码环境:
SDK
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>alibaba-dingtalk-service-sdk</artifactId>
<version>1.0.1</version>
</dependency>
问题复现:
首先 我们通过利用SDK提供的DefaultDingTalkClient
类来调用发送消息的接口,而DefaultDingTalkClient
这个类继承于DefaultTaobaoClient
, DefaultTaobaoClient
有 Proxy属性
public class DefaultDingTalkClient extends DefaultTaobaoClient implements DingTalkClient {
****** 省略了代码
}
public class DefaultTaobaoClient implements TaobaoClient {
****** 省略了代码
private Proxy proxy; //代理类
public Proxy getProxy() {
return proxy;
}
public void setProxy(Proxy proxy) {
this.proxy = proxy;
}
}
那么我们遇到的问题解决方案看似很简单,直接setProxy,将代理设置好即可实现。
实际操作后,发现报错如下
Caused by: java.net.SocketTimeoutException: connect timed out
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
超时了? 登上服务器后,ping了代理的地址,是没问题的,那么问题肯定出在并没有真的使用代理去访问外网。
问题探索:
出了问题,那么看下源码怎么回事吧。跟随断点进去,DefaultDingTalkClient
复写了几个DefaultTaobaoClient
的方法,复写的方法中,最终要不就是调用父类,要不就是调用com.dingtalk.api.DefaultDingTalkClient#executeOApi(com.taobao.api.TaobaoRequest<T>, java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String)
这个方法,
public class DefaultDingTalkClient extends DefaultTaobaoClient implements DingTalkClient {
public <T extends TaobaoResponse> T execute(TaobaoRequest<T> request, String accessKey, String accessSecret) throws ApiException {
return execute(request, accessKey, accessSecret, null,null);
}
public <T extends TaobaoResponse> T execute(TaobaoRequest<T> request, String accessKey, String accessSecret, String suiteTicket) throws ApiException {
return execute(request, accessKey, accessSecret, suiteTicket,null);
}
public <T extends