安卓防抓包简单处理

网络相关

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

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,从事安卓开发,希望一起前行,一起进阶
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值