Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Invalid route parameter returns 500 instead of 404 #2218

Open
Colysia opened this issue Dec 1, 2024 · 1 comment
Open

Invalid route parameter returns 500 instead of 404 #2218

Colysia opened this issue Dec 1, 2024 · 1 comment

Comments

@Colysia
Copy link

Colysia commented Dec 1, 2024

Describe the bug
When making a request to the route /api/num/{number} with a parameter like /api/num/s-1.2e-3, the server returns a 500 Internal Server Error instead of the expected 404 Not Found.
The URL /api/num/s-1.2e-3 should not match the route /api/num/ since it starts with s and is not a valid double. However, the server currently throws a 500 Internal Server Error.
And here is the log:

20241201 04:41:45.637000 UTC 37404 ERROR Unhandled exception in /api/num/s-1.2e-3, what(): invalid stod argument - HttpAppFrameworkImpl.cc:124

To Reproduce
Steps to reproduce the behavior:

  1. Set up a Drogon server with the following handler registration:
#pragma comment(lib, "Crypt32")
#pragma comment(lib, "Rpcrt4")

#include <drogon/drogon.h>
#include <string>

int main(int argc, char *argv[])
{
  auto &app = drogon::app();

  app.registerHandler("/api/num/{number}",
      [](const drogon::HttpRequestPtr &, std::function<void(const drogon::HttpResponsePtr &)> &&callback, double number) {
        auto resp = drogon::HttpResponse::newHttpResponse();
        std::string text = std::to_string(number);
        resp->setBody(text);
        resp->setContentTypeCode(drogon::CT_TEXT_PLAIN);
        resp->setStatusCode(drogon::k200OK);
        callback(resp);
      },
      {drogon::Get});

  app.setLogLevel(trantor::Logger::kInfo)
      .setLogPath("./")
      .addListener("0.0.0.0", 18080)
      .addListener("::0", 18080)
      .setThreadNum(6)
      .setIdleConnectionTimeout(std::chrono::seconds(5))
      .run();

  return 0;
}

Expected behavior
I expected the server to return a 404 Not Found error, as the parameter s-1.2e-3 is not a valid double (it starts with s and cannot be parsed as a number). The server should not attempt to match the route when the parameter is invalid.

Screenshots
捕获

Desktop (please complete the following information):

  • OS: Windows 11
  • Compiler: Visual Studio 2022
  • C++ Standard: C++17
  • Drogon version: 1.9.6
  • Charset: Unicode

Additional context

@an-tao
Copy link
Member

an-tao commented Dec 3, 2024

You could try to use the ADD_METHOD_VIA_REGEX mecro or the registerMethodViaRegex method, and create a regular expression for matching floating point numbers for your scenario.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants