好吧,基本上只是想在我的 Spring Web 应用程序中实现一些 ajax。出于测试目的,我尝试编写一些代码,以便在他们按下链接/按钮时根据他们的个人“id”值检索“用户”信息。我假设这是服务器端错误,我的控制器有问题,尽管我不完全确定并且需要帮助才能使其正常工作。这是我当前的 JSP 页面,仅用于测试:
<c:forEach var="user" items="${users}">
<tr>
<td><c:out value="${user.id}" /></td>
<td><c:out value="${user.name}"/></td>
<td><c:out value="${user.username}"/></td>
<td><c:out value="${user.email}"/></td>
<td><c:out value="${user.dob}"/></td>
<td><c:out value="${user.authority}"/></td>
<td>
<a class="update" href="<c:url value="/viewUser"><c:param name="id" value="${user.id}"/></c:url>"><button>Update</button></a>
</td>
<td>
<a class="delete" href="<c:url value="/deleteUser"><c:param name="id" value="${user.id}"/></c:url>"><button>Delete</button></a>
</td>
<td>
<a class="ajax" href="<c:url value="/ajax"><c:param name="id" value="${user.id}"/></c:url>">Ajax</a>
</td>
</tr>
</c:forEach>
</table>
<script type="text/javascript">
$(document).ready(function(){
$('.ajax').click(function(e){
e.preventDefault();
$.ajax({
url:"http://localhost:8080/SDP_v1.7/ajax",
type: 'GET',
dataType:'json',
contentType: 'application/json',
mimeType: 'application/json',
succes: function(user){
alert(user.id + " + " + user.username);
},
error:function(user,status,er) {
alert("error: "+user+" status: "+status+" er:"+er);
}
});
});
});
</script>
这是我的控制器类:
@RequestMapping("/viewUser")
public String updateUser(Model model, @RequestParam(value = "id", required = false) Integer id) {
User user = usersService.getUser(id);
model.addAttribute("user", user);
return "settings";
}
@RequestMapping(value = "/ajax", method = RequestMethod.GET)
public @ResponseBody User getUser(@PathVariable Integer id) {
return usersService.getUser(id);
}
这是我在控制台中弹出的错误:
GET http://localhost:8080/SDP_v1.7/ajax 403 (Forbidden) jquery.js:5
发送 jquery.js:5 x.extend.ajax jquery.js:5 (匿名函数) users:106 x.event.dispatch jquery.js:4 v.handle
本质上,我的目标是将每个用户的信息加载到带有表单的弹出模式中。虽然我必须先让这一步工作。谢谢