随笔 - 6  文章 - 0  评论 - 3  阅读 - 9184

解决cocos2d 热更是连不上https服务器

最近苹果宣布所有上架应用都要用https,我们后端走的是同一个函数,导致Android也要连接https.

百度了下,网上说客户端不需要做什么特殊处理,因为cocos本身是支持https的.但是服务端自建的证书是不行的.需要购买的证书才可以.

但是还有个问题,购买的证书,Android可以拿到服务器列表,但是热更新时连不上热更新的服务器.

下面是我的解决方法.(思路是绕过https验证,借鉴了网上的代码)

找到这个jar文件,这个是热更新时连接服务器的java文件编译后的文件.具体的路径在

cocos2d-x-3.13.1\cocos\platform\android\java\src\org\cocos2dx\lib

找到扩展名为.java的文件才能编辑,否则是编辑不了.

下面是我修改的代码部分.

复制代码
//內建类,下面会用到
public class SSLSocketFactor extends SSLSocketFactory {

        SSLContext sslContext = SSLContext.getInstance("TLS");
        
        public SSLSocketFactor(KeyStore truststore)
                throws NoSuchAlgorithmException, KeyManagementException, KeyStoreException, UnrecoverableKeyException {
            super(truststore);
            // TODO Auto-generated constructor stub
            TrustManager tm = new X509TrustManager() {  
                public void checkClientTrusted(X509Certificate[] chain,  
                        String authType) throws CertificateException {  
                }  
      
                public void checkServerTrusted(X509Certificate[] chain,  
                        String authType) throws CertificateException {  
                }  
      
                public X509Certificate[] getAcceptedIssuers() {  
                    return null;  
                }  
            };  
            sslContext.init(null, new TrustManager[] { tm }, null); 
        }
    }
复制代码
复制代码
//修改cocos2dx原有的方法
public static Cocos2dxDownloader createDownloader(int id, int timeoutInSeconds, String tempFileNameSufix, int countOfMaxProcessingTasks) {
        Cocos2dxDownloader downloader = new Cocos2dxDownloader();
        downloader._id = id;

        downloader._httpClient.setEnableRedirects(true);
        if (timeoutInSeconds > 0) {
            downloader._httpClient.setTimeout(timeoutInSeconds * 1000);
        }
        
        try {  
            //Secure Protocol implementation.    
            SSLContext ctx = SSLContext.getInstance("SSL");  
            //Implementation of a trust manager for X509 certificates    
            X509TrustManager tm = new X509TrustManager() {  
  
                public void checkClientTrusted(X509Certificate[] xcs,  
                        String string) throws CertificateException {  
  
                }  
  
                public void checkServerTrusted(X509Certificate[] xcs,  
                        String string) throws CertificateException {  
                }  
  
                public X509Certificate[] getAcceptedIssuers() {  
                    return null;  
                }  
            };  
            ctx.init(null, new TrustManager[] { tm }, null);  
            SSLSocketFactory ssf = new SSLSocketFactory(ctx);

//允许所有的验证通过            
ssf.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
downloader._httpClient.setSSLSocketFactory(ssf); } catch (Exception e) { e.printStackTrace(); } // downloader._httpClient.setMaxRetriesAndTimeout(3, timeoutInSeconds * 1000); downloader._httpClient.allowRetryExceptionClass(javax.net.ssl.SSLException.class); downloader._tempFileNameSufix = tempFileNameSufix; downloader._countOfMaxProcessingTasks = countOfMaxProcessingTasks; return downloader; }
复制代码

 

posted on   二二的路人甲  阅读(3505)  评论(3编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· 【.NET】调用本地 Deepseek 模型
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8

点击右上角即可分享
微信分享提示