[英]SparkJava - Case sensitive endpoints
我有一个 java 代码,它使用 SparkJava ( http://sparkjava.com/ )为 http 端点提供服务。
端点是这样生成的:
get("/xxx/yyy", (request, response) -> {
...
return SOMETHING_TO_RETURN
});
使用这种方法我有一个问题:
假设我定义了一个端点:'/api/status/car',
但用户有时会调用 '/api/status/ CAR '。 所以问题在于这样定义的 url 区分大小写。
现在我必须以某种方式修复它:使大小写不敏感。 我看过过滤器(例如“之前”),但我相信我无法修改请求 url(toLowerCase)。
所以主要问题是:通过使用这种方法定义端点,我如何将请求 url 修改为小写,或者说 sparkjava 应该使用不区分大小写的模式映射 url。
URL(域名部分除外)可能始终区分大小写。 由服务器决定,因此用户永远无法知道。 您可以在W3.org中了解更多信息。
解决您的问题的一种方法可能是使用请求参数:
get("/api/status/:carParam", (request, response) -> {
if (request.params(":carParam").equalsIgnoreCase("car")) {
return SOMETHING_TO_RETURN;
}
});
如果您在/api/status/
除了car
下还有更多路线,那么您应该将:carParam
重命名为更通用的名称,例如:param
,然后在处理程序主体中,您将检查此查询参数并相应地返回正确的返回值。 例如:
get("/api/status/:param", (request, response) -> {
if (request.params(":param").equalsIgnoreCase("car")) {
return SOMETHING_TO_RETURN_CAR;
} else if (request.params(":param").equalsIgnoreCase("passenger")) {
return SOMETHING_TO_RETURN_PASSENGER;
}
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.