请求过程:
1.创建OkHttpClient
2.创建Request
3.同步或异步发送请求,并进过Interceptors处理
4.得到Response
Request是一个载体,封装了一个请求的Header Method url body
Response:响应是对请求的回复,包括状态码,http头和主体部分
Call:call抽象出一个满足请求头的模型,尽管中间可能会有多个请求或响应,执行call的的方式有两种,同步或异步
发起请求:
Request request = new Request.Builder().url(url).build();
Response response = client.newCall(request).execute();
response.body().string();
1.同步请求网络:execute()
2.异步请求网络:enqueue(callBack)
创建请求头
创建OkhttpClient的时候有两种方式:(查看okhttp的源码可以找到以下两个部分)
一是:默认的
public OkHttpClient() {
this(new Builder());
}
二是:通过内部类Builder自定义 http请求的client
public Builder() {
dispatcher = new Dispatcher(); // 由call代表的请求的分发器
protocols = DEFAULT_PROTOCOLS; // 默认的协议 http2 http1.1
connectionSpecs = DEFAULT_CONNECTION_SPECS; // 设置连接时支持的tls层协议以及不进行数据加密
eventListenerFactory = EventListener.factory(EventListener.NONE);
proxySelector = ProxySelector.getDefault();
cookieJar = CookieJar.NO_COOKIES;
socketFactory = SocketFactory.getDefault(); // socket生产工厂
hostnameVerifier = OkHostnameVerifier.INSTANCE;
certificatePinner = CertificatePinner.DEFAULT;
proxyAuthenticator = Authenticator.NONE;
authenticator = Authenticator.NONE;
connectionPool = new ConnectionPool(); //连接池 支持多路复用
dns = Dns.SYSTEM;
followSslRedirects = true;
followRedirects = true;
retryOnConnectionFailure = true;
connectTimeout = 10_000;
readTimeout = 10_000;
writeTimeout = 10_000;
pingInterval = 0;
}
比如可以设置OkhttpClient的:
1.connectTimeout(long timeout,TimeUnit unit) 连接超时时间
2.readTimeout(long timeout,TimeUnit unit) 连接的读取超时时间
3.writeTimeout(long timeout,TimeUnit unit) 写入超时时间
最后通过build方法创建OkHttpClient
public OkHttpClient build() {
return new OkHttpClient(this);
}
比如创建一个有连接超时和读取超时的client请求头:
OkHttpClient okHttpClient = new OkHttpClient.Builder()
.connectTimeout(4, TimeUnit.MINUTES)
.readTimeout(4, TimeUnit.MINUTES)
.build();
在源码里可以找到更多的方法:参考博客:https://blog.youkuaiyun.com/cdye_1234/article/details/80289967
创建请求体
Get无请求体
Post的请求体:(网址:https://www.jianshu.com/p/1133389c1f75)
RequestBody --json数据提交
FormBody--表单数据提交(RequestBody 的子类)
MultipartBody--文件上传(RequestBody 的子类)