安卓防抓包简单处理

网络相关

判断当前系统是否设置了代理

private boolean isProxy() {
    String proxyAddress = "";
    int proxyPort = 0;
    if (Build.VERSION.SDK_INT > Build.VERSION_CODES.ICE_CREAM_SANDWICH) {            proxyAddress = System.getProperty("http.proxyHost");
        String proxyPortString = System.getProperty("http.proxyPort");
        proxyPort = Integer.parseInt((proxyPortString != null ? proxyPortString : "-1"));
    } else {
        proxyAddress = android.net.Proxy.getHost(this);
        proxyPort = android.net.Proxy.getPort(this);
    }        
    if (!TextUtils.isEmpty(proxyAddress) && proxyPort != -1) {
        return true;
    }        
    return false;
}

使用OkHttp设置简单的不允许抓包

  抓包工具,本质上就是利用中间人攻击的方式,通过这个中间人获取到通信的数据。
  而利用这些工具抓包的前提,都是在设备上,设置代理,通常我们直接在 WiFi 连接页面,设置代理即可。
  而对于一些常用的网络库,其实是提供了我们设置的代理的接口,我们只需要将其设置成无代理的模式,它就不会去应用系统默认的代理了。
  拿比较常用的 OkHttp 来举例,在初始化的时候,就可以通过proxy() 方法,为 OkHttp 设置一个代理。设置为proxy(Proxy.NO_PROXY),就是不使用代理的模式,它就不会从系统中,读取代理信息,进行网络请求。而是会忽略掉它,直接发送网络请求。以这样的方式,就可以阻止第三方使用 Fiddler 或 Charles 进行抓包。
  代码如下:

OkHttpClient okHttpClient = new OkHttpClient.Builder()
            .proxy(Proxy.NO_PROXY)
            .build();
Request request = new Request.Builder()
        .url("https://wanandroid.com/wxarticle/chapters/json ")                
        .build();
Call call = okHttpClient.newCall(request);
call.enqueue(new Callback() {
    @Override
    public void onFailure(Call call, IOException e) {
        Log.e("===MockingJay===", "getNoHttpData    onFailure...");
    }

    @Override
    public void onResponse(Call call, Response response) throws IOException {
        Log.e("===MockingJay===", "getNoHttpData    onResponse...");
        String str = response.body().string();
        Log.e("===MockingJay===", "getNoHttpData    str:" + str);
    }
});
个人微信联系方式:Kang_01123,从事安卓开发,希望一起前行,一起进阶

你可能感兴趣的:(安卓防抓包简单处理)