基本的に、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
send jquery.js:5 x.extend.ajax jquery.js:5 (匿名関数) users:106 x.event.dispatch jquery.js:4 v.handle
基本的に、フォームを使用して各ユーザーの情報をポップアップ モーダルにロードすることを目指しています。最初にこのステップを機能させる必要がありますが。ありがとう