相关疑难解决方法(0)

javax.net.ssl.SSLException:读取错误:ssl = 0x9524b800:系统调用期间的I/O错误,同级连接重置

在过去的几周里,我们的客户开始看到100个这样的"SSLException错误 - 连接重置连接",我无法弄清楚为什么

  1. 我们在okhttp上使用Retrofit,没有特殊配置

    public class OkHttpClientProvider implements IOkHttpClientProvider {
    
        OkHttpClient okHttpClient;
    
        public OkHttpClientProvider() {
            this.okHttpClient = createClient();
        }
    
        public OkHttpClient getOkHttpClient() {
            return this.okHttpClient;
        }
    
        private OkHttpClient createClient() {
            return new OkHttpClient();
        }
    }
    
    Run Code Online (Sandbox Code Playgroud)

上述客户提供商是单身人士.RestAdapter是使用这个注入的客户端构建的(我们使用匕首) -

RestAdapter.Builder restAdapterBuilder = new RestAdapter.Builder()
                                        .setConverter(converter)
                                        .setEndpoint(networkRequestDetails.getServerUrl())
                                        .setClient(new OkClient(okHttpClientProvider.getOkHttpClient()))
                                        .setErrorHandler(new NetworkSynchronousErrorHandler(eventBus))
                                        );
Run Code Online (Sandbox Code Playgroud)

基于堆栈溢出解决方案,我发现了 -

  1. 服务器上的保持活动持续时间为180秒,OkHttp的默认值为300秒

  2. 服务器在其标头中返回"Connection:close",但客户端请求发送"Connection:keepAlive"

  3. 服务器支持TLS 1.0/1.1/1.2并使用Open SSL

  4. 我们的服务器最近已转移到另一个托管服务提供商的另一个地理位置,因此我不知道这些是否是DNS故障

  5. 我们尝试调整keepAlive之类的东西,在服务器上重新配置OpenSSL,但由于某种原因,Android客户端不断收到此错误

  6. 当您尝试使用应用程序发布内容或拉动刷新时,它会立即发生,并且不会出现任何延迟(在发生此异常之前,它甚至不会进入网络或延迟,这意味着连接已经断开).但尝试多次以某种方式"修复它",我们取得了成功.它会在以后再次发生

  7. 我们已经在服务器上使我们的DNS条目无效,看看这是否是由它引起的,但是没有帮助

  8. 它主要发生在LTE上,但我也在Wifi上看过它

我不想禁用keep alive,因为大多数现代客户都不这样做.此外,我们正在使用OkHttp 2.4,这是后冰淇淋三明治设备的一个问题,所以我希望它应该照顾这些潜在的网络问题.iOS客户端也获得了这些例外但接近100倍(iOS客户端使用AFNetworking 2.0).我正在努力寻找新的东西,在这一点上尝试,任何帮助/想法?

更新 - 通过okhttp添加完整堆栈跟踪

      retrofit.RetrofitError: Read error: ssl=0x9dd07200: I/O error during system call, Connection reset by …
Run Code Online (Sandbox Code Playgroud)

ssl android http retrofit okhttp

53
推荐指数
3
解决办法
7万
查看次数

SSLException由于亚马逊服务的上传项目

我将我的文件从android上传到aws服务.我这样配置:

  AwsMetadata awsMetadata = resultData.getParcelable(Params.CommandMessage.EXTRA_MESSAGE);
        AWSCredentials awsCredentials = new BasicAWSCredentials(
                awsMetadata.getAccountId(),
                awsMetadata.getSecretKey()
        );
        // set up region
        TransferManager transferManager = new TransferManager(awsCredentials);
        Region region = Region.getRegion(Regions.fromName(awsMetadata.getRegionEndpoint()));
        transferManager.getAmazonS3Client().setRegion(region);


        final MediaItem mediaItem = datasource.get(0);
        Log.d(App.TAG, "File is exists: "
                + mediaItem.getContentUri() + " "
                + new File(mediaItem.getContentUri()).exists());

        // prepare file for upload
        PutObjectRequest putObjectRequest = new PutObjectRequest(
                awsMetadata.getBucketName(),
                awsMetadata.getSecretKey(),
                new File(mediaItem.getContentUri())
        );


        Log.d(App.TAG, "Total data: " + mediaItem.getSize());
        Upload upload = transferManager.upload(putObjectRequest, new S3ProgressListener() {

            private int totalTransfered = 0;

            @Override
            public …
Run Code Online (Sandbox Code Playgroud)

android amazon-web-services sslexception

7
推荐指数
1
解决办法
4161
查看次数