在一些安全性较高的系统中,应用部署在内网环境中,但难免有些外部的接口需要调用,常见的安全策略是搭一个代理,所有的外网访问都通过代理通道,做到可控。
这里提供一种用okhttp3的实现方法
第一步,引入jar依赖
<!-- https://mvnrepository.com/artifact/com.squareup.okhttp3/okhttp -->
<dependency>
<groupId>com.squareup.okhttp3</groupId>
<artifactId>okhttp</artifactId>
<version>3.12.1</version>
</dependency>
第二步,找一个免费的代理做测试,推荐西刺免费代理IP,Ps. 很多不能用,多试几个
第三步,写代码,找个测试的网站,推荐IP测试地址,这个地址会返回你的访问IP
import okhttp3.Call;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import java.io.IOException;
import java.net.InetSocketAddress;
import java.net.Proxy;
public class LearnOkhttp {
public static void main(String[] args) {
String url = "http://exercise.kingname.info/exercise_middleware_ip";
// 代理
String hostname = "113.54.152.170";
int port = 8080;
//Proxy.Type 可以选择socket和http
Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress(hostname, port));
OkHttpClient.Builder builder = new OkHttpClient.Builder().proxy(proxy);
OkHttpClient okHttpClient = builder.build();
final Request request = new Request.Builder()
.url(url)
.build();
final Call call = okHttpClient.newCall(request);
new Thread(new Runnable() {
public void run() {
try {
Response response = call.execute();
System.out.println("run: " + response.body().string());
} catch (IOException e) {
e.printStackTrace();
}
}
}).start();
}
}