【发布时间】:2019-06-28 10:08:20
【问题描述】:
我的问题是,使用 Debian 9 VM 上托管的远程 tomcat 时,使用 AJAX 发送的每个 POST 请求都会返回 415 错误。相同的代码适用于本地 tomcat(相同的版本,配置文件没有区别)。 使用不同版本的 tomcat(8.5 和 9)进行测试。同样的问题。
考虑的登录页面(见下文):
HTML
<div id="form">
<form id="loginEmp-Form">
<input type="email" id="login" name="login" placeholder="email" />
<input type="password" id="password" name="password" placeholder="password" />
<input type="submit" id="loginButton" value="Connection" />
</form>
<div id="errorMsg"></div>
</div>
JAVASCRIPT
$('#loginEmp-Form').submit(function(event) {
event.preventDefault();
var loginReceived = loginForm.login.value;
var passwordReceived = loginForm.password.value;
//I deliberately deleted the logic concerning the password hashing to make it simple
var Login = {
login: loginReceived,
password: passwordReceived
};
$.ajax({
headers : {'Content-Type' : 'application/json;charset=utf-8'},
type : 'POST',
url : 'login',
data : JSON.stringify(Login),
success : function(result) {
// DO SOMETHING
},
error : function(e) {
// DO SOMETHING
}
});
}
JAVA
控制器
public class LoginController {
private static final Logger LOGGER=LoggerFactory.getLogger(LoginController.class);
@RequestMapping(value = "/login", method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_VALUE)
public ModelAndView processLoginEmployee(@RequestBody Login loginReceived, HttpSession session) {
// Logic not detailed here because we're not even entering in the controller. Checked with the following traces.
LOGGER.info("Received request POST"); // nothing display
ModelAndView mav = null;
return mav;
}
}
对应的Bean
public class Login {
private String login;
private String password;
/*
* Constructors
*/
public Login(String login, String password) {
super();
this.login = login;
this.password= password;
}
public Login() {
}
/*
* Getters & setters
*/
public String getLogin() {
return login;
}
public void setLogin(String login) {
this.login = login;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password= password;
}
}
正如我所说,当我在本地 Tomcat 上部署应用程序时,一切正常(前端和后端)。我理解 415 错误是指请求格式的问题。但我真的不知道它是从哪里来的。所以这就是我寻求帮助的原因!我花了几个小时试图在互联网上搜索解决方案,但没有成功。
其他信息:
- GET 请求工作正常,即使在使用远程 Tomcat 时也是如此。
- 我正在处理我公司的互联网网络。任何安全元素都可以阻止发布请求吗?像防火墙一样?我声称不会,因为一些同事在远程 tomcat 上开发和部署了他们的应用程序,并且 POST 请求运行良好。我寻求他们的帮助,但他们没有找到任何解决方案。
我已经尝试过的 --> Ajax 调用:
- 使用 'content-type: application/json' 添加/删除标头
- 添加/删除“内容类型:应用程序/json”
Java 控制器:
- 添加/删除“consumes=MediaType.APPLICATION_JSON_VALUE”
Tomcat的配置 :
- 检查请求的大小限制是否正常
- 检查 tomcat 是否打开到远程连接
我已尝试使用 Postman 发送完全相同的请求。结果:415。
如果有人找到解决方案或至少有建议,我将不胜感激。提前感谢您的宝贵时间。
解决方案
问题解决了。两件事:
首先,在 pom.xl 中,只使用这个依赖,而不是来自 org.codehaus 的旧依赖。
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>${jackson.version}</version>
</dependency>
Maven 将在构建时自动创建每个需要的 jar。此外,另一个错误是同时使用两个依赖项(来自 codehaus 和 fastxml)。 fastxml 的依赖项是现在要使用的依赖项。
然后,在控制器中进行了修改:
@RequestMapping(value = "/login", method = RequestMethod.POST)
public String processLoginEmployee(@RequestBody String json)
throws JsonParseException, JsonMappingException, IOException {
LOGGER.info("Received request POST");
ObjectMapper mapper = new ObjectMapper();
Login employee = mapper.readValue(json, Login.class);
System.out.println(employee.getLogin());
System.out.println(employee.getMdp());
return "success";
}
尝试使用 @RequestParam 直接获取对象不起作用。 将 json 作为字符串获取,然后使用 ObjectMapper 对其进行解析即可完成工作。
【问题讨论】:
-
http/https ssl 问题?
-
与您的解决方案相关的问题,它是如何在本地部署中发挥作用的?
-
它也很好用!
标签: javascript java ajax spring-mvc tomcat