Retrofit使用https

最近CTO使用第三方app评测工具检测到项目中没有使用https。接口的请求地址都是https的只是都设置了忽略证书…

证书

在PC上https的证书是cer格式,但是Android的似乎不支持,反正我使用cer的证书报了"Trust anchor for certification path not found"这个错误。网上看到有人将cer证书转换成bks证书问题就完美解决了。

BKS证书制作

keytool -importcert -v -trustcacerts -alias 位置1
-file 位置2
-keystore 位置3 -storetype BKS
-providerclass org.bouncycastle.jce.provider.BouncyCastleProvider
-providerpath 位置4 
-storepass 位置5

位置1 给你的新证书起的别名;
位置2 cer证书的本地路径;
位置3 生成的bks证书存储的路径;
位置4 步骤1中下载的jar文件所在的本地路径;
位置5 设置一个密码,代码中加载证书会使用;

代码中使用bks文件

  1. 将bks文件复制到raw文件夹里(也可以放在assets文件夹里,只是获取流的方法不一样)
  2. 获取SSLSocketFactory
    class HttpsUtils {
        companion object {
            fun getSSLSocketFactory(context: Context): SSLSocketFactory {
                val certificate = context.resources.openRawResource(R.raw.xxx)
                val keyStore = KeyStore.getInstance("BKS")
                keyStore.load(certificate, "123456".toCharArray())
                certificate?.close()
                val sslContext = SSLContext.getInstance("TLS")
                val trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm())
                trustManagerFactory.init(keyStore)
                sslContext.init(null, trustManagerFactory.trustManagers, null)
                return sslContext.socketFactory
            }
        }
    }
    
  3. 在Retrofit中设置
    class RetrofitBuildUtils {
        companion object {
            fun retrofitBuild(context: Context): Retrofit {
                val retrofit: Retrofit
                val builder = OkHttpClient().newBuilder()       
                builder.sslSocketFactory(HttpsUtils.getSSLSocketFactory(context))
                val client = builder.build()
                retrofit = Retrofit.Builder()
                        .baseUrl(Config.getBaseUrl())
                        .addConverterFactory(GsonConverterFactory.create())
                        .client(client)
                        .build()
                return retrofit
            }
        }
    }
    

至此ok

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

得食猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值