andriod中对OkhttpClient请求的封装及

为了不重复去写代码,对okhttpClient请求做封装,包含了如何跳过请求证书验证,以及请求拦截器中对报文加密,响应拦截器中报文解密的实现如下:
1、modle的build.gradle添加依赖
implementation 'com.squareup.okhttp3:okhttp:3.7.0'
implementation 'com.squareup.retrofit2:retrofit:2.9.0'
implementation "com.squareup.retrofit2:converter-gson:2.9.0"
implementation 'com.alibaba:fastjson:1.2.4'
2、RequestService代码如下:

import retrofit2.Call;
import okhttp3.RequestBody;
import okhttp3.ResponseBody;
import retrofit2.http.Body;
import retrofit2.http.GET;
import retrofit2.http.Headers;
import retrofit2.http.POST;
import retrofit2.http.Path;
import retrofit2.http.Streaming;
import retrofit2.http.Url;

/**
 * 作者:created by fanHongJiao
 */
public class RequestService {
    public interface commonService {
        @Headers({"Content-type:application/json;charset=UTF-8"})
        @POST("{reqPath}")
        Call<ResponseBody> createCommit(@Path(value = "reqPath", encoded = true) String path, @Body RequestBody route);

        @Headers({"Content-type:application/json;charset=UTF-8"})
        @POST("")
        Call<ResponseBody> createUilCommit(@Url String url, @Body RequestBody route);
    }

    public interface downloadFileService {
        @Streaming
        @GET
        Call<ResponseBody> downloadFileWithDynamicUrlSync(@Url String fileUrl);
    }

}

3、RequestBodyFactory代码如下

package okhttpclientDemo.utils;
import org.json.JSONException;
import org.json.JSONObject;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import okhttp3.MediaType;
import okhttp3.RequestBody;
import okhttp3.ResponseBody;
import retrofit2.Call;

/**
 * 作者:created by fanHongJiao
 */
public class RequestBodyFactory {
    public static Call<ResponseBody> requestNet(Object body,String reqPath) throws JSONException {
        RequestService.commonService service=NetManger.getInstance().CreateService(RequestService.commonService.class);
        JSONObject jsonObject=new JSONObject();
        JSONObject heard=new JSONObject();
        Date time= Calendar.getInstance().getTime();
        SimpleDateFormat format=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
        heard.put("time",format.format(time));
        jsonObject.put("heard",heard);
        RequestBody requestBody=RequestBody.create(MediaType.parse("Content-Type,application/json"),jsonObject.toString());
        Call<ResponseBody> commit=service.createCommit(reqPath,requestBody);
        return commit;
    }
}

4、NetManger代码

package okhttpclientDemo.utils;

import com.google.gson.Gson;
import com.google.gson.GsonBuilder;

import java.security.KeyManagementException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.util.concurrent.TimeUnit;
import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import okhttp3.OkHttpClient;
import okhttpclientDemo.utils.e2ee.RequestInterceptor;
import okhttpclientDemo.utils.e2ee.ResponseInterceptor;
import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;

/**
 * 作者:created by fanHongJiao
 */
public class NetManger {
    private static NetManger instance;
    Retrofit retrofit;

    public static NetManger getInstance() {
        if (instance == null) {
            instance = new NetManger();
        }
        return instance;
    }

    private NetManger() {

        //跳过http验证
        X509TrustManager xtm = new X509TrustManager() {
            @Override
            public void checkClientTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {

            }

            @Override
            public void checkServerTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {

            }

            @Override
            public X509Certificate[] getAcceptedIssuers() {
                return new X509Certificate[0];
            }
        };

        SSLContext sslContext = null;
        try {
            sslContext = SSLContext.getInstance("SSL");
            sslContext.init(null, new TrustManager[]{xtm}, new SecureRandom());

        } catch (NoSuchAlgorithmException | KeyManagementException e) {
            e.printStackTrace();
        }

        HostnameVerifier DO_NOT_VERIFY = new HostnameVerifier() {
            @Override
            public boolean verify(String s, SSLSession sslSession) {
                return true;
            }
        };

        OkHttpClient client = new OkHttpClient().newBuilder()
                .sslSocketFactory(sslContext.getSocketFactory())//跳过hhtp验证
                .hostnameVerifier(DO_NOT_VERIFY)
                .addInterceptor(new RequestInterceptor())//拦截器
                .addInterceptor(new ResponseInterceptor())
                .connectTimeout(5, TimeUnit.SECONDS)//链接超时时间
                .readTimeout(120, TimeUnit.SECONDS)
                .callTimeout(120, TimeUnit.SECONDS)
                .build();

        //配置你的gson
        Gson gson = new GsonBuilder()
                .setDateFormat("yyyy-MM-dd hh:mm:ss")
                .create();
        retrofit = new Retrofit.Builder()
                .baseUrl(Constant.BaseUrl)//url
                .addConverterFactory(GsonConverterFactory.create(gson))
                .client(client)
                .build();
    }

    public <T> T CreateService(Class tClass) {
        T service = (T) retrofit.create(tClass);
        return service;
    }

}

5、IResponse代码如下:

package okhttpclientDemo.utils;

import org.json.JSONObject;

/**
 *
 * 作者:created by fanHongJiao
 */
public interface IResponse {
    void success(JSONObject object);
    void failed(String code,String message,Object obj);
}

6、HttpRequestManager代码如下:

package okhttpclientDemo.utils;

import org.json.JSONException;
import org.json.JSONObject;
import java.io.IOException;
import okhttp3.ResponseBody;
import retrofit2.Call;
import retrofit2.Callback;
import retrofit2.Response;

/**
 *
 * 作者:created by fanHongJiao
 */
public class HttpRequestManager {
    public static final void postRequestObject(JSONObject body,String path,final IResponse callBack) throws JSONException {
        Call<ResponseBody>responseBodyCall=RequestBodyFactory.requestNet(body,path);
        responseBodyCall.enqueue(new Callback<ResponseBody>() {
            @Override
            public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {
                try {
                    String string = response.body().string();
                    callBack.success(body);
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

            @Override
            public void onFailure(Call<ResponseBody> call, Throwable t) {
                callBack.failed("-3", t.getMessage(), t);
                //连接失败
            }
        });
    }
}

7、Constant代码如下:

package okhttpclientDemo.utils;

/**
 *常量定义
 * 作者:created by fanHongJiao
 */
public class Constant {
    public static  final  String BaseUrl="https://220.241.39.45/cibs/sit/";
    public static  final  String requestUrl="custpc/generateGetSessionKey.do";
}

8、E2eeUtils用于模拟加解密,具体如何加密根据需求

package okhttpclientDemo.utils.e2ee;

/**
 * 模仿加密,如何加密根据需求添加代码
 * 作者:created by fanHongJiao
 */
public class E2eeUtils {
    public E2eeUtils() {
    }

    /**
     * 加密操作
     * @param bytes
     * @return
     */
    public String encrypt(byte[] bytes) {
        String enStr = null;
        return enStr;
    }

    /**
     * 解密
     * @param bytes
     * @return
     */
    public String decrypt(byte[] bytes){
        String decStr=null;
        return decStr;
    }
}

9、RequestInterceptor请求拦截器,在请求发出之前执行,用于放加密,统一的请求头参数代码如下:

package okhttpclientDemo.utils.e2ee;
import java.io.IOException;
import java.nio.charset.Charset;
import okhttp3.MediaType;
import okhttpclientDemo.utils.e2ee.E2eeUtils;
import okio.Buffer;
import okhttp3.Interceptor;
import okhttp3.Request;
import okhttp3.RequestBody;
import okhttp3.Response;
/**
 * 请求拦截器,可对报文加密, 或者添加公共参数等
 * 作者:created by fanHongJiao
 */
public class RequestInterceptor implements Interceptor {
    private static boolean isE2ee = false;//是否加密,true表示需要加密
    private static final String CHARSET = "UTF-8";

    @Override
    public Response intercept(Chain chain) throws IOException {
        Request request = chain.request();
        RequestBody requestBody = request.body();
        String requestUrl = request.url().toString();
        //判断是否需要加密
        if (isE2ee) {
            Buffer buffer = new Buffer();
            //做加密,以简单的md5加密为例
            E2eeUtils e2eeUtils = new E2eeUtils();
            requestBody.writeTo(buffer);
            Charset charset;
            MediaType contentType = requestBody.contentType();
            charset = contentType.charset(Charset.forName("UTF-8"));
            String requestString = buffer.readString(charset);//读取请求体
            String encrytParams = null;
            encrytParams = e2eeUtils.encrypt(requestString.getBytes(CHARSET));//加密

            RequestBody body = chain.request().body();
            MediaType contentType1 = body.contentType();
            if(encrytParams!=null){
            requestBody = RequestBody.create(contentType1, encrytParams.trim());}
            request = chain.request()
                    .newBuilder()
                    .header("Accept-Language", "en")//okhttp请求头提交语言
                    .post(requestBody)
                    .build();
        }
        return chain.proceed(request);
    }
}

10、ResponseInterceptor请求数据返回时执行,可处理报文解密,代码如下:

package okhttpclientDemo.utils.e2ee;

import java.io.IOException;
import java.nio.charset.Charset;
import okhttp3.Interceptor;
import okhttp3.MediaType;
import okhttp3.Request;
import okhttp3.Response;
import okhttp3.ResponseBody;
import okhttpclientDemo.utils.e2ee.E2eeUtils;
import okio.Buffer;
import okio.BufferedSource;
/**
 * 请求响应拦截器,处理返回的加密报文得解密
 * 作者:created by fanHongJiao
 */
public class ResponseInterceptor implements Interceptor {
    private static boolean isE2ee = false;//是否解密,true表示需要解密
    private static final String CHARSET = "UTF-8";

    @Override
    public Response intercept(Chain chain) throws IOException {
        Request request=chain.request();
        Response response=chain.proceed(request);
        ResponseBody responseBody=response.body();
        if(responseBody!=null){
            //获取响应body
            BufferedSource source=responseBody.source();
            source.request(Long.MAX_VALUE);
            Buffer buffer=source.buffer();
            Charset charset=Charset.forName("UTF-8");
            MediaType contentType=responseBody.contentType();
            charset=contentType.charset(charset);
            String bodyString=buffer.clone().readString(charset);
            String responseData=null;
            if(isE2ee){
                E2eeUtils e2eeUtils=new E2eeUtils();
                responseData=e2eeUtils.decrypt(bodyString.getBytes(CHARSET));//解密
                if(responseData!=null) {
                    ResponseBody newResponseBody = ResponseBody.create(contentType, responseData);

                response=response
                        .newBuilder()
                        .body(newResponseBody)
                        .build();
                return response;
                }

            }
        }
        return response;
    }
}

11、OkHttpClientActivity,测试请求页面代码如下:

package okhttpclientDemo;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import com.example.viewpaerdemo.R;
import org.json.JSONException;
import org.json.JSONObject;
import okhttpclientDemo.utils.Constant;
import okhttpclientDemo.utils.HttpRequestManager;
import okhttpclientDemo.utils.IResponse;
public class OkHttpClientActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_ok_http_client);
        JSONObject body=new JSONObject();
        try {
            body.put("heard","heard");
        } catch (JSONException e) {
            e.printStackTrace();
        }
        try {
            HttpRequestManager.postRequestObject(body, Constant.requestUrl, new IResponse() {
                @Override
                public void success(JSONObject object) {
                    Log.e("success:",object.toString());
                }

                @Override
                public void failed(String code, String message, Object obj) {
                    Log.e("failed:",obj.toString());
                }
            });
        } catch (JSONException e) {
            e.printStackTrace();
        }
    }
}

完结。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容