Where communities thrive

  • Join over 1.5M+ people
  • Join over 100K+ communities
  • Free without limits
  • Create your own community
Repo info
  • 10:03
    zekageri commented #1160
  • 10:00
    zekageri commented #1160
  • 00:42
    DanteNahuel commented #1147
  • May 16 20:59
    RadianM commented #1131
  • May 16 17:20
    arslan437 commented #1151
  • May 16 17:18
    arslan437 commented #1151
  • May 16 14:04
    VNovytskyi edited #1160
  • May 16 14:03
    VNovytskyi opened #1160
  • May 16 13:50
    RadianM commented #1131
  • May 16 12:34
    VNovytskyi closed #1143
  • May 16 12:34
    VNovytskyi commented #1143
  • May 16 11:48
    vatsake commented #1156
  • May 16 09:55
    vatsake closed #1156
  • May 16 09:55
    vatsake commented #1156
  • May 16 09:52
    zekageri commented #1156
  • May 16 09:43
    zekageri commented #1156
  • May 16 09:35
    zekageri commented #1156
  • May 16 09:26
    vatsake commented #1156
  • May 16 09:20
    zekageri commented #1156
  • May 16 07:27
    vatsake commented #1156
For posterity:

  aClient->onError([](void * arg, AsyncClient * client, err_t error) {
    ESP_LOGE( TAG, "aSyncClient error %i", error);
    ESP_LOGE( TAG, "aSyncClient error code %s", client->errorToString(error));
    aClient = NULL;
    delete client;
  }, NULL);
@BlueAndi That's the approach I used as a workaround, but it required POSTing with javascript. Having the file size available in the upload handler would make things much the webpage code much simpler.
Mike Dunston
File uploads are typically a POST, there is a header included by the client with the part size. The callback from the webserver provides a chunk size only. But you should be able to grab the segment header or at worst case the overall Content-Length header (it will be larger than the actual file upload though)
I see now that size() (_itemSize) comes from counting up the number of bytes uploaded, so it isn't available until after the upload. The original code I used calls contentLength() which works fine for uploading firmware because firmware size + a little extra from the contentLength() "boundary=----..." header and footer is still less than the space available. The problem is when I try to upload a littlefs.bin that is exactly 1MB and there is 1MB of space available using contentLength() makes it look like the file is too big for the space available.
I see if I add an input with the size of the file to my html form before the file input that the file size input gets read in before the upload handler is called, so some potential there to explore. I'll post an update.
Yes, this solution works well! It works much better for me than using javascript to POST with a custom header. Uploading is quicker and more reliable.
Here are some snippets to help out anyone else that had this problem:

<form id='flash' method='POST' action='/flash_firmware' enctype='multipart/form-data'>
<!--need to upload filesize first because Content-Length [request->contentLength()] isn't the actual file size-->
<input id='filesize' name="filesize" value="0" style="display:none">
<input id='file' type='file' name='update'>
<input id='flash_btn' type='submit' value='Flash'>

document.querySelector('form').addEventListener('submit', (e) => {
document.getElementById('filesize').value = document.getElementById('file').files[0].size;

size_t filesize = 0;
if (request->hasParam("filesize", true)) {
// because contentLength() doesn't work for spiffs or littlefs had to use a separate form input to upload actual filesize.
filesize = request->getParam("filesize", true)->value().toInt();
else {
// this doesn't work for spiffs or littlefs because contentLength() includes count of bytes in bin file plus header and footer
filesize = request->contentLength();
Does anyone still experience the websockets random disconnect issues? I am at the end of a 3 year dev cycle and have not been able to contain it. Only other issue I had was the 5-file limit on filerequest which was solved by using JS function that would only request the next file once it has actually been loaded. Not much difference in download speed. For static images local storage is a great workaround.
Hi @Turbotronics. I have faced the two same issues as you. WebSocket disconnection is an ongoing issues with ESPAsyncWebServer and its underlying use os ESPAsyncTCP. There are many forks that seems to fix this. Haven't tryed anyone yet. It's a pity the main lbrary is stalled and not willing to accept pull requests. The second issues, the 5-file limit, I solve it creating only one huge html file with all the content embedded (html, css, js)
Hi Gonzalo, thanx for the feedback. Do you have links to the other forks? My i/f is a controller dashboard than must always be responsive to user input. I am considering using streams to replace the socket since so far I have had no issues transfering data that way. I had a function calling a sequence of strings to tx to client. It was painfully slow since without long intervals it would break. Replacing this with an XMLHttpRequest made is almost instant.
Michael Heinrich

I want to write a file upload handler class.
My current class is

class UpdateMasterRequestHandler : public AsyncWebHandler {
    UpdateMasterRequestHandler(/* args */) { }
    virtual ~UpdateMasterRequestHandler() { }

    bool canHandle(AsyncWebServerRequest *request);
    void handleUpload(AsyncWebServerRequest *request, const String& filename, size_t index, uint8_t *data, size_t len, bool final);

canHandle returns true, but handleUpload never gets called.
What am I doing wrong?

bool UpdateMasterRequestHandler::canHandle(AsyncWebServerRequest *request) {
    bool forMe = request->url() == "/api/UpdateMaster"
              && request->method() == HTTP_POST
              && request->multipart();
    if (forMe) logDebugln("UpdateMasterRequestHandler!");

    return forMe;

void UpdateMasterRequestHandler::handleUpload(AsyncWebServerRequest *request, const String& filename, size_t index, uint8_t *data, size_t len, bool final) {
    if (index == 0) {
        logDebug("UploadStart: ");

        request->_tempFile = SPIFFS.open("master.hex", "w");

    if (len > 0) {
        request->_tempFile.write(data, len);

    if (final) {
        logDebug("UploadEnd: ");


        request->send(200, MIME_TYPE_PLAIN_TEXT, "Upload complete!");
<form id="masterUpdateForm" action="/api/UpdateMaster" method="POST" enctype="multipart/form-data">
    Firmware: <input type="file" name="file" accept="*.hex">
    <button type="submit">Update</button>
Michael Heinrich
I also tried this:
class UpdateMasterRequestHandler : public AsyncWebHandler {
    UpdateMasterRequestHandler(/* args */) { }
    virtual ~UpdateMasterRequestHandler() { }

    virtual bool canHandle(AsyncWebServerRequest *request) override final;
    virtual void handleRequest(AsyncWebServerRequest *request) override final;
    virtual void handleUpload(AsyncWebServerRequest *request, const String& filename, size_t index, uint8_t *data, size_t len, bool final) override final;
Michael Heinrich
I found the solution. I had to override isRequestHandlerTrivial as well and make it return false.
Hi, is there a complimentary ESP8266 WebSocket library for ws clients? I used the library for Wemos D1 Mini as websocket server, which works great! But I want to connect to this websocket server using a second Wemos D1 Mini. Can I do this using the same library? Or is there a complimentary library?
@me-no-dev I am working on a project that uses AsyncTCP for networking.
Is there a way to disable the WDT on the Async task?
Paul Andrews
I am curious about how async TCP works on the ESP8266. In particular, do I need to be careful about concurrency issues in handlers?
Should maybe have tagged that with @me-no-dev :-)
Hello. Can we use ESPAsyncWebServer library with GSM shield in ESP32-ESP8266?
Hello guys, i have a question in terms of licensing of the „ESPAsyncWebServer“. Every other library from @me-no-dev is licensed as LGPL-3.0 or 2.0 licence, however this one has no license listed.
@me-no-dev I made a simple class from AsyncTCP but am at a loss how to set a timeout.
I have opend ESPAsyncTCP library. main class includes C-C++ "lwip" library... Can I get a result if I edit the void AsyncServer :: begin () function in the class according to AT commands?
Please can you advise to me about "Can we use ESPAsyncWebServer library with GSM shield in ESP32-ESP8266?"?
im create async web server
but refreshing and reset esp32
how to fix that
my html document

Backtrace: 0x4000c3f0:0x3ffd1380 0x400db076:0x3ffd13a0 0x400db192:0x3ffd13c0 0x400d7ad1:0x3ffd13e0 0x400d6192:0x3ffd1450 0x400d60f5:0x3ffd1490 0x400d145d:0x3ffd14b0 0x4015188f:0x3ffd14f0 0x400d9309:0x3ffd1510 0x400d6df1:0x3ffd1560 0x400d6eb5:0x3ffd15a0 0x400d7105:0x3ffd15f0 0x4014b7b1:0x3ffd1610 0x4014b82d:0x3ffd1650 0x4014bed6:0x3ffd1670 0x4008a286:0x3ffd16a0

#0 0x4000c3f0:0x3ffd1380 in ?? ??:0

#1 0x400db076:0x3ffd13a0 in String::move(String&) at C:\Users\OnurNP.platformio\packages\framework-arduinoespressif32\cores\esp32/WString.cpp:857

#2 0x400db192:0x3ffd13c0 in String::operator=(String&&) at C:\Users\OnurNP.platformio\packages\framework-arduinoespressif32\cores\esp32/WString.cpp:857

#3 0x400d7ad1:0x3ffd13e0 in AsyncBasicResponse::_respond(AsyncWebServerRequest) at lib\ESPAsyncWebServer\src/WebResponses.cpp:699

#4 0x400d6192:0x3ffd1450 in AsyncWebServerRequest::send(AsyncWebServerResponse
) at lib\ESPAsyncWebServer\src/WebRequest.cpp:797

#5 0x400d60f5:0x3ffd1490 in AsyncWebServerRequest::send(int, String const&, String const&) at lib\ESPAsyncWebServer\src/WebRequest.cpp:797

#6 0x400d145d:0x3ffd14b0 in handleRoot(AsyncWebServerRequest) at src/main.cpp:289

#7 0x4015188f:0x3ffd14f0 in std::_Function_handler<void (AsyncWebServerRequest
), void ()(AsyncWebServerRequest)>::_M_invoke(std::_Any_data const&,

AsyncWebServerRequest*&&) at c:\users\onurnp.platformio\packages\toolchain-xtensa32@2.50200.97\xtensa-esp32-elf\include\c++\5.2.0/functional:1871

#8 0x400d9309:0x3ffd1510 in std::function<void (AsyncWebServerRequest*)>::operator()(AsyncWebServerRequest*) const at lib\ESPAsyncWebServer\src/StringArray.h:73

  (inlined by) AsyncCallbackWebHandler::handleRequest(AsyncWebServerRequest*) at lib\ESPAsyncWebServer\src/WebHandlerImpl.h:132

#9 0x400d6df1:0x3ffd1560 in AsyncWebServerRequest::_parseLine() at lib\ESPAsyncWebServer\src/WebRequest.cpp:797

#10 0x400d6eb5:0x3ffd15a0 in AsyncWebServerRequest::_onData(void, unsigned int) at lib\ESPAsyncWebServer\src/WebRequest.cpp:797

#11 0x400d7105:0x3ffd15f0 in std::_Function_handler<void (void
, AsyncClient, void, unsigned int), AsyncWebServerRequest::AsyncWebServerRequest(AsyncWebServer, AsyncClient)::{lambda(void, AsyncClient, void, unsigned int)#8}>::_M_invoke(std::_Any_data const&, void&&, AsyncClient*&&, std::_Any_data const&, unsigned int&&) at lib\ESPAsyncWebServer\src/WebRequest.cpp:797

  (inlined by) _M_invoke at c:\users\onurnp\.platformio\packages\toolchain-xtensa32@2.50200.97\xtensa-esp32-elf\include\c++\5.2.0/functional:1871    

#12 0x4014b7b1:0x3ffd1610 in std::function<void (void*, AsyncClient*, void*, unsigned int)>::operator()(void, AsyncClient, void*, unsigned int) const at lib\AsyncTCP\src/AsyncTCP.cpp:1039

  (inlined by) AsyncClient::_recv(tcp_pcb*, pbuf*, signed char) at lib\AsyncTCP\src/AsyncTCP.cpp:934

#13 0x4014b82d:0x3ffd1650 in AsyncClient::_s_recv(void, tcp_pcb, pbuf, signed char) at lib\AsyncTCP\src/AsyncTCP.cpp:1039

#14 0x4014bed6:0x3ffd1670 in _async_service_task(void
) at lib\AsyncTCP\src/AsyncTCP.cpp:1039

  (inlined by) _async_service_task at lib\AsyncTCP\src/AsyncTCP.cpp:197

#15 0x4008a286:0x3ffd16a0 in vPortTaskWrapper at

/home/runner/work/esp32-arduino-lib-builder/esp32-arduino-lib-builder/esp-idf/components/freertos/port.c:355 (discriminator 1)

how to fix that help me
"I made a simple class from AsyncTCP but am at a loss how to set a timeout." : Could you tell me briefly what to do? Can I put in AT commands?
Hi!! anyone around?
im activated external interrupt and cant connect wifi
how to fix that
how do use rtos on async web server
Ramses Garcia Dilone
hello world
i tried use this lib with w5500
is possible?

Using AsyncWebServer on ESP32 I'm getting frequent Guru Meditation Errors:
Core 1 panic'ed (LoadProhibited). Exception was unhandled.
Core 1 register dump:
PC : 0x400d7e7c PS : 0x00060430 A0 : 0x800d7f1a A1 : 0x3ffb1f00
A2 : 0x3ffd31bc A3 : 0x3ffd2f84 A4 : 0x00000026 A5 : 0x3ffd2caa
A6 : 0x00000a0d A7 : 0x3a617461 A8 : 0x800d7e88 A9 : 0x3ffb1ee0
A10 : 0xe0088080 A11 : 0x00000026 A12 : 0x00000026 A13 : 0x00000026
A14 : 0x00000000 A15 : 0x00000000 SAR : 0x0000000a EXCCAUSE: 0x0000001c
EXCVADDR: 0xe0088088 LBEG : 0x4000c2e0 LEND : 0x4000c2f6 LCOUNT : 0xffffffff

ELF file SHA256: 0000000000000000

Backtrace: 0x400d7e7c:0x3ffb1f00 0x400d7f17:0x3ffb1f20 0x400d7f37:0x3ffb1f40 0x400d7f8d:0x3ffb1f60 0x400d17d3:0x3ffb1f90 0x400df329:0x3ffb1fb0 0x40089afa:0x3ffb1fd0

the backtrace shows
Decoding 7 results
0x400d7e7c: AsyncEventSourceClient::_runQueue() at c:\arduinoideportable\portable\packages\esp32\tools\xtensa-esp32-elf-gcc\1.22.0-97-gc752ad5-5.2.0\xtensa-esp32-elf\include\c++\5.2.0/functional line 1858
0x400d7f17: AsyncEventSourceClient::_queueMessage(AsyncEventSourceMessage) at c:\arduinoideportable\portable\packages\esp32\tools\xtensa-esp32-elf-gcc\1.22.0-97-gc752ad5-5.2.0\xtensa-esp32-elf\include\c++\5.2.0/functional line 1858
0x400d7f37: AsyncEventSourceClient::write(char const
, unsigned int) at c:\arduinoideportable\portable\packages\esp32\tools\xtensa-esp32-elf-gcc\1.22.0-97-gc752ad5-5.2.0\xtensa-esp32-elf\include\c++\5.2.0/functional line 1858
0x400d7f8d: AsyncEventSource::send(char const, char const, unsigned int, unsigned int) at c:\arduinoideportable\portable\packages\esp32\tools\xtensa-esp32-elf-gcc\1.22.0-97-gc752ad5-5.2.0\xtensa-esp32-elf\include\c++\5.2.0/functional line 1858
0x400d17d3: loop() at C:\ArduinoIDEPortable\portable\sketchbook\ESP32\SolarLoggerJune12/SolarLoggerJune12.ino line 151
0x400df329: loopTask(void*) at C:\ArduinoIDEPortable\portable\packages\esp32\hardware\esp32\1.0.6\cores\esp32/main.cpp line 23
0x40089afa: vPortTaskWrapper at /home/runner/work/esp32-arduino-lib-builder/esp32-arduino-lib-builder/esp-idf/components/freertos/port.c line 355 (discriminator 1)

referring to this line in my code

151: events.send( mycWatts , "cwatts", millis());

It doesntt happen every time but its realy giving me a headache. Any ideas?

Rolf Wedermann
Hello everyone, will the ESP Async web server be further developed or is the project idle?
Seems idle
Tom Sciano
how can I send a fetch/post request to itself using javascript
i keep getting a cors error
` const button = document.getElementById("post-btn");
    button.addEventListener("click", async(_) => {
        try {
            const response = await fetch("board", {
                method: "post",
                body: {
            console.log("Completed!", response);
        } catch (err) {
            console.error(`Error: ${err}`);
    }); `