How to fix HttpException: Connection closed before full header was received

FlutterHttpHttpsHttp HeadersConnection

Flutter Problem Overview


I have recently upgraded my flutter version in my app. But when I want to debug the application, it shows me the following error.

Error connecting to the service protocol: HttpException: Connection closed before full header was received, URI = http://127.0.0.1:50795/ws

Is there anyone facing the same issue after upgrading the flutter version? If is there any workaround, please share.

Flutter Solutions


Solution 1 - Flutter

Right now this issue is opened on github https://github.com/flutter/flutter/issues/32587

Temporarily you can solve this issue by switching to physical device instead of emulator https://stackoverflow.com/questions/21947834/how-to-test-android-apps-in-a-real-device-with-android-studio

Decision found on github (link upward)

> I've got a temporary work around, which I can use for now. The exception above is thrown when I run the emulator as a Pixel 3 Android 9.+ Target (Q API). I made up a second emulated device, a Pixel 2 Android 9.0 Target (28 API), and this target works fine. > >I'm also noticing that the Pixel 2 target takes up 8.5GB on Disk, while the Pixel 3 target only takes up 1.4GB. It makes me wonder if the Pixel 3 target is missing some important things.

Solution 2 - Flutter

The issue is mainly with Android Q.

You can downgrade your android version from Android Q to Android Pie.

which eventually leads to resolve the issue.

Solution 3 - Flutter

No solution unless the Flutter guys fix it.

I'm having it on one machine (Mac OS Mojave) even when connecting physical iOS devices. Of course it happens too with emulated Android devices (no matter which one).

I've also having this problem in a different computer (MacOS Mojave too) with a physical Android device (with a very old Android version: 5.1).

flutter clean does not fix it at all in my case(s).

Solution 4 - Flutter

First turning off your WiFi/Bluetooth.

And run below command:

flutter clean

And then quitting or restarting your emulator.

Solution 5 - Flutter

I figured out how to limit the connections on the underlying HttpClient of NetworkImage!

I globally overrode the HttpClient: (ref: Override HttpClient globally)

class MyHttpOverrides extends HttpOverrides {
  @override
  HttpClient createHttpClient(SecurityContext context) {
    return super.createHttpClient(context)
        ..maxConnectionsPerHost = 5;
  }
}


void main() {
  HttpOverrides.global = MyHttpOverrides();
  runApp(MyApp());
}

Ref : Connection closed...

Solution 6 - Flutter

This was my Problem And this worked For me:

PROBLEM
App would crash abruptly out of no where

CAUSE
I was using cached_network_image, When users uploaded heavy photos > 2MB, cache ran out of memory then app crashes. No warning.

SOLUTION
Use FadeInImage.memoryNetwork() or something else like NetworkImage() but not cache_network_image, it only works for less than 2 MB photos
thanks :)

Solution 7 - Flutter

In my case (error "HttpException: Connection closed before full header was received") the call was to an https address using Microsoft Internet Information Services as backend, in the SSL settings of the website in IIS i had mistakenly set "Client certificates: Accept" instead of "Client certificates: Ignore", setting "Ignore" solved the problem.

Solution 8 - Flutter

I've faced the same problem. Actually the problem was in the native code.

You can track the problem for android if you open an your_app/android project from Android Studio and run it, the same for iOS -> open ios project in XCode So after I've fixed it the app run as intended

I hope this'd help

Solution 9 - Flutter

Like Vitaly says ..

I am also struggling to force this error at all when building through Xcode for iOS and I imagine the same goes for Android with Android studio..

For iOS do flutter build ios --release and then open/run the project in Xcode

For Android do flutter build apk --release and then open/run the project in Android Studio

It seems to be an issue when debugging through flutter ... I will update this answer if I find otherwise but it seems stable with this method

Solution 10 - Flutter

I got the same error when I using Flutter with http package.

import 'package:http/http.dart' as http;
...
http.Response response =  http.get('url')

This was fine. But when I went to get the response.statusCode, it Error connecting error.

I found that I'm using SSR/v2Ray on my pc. I fix it by setting the proxy on Android Emulator extended controls panel.

Solution 11 - Flutter

I was getting the same issue in POST request while sending the Images as multipart
Resolved by using 
contentType: MediaType('image', 'jpeg') in the http.MultipartFile function 
e.g 
    request.files.add(
          http.MultipartFile(
            'image',
            stream,
            length,
            filename: basename(_image1.path),
            contentType: MediaType('image', 'jpeg'),
          ),
        );
where 'image' is the paramter name.
 
Don't forget to import 'package:http_parser/http_parser.dart';
for MediaType.
 
Other Mediatype which you can use are 
"image/png"
"image/jpg" 
"image/jpeg"
And I am sending this too in Header "Content-Type": "multipart/form-data"

Solution 12 - Flutter

Stopping the running application and clicking on run again worked for me.

Solution 13 - Flutter

You also need to mention your listening port which you define in your file like this final WebSocketChannel channel = IOWebSocketChannel.connect('wss://check.com:6043/');

It has solved my issue

Solution 14 - Flutter

I'm using Dio and faced the same issue so I have made this workaround by creating this interceptor which can be implemented too using the http interceptors.

You can check it here: https://stackoverflow.com/a/71415759/16314136

Solution 15 - Flutter

If you faced this issue on IOS build, follow th below steps

> Goto Runner -> editSchema -> Run -> change build configurations to > Debug.

if you are in Release mode you will face this issue, while running on android studio.

Solution 16 - Flutter

I found the solution/work around. For me, it worked on physical device but not on emulator. The simple fix is to use your an emulator of x86 environment rather than x86_64 emulator.

Solution 17 - Flutter

I fixed the issue by setting request.persistentConnection = false; (default is true)

Writing this in case someone has the same problem...

Solution 18 - Flutter

Maybe something goes wrong with your internet service provider, I try to enable VPN, it works

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionJuthi Sarker AkaView Question on Stackoverflow
Solution 1 - FlutterawaikView Answer on Stackoverflow
Solution 2 - FlutterVicky SalunkheView Answer on Stackoverflow
Solution 3 - FlutternbloqsView Answer on Stackoverflow
Solution 4 - FlutterPayam KhaninejadView Answer on Stackoverflow
Solution 5 - FlutterParesh MangukiyaView Answer on Stackoverflow
Solution 6 - FlutterRay ZionView Answer on Stackoverflow
Solution 7 - FlutterFabio PaganoView Answer on Stackoverflow
Solution 8 - FlutterVitaly ZeyenkoView Answer on Stackoverflow
Solution 9 - FlutterChrisView Answer on Stackoverflow
Solution 10 - FlutteromgoverflowView Answer on Stackoverflow
Solution 11 - FluttersonalView Answer on Stackoverflow
Solution 12 - FlutterJagadish NallappaView Answer on Stackoverflow
Solution 13 - FlutterDilendra ShahiView Answer on Stackoverflow
Solution 14 - FlutterAmrView Answer on Stackoverflow
Solution 15 - FlutterNavin KumarView Answer on Stackoverflow
Solution 16 - FlutterAxes GrindsView Answer on Stackoverflow
Solution 17 - FlutterBosko PopovicView Answer on Stackoverflow
Solution 18 - FlutterHieu VoView Answer on Stackoverflow