app防止被抓包,包括Fiddler,Charles,HttpCanary等工具

防抓包方式一:

在客戶端請求網絡之前先判斷手機網絡是否使用了代理,如果使用了代理就不請求接口。
java版:

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

kotlin版:

private fun checkWifiProxy(): Boolean {
        val IS_ICS_OR_LATER = Build.VERSION.SDK_INT >= Build.VERSION_CODES.ICE_CREAM_SANDWICH
        val proxyAddress: String?
        val proxyPort: Int?
        if (IS_ICS_OR_LATER) {
            proxyAddress = System.getProperty("http.proxyHost")
            val portStr = System.getProperty("http.proxyPort")
            proxyPort = Integer.parseInt(portStr ?: "-1")
        } else {
            proxyAddress = android.net.Proxy.getHost(this)
            proxyPort = android.net.Proxy.getPort(this)
        }
        Log.i("cxmyDev","proxyAddress : ${proxyAddress}, prot : ${proxyPort}")
        return !TextUtils.isEmpty(proxyAddress) && proxyPort != -1
    }

缺點顯而易見:如果使用了代理,就不允許請求接口。那麼因爲其他原因使用了代理的用戶就用不了這個App了。

防抓包方式二:

網絡庫大都是提供了我們設置的代理的接口,我們只需要將其設置成無代理的模式,它就不會去應用系統默認的代理了。我用的是okgo,增加了builder.proxy(Proxy.NO_PROXY);這句代碼,如圖:
在這裏插入圖片描述拓展:反編譯的話可以拿到代碼,就可以看到域名了,後續介紹反編譯和加固。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章