Android网络编程——https 不验证证书方式(信任所有证书)

         前面写了http的联网方式,Android平台上经常有使用https的需求,对于https服务器使用的根证书是受信任的证书的话,实现https是非常简单的,直接用httpclient库就行了,与使用http几乎没有区别。但是在大多数情况下,服务器所使用的根证书是自签名的,或者签名机构不在设备的信任证书列表中,这样使用httpclient进行https连接就会失败。解决这个问题的办法有两种,一是在发起https连接之前将服务器证书加到httpclient的信任证书列表中,这个相对来说比较复杂一些,很容易出错;另一种办法是让httpclient信任所有的服务器证书,这种办法相对来说简单很多,但安全性则差一些,但在某些场合下有一定的应用场景。这一篇主要实现httpclient信任所有的服务器证书。

      直接给出代码:

     

public class HttpsTestActivity extends Activity {
    /** Called when the activity is first created. */
	private TextView text;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        text=(TextView)findViewById(R.id.textView1);
        GetHttps();
    }
    
    private void GetHttps(){
    	String https = "https://www.google.com.hk";
        try{
        	SSLContext sc = SSLContext.getInstance("TLS");
            sc.init(null, new TrustManager[]{new MyTrustManager()}, new SecureRandom());
            HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
            HttpsURLConnection.setDefaultHostnameVerifier(new MyHostnameVerifier());
            HttpsURLConnection conn = (HttpsURLConnection)new URL(https).openConnection();
            conn.setDoOutput(true);
            conn.setDoInput(true);
            conn.connect();
            BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream())); 
            StringBuffer sb = new StringBuffer(); 
            String line; 
            while ((line = br.readLine()) != null) 
                sb.append(line);                
            text.setText(sb.toString());
           }catch(Exception e){
                Log.e(this.getClass().getName(), e.getMessage());
           }      
     }



      private class MyHostnameVerifier implements HostnameVerifier{
            @Override
            public boolean verify(String hostname, SSLSession session) {
                    // TODO Auto-generated method stub
                    return true;
            }

       }

       private class MyTrustManager implements X509TrustManager{
            @Override
            public void checkClientTrusted(X509Certificate[] chain, String authType)
                            throws CertificateException {
                    // TODO Auto-generated method stub  
            }
            @Override
            public void checkServerTrusted(X509Certificate[] chain, String authType)

                            throws CertificateException {
                    // TODO Auto-generated method stub    
            }
            @Override
            public X509Certificate[] getAcceptedIssuers() {
                    // TODO Auto-generated method stub
                    return null;
            }        

      }   
}

使用HttpsURLConnection时需要实现HostnameVerifier 和 X509TrustManager,这两个实现是必须的,要不会报安全验证异常。


/**
* @author 张兴业
* 邮箱:xy-zhang#163.com
* android开发进阶群:278401545
*
*/

### 解决 Android 开发中的 "unable to find valid certification path to requested target" 错误 当开发者在使用 Android Studio 构建项目时遇到 `unable to find valid certification path to requested target` 的错误提示,通常是因为 Java 未能验证 HTTPS 请求的目标服务器的身份认证链。此问题可能由多种原因引起,包括但限于本地网络配置、Gradle 配置文件设置以及所使用的仓库地址。 #### 方法一:更新 Gradle 和插件版本 确保正在使用最新版的 Gradle 及其插件可以有效减少因旧版本软件中存在的 bug 或兼容性而引发的问题。对于新创建的项目,默认情况下会采用较新的稳定版本;但对于遗留项目,则需手动检查并升级至合适的新版本[^1]。 ```groovy // build.gradle (Project level) buildscript { repositories { google() mavenCentral() // 替换 jcenter(), 因为 JFrog 宣布关闭 Bintray/JCenter 服务 } } allprojects { repositories { google() mavenCentral() } } ``` #### 方法二:调整 IDE 中的安全协议选项 如果上述方法仍无法解决问题,尝试通过修改 JVM 参数来允许较低级别的 SSL/TLS 协议握手过程。可以在启动参数里加入 `-Dhttps.protocols=TLSv1,TLSv1.1,TLSv1.2` 来放宽安全策略限制[^2]。 #### 方法三:安装自定义 CA 根证书 针对特定的企业内部环境或是某些特殊场景下,可能存在自签名或其他非公共CA签发的服务端SSL证书的情况。此时可考虑将该类证书作为受信实体添加进JVM的信任库中。具体操作步骤如下: 1. 下载目标站点提供的 `.crt` 文件; 2. 使用命令行工具 keytool 导入证书到 cacerts 文件夹内: ```bash sudo keytool -importcert -file /path/to/certificate.crt -alias myCertAlias -keystore $JAVA_HOME/jre/lib/security/cacerts ``` 3. 输入默认密码 `changeit` 并确认完成导入动作[^3]。 #### 方法四:切换 Maven 仓库源 由于部分国外镜像站在国内访问速度慢甚至可达,建议更换国内知名的Maven中央仓库镜像如阿里云等,从而提高依赖项解析效率的同时也规避了潜在的安全隐患[^4]。 ```groovy maven { url 'https://maven.aliyun.com/repository/public' } ```
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值