Android SSL Pinning(防止中间人攻击)

为了防止中间人攻击,我们需要证书固定技术

Android:https://developer.android.com/training/articles/security-ssl.html#Pinning
OKHttp CertificatePinner: https://square.github.io/okhttp/3.x/okhttp/okhttp3/CertificatePinner.html
OKHttp Certificate Pinning: https://square.github.io/okhttp/https/#certificate-pinning-kt-java

通过证书固定的技术,应用可以更好地保护自己免受以欺诈方式发放的证书的攻击。

在OKhttp中实现SSL Pinning是十分简单的

public final class CertificatePinning {
  private final OkHttpClient client = new OkHttpClient.Builder()
      .certificatePinner(
          new CertificatePinner.Builder()
              .add("publicobject.com", "sha256/Vjs8r4z+80wjNcr1YKepWQboSIRi63WsWXhIMN+eWys=")
              .build())
      .build();

  public void run() throws Exception {
    Request request = new Request.Builder()
        .url("https://publicobject.com/robots.txt")
        .build();

    try (Response response = client.newCall(request).execute()) {
      if (!response.isSuccessful()) throw new IOException("Unexpected code " + response);

      for (Certificate certificate : response.handshake().peerCertificates()) {
        System.out.println(CertificatePinner.pin(certificate));
      }
    }
  }

  public static void main(String... args) throws Exception {
    new CertificatePinning().run();
  }
}

另外从Android 24起,支持SSL Pinning是一件十分简单的事情,在AndroidManifest.xml file中指定`configuration file

<application
    android:networkSecurityConfig="@xml/network_security_config"
    >
</application>
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
    <domain-config>
        <domain includeSubdomains="true">appmattus.com</domain>
        <pin-set>
            <pin digest="SHA-256">4hw5tz+scE+TW+mlai5YipDfFWn1dqvfLG+nU7tq1V8=</pin>
            <pin digest="SHA-256">YLh1dUR9y6Kja30RrAn7JKnbQG/uEtLMkBgFF2Fuihg=</pin>
        </pin-set>
    </domain-config>
</network-security-config>

更多集成方式(Retrofit / Picasso / Volley)请参考:Android Security: SSL Pinning

版权声明:
作者:Joe.Ye
链接:https://www.appblog.cn/index.php/2023/03/25/android-ssl-pinning-preventing-man-in-the-middle-attacks/
来源:APP全栈技术分享
文章版权归作者所有,未经允许请勿转载。

THE END
分享
二维码
打赏
海报
Android SSL Pinning(防止中间人攻击)
为了防止中间人攻击,我们需要证书固定技术 Android:https://developer.android.com/training/articles/security-ssl.html#Pinning OKHttp CertificatePinner……
<<上一篇
下一篇>>
文章目录
关闭
目 录