Spring Boot:防止对@RequestParam进行解码

我有一个在Tomcat 8.5上运行的Spring-Boot(1.5.3)应用程序。在其中,我有一个带有单个参数的RestController。

此参数会自动解码-

这对于我的应用程序中的所有其他控制器都很好,但是对此,我需要原始请求数据,因为它们将在另一个请求中使用。请注意,我只想对此控制器/请求禁用自动解码,并在其他地方保持正常行为。

@RestController

@RequestMapping("/rest/test")

public class TestController {

@RequestMapping("/test")

public ResponseEntity<String> test(@RequestParam final String test){

return ResponseEntity.ok("Requested: " + test);

}

}

现在,如果我发送访问

curl localhost/rest/test/test?test=%C3%B6%20%C3%A4

我收到输出:

Requested: ö ä

我想拥有

Requested: %C3%B6%20%C3%A4

有任何想法吗?

回答:

如果仅在单个位置需要此行为,则可以使用控制器主体内部的标准Java

URLEncoder将参数编码回原始形式:

@RequestMapping("/test")

public ResponseEntity<String> test(@RequestParam final String test) {

String encodedParam = URLEncoder.encode(test, "UTF-8");

return ResponseEntity.ok("Requested: " + encodedParam);

}

以上是 Spring Boot:防止对@RequestParam进行解码 的全部内容, 来源链接: utcz.com/qa/434519.html

回到顶部