?????? 最近公司来了几个新员工,让我给他们做一些培训。其中就包括Spring MVC。由于自己接触的也不多,所以也常常会碰到一些问题。现在把这些问题记录下来,以免以后遇到问题的时候又找不到解决办法。
?????? 由于我让他们做了一个简版的微博系统,也就出现了对听众的“取消”和“立即收听”的操作,而这一下操作必须使用ajax实现,才能保证页面的局部刷新效果。而这就涉及到了json数据的返回值问题。
说明:代码是在新员工编写的代码上进行修改的,有些地方可能会有些冗余,但是不影响效果,仅供参考。
操作步骤如下:
1、在项目中引入使用json需要的两个jar包:
jackson-core-lgpl-1.8.5.jar和jackson-mapper-asl-1.8.5.jar
2、在Controller的相应方法上加上@ResponseBody,该方法的返回值可以为POJO对象,也可以为Map。
使用Map的实现代码如下:
@RequestMapping(value = "/deleteListen",method = RequestMethod.POST)
@ResponseBody
public Map<String, String> deleteListen(HttpServletRequest request,String microblogid, String operatorType){
User user = (User) request.getSession().getAttribute("user");
String listenid = user.getMicroblogid();
Map<String, String> map = new HashMap<String, String>();
try{
if("cancel".equals(operatorType)){// 取消操作
// 从LISTEN表中删除
listenService.deleteListen(listenid, microblogid);
// 操作状态变为"立即收听"
map.put("operatorState", "立即收听");
// 收听状态变为""
map.put("tuneState", "");
}else{// 立即收听操作
// 添加收听人到LISTEN表中
listenService.save1Listen(listenid, microblogid);
// 操作状态变为"取消"
map.put("operatorState", "取消");
// 被收听的人收听了当前用户
if(listenService.isListen(microblogid, listenid)){
// 收听状态变为"已互听"
map.put("tuneState", "已互听");
}else{
// 收听状态变为"已收听"
map.put("tuneState", "已收听");
}
}
map.put("result", "success");
}catch (Exception e) {
map.put("result", "fail");
}
return map;
}
?使用POJO类的代码如下:
?
@RequestMapping(value = "/deleteListen",method = RequestMethod.POST)
@ResponseBody
public Operator deleteListen(HttpServletRequest request,String microblogid, String operatorType){
User user = (User) request.getSession().getAttribute("user");
String listenid = user.getMicroblogid();
Operator operator = new Operator();
try{
if("cancel".equals(operatorType)){// 取消操作
// 从LISTEN表中删除
listenService.deleteListen(listenid, microblogid);
// 操作状态变为"立即收听"
operator.setOperatorState("立即收听");
// 收听状态变为""
operator.setTuneState("");
}else{// 立即收听操作
// 添加收听人到LISTEN表中
listenService.save1Listen(listenid, microblogid);
// 操作状态变为"取消"
operator.setOperatorState("取消");
// 被收听的人收听了当前用户
if(listenService.isListen(microblogid, listenid)){
// 收听状态变为"已互听"
operator.setTuneState("已互听");
}else{
// 收听状态变为"已收听"
operator.setTuneState("已收听");
}
}
operator.setResult("success");
}catch (Exception e) {
operator.setResult("fail");
}
return operator;
}
?3、页面中ajax的调用方法如下:
?
function operator(obj, microblogid){
var date = new Date();
var operatorType = $(obj).text();
if(operatorType == "取消"){
operatorType = "cancel";
}else{
operatorType = "tune";
}
$.ajax({
url: "<%=path%>/deleteListen",
type : "post",
dataType : "json",
data : "microblogid=" + microblogid + "&operatorType=" + operatorType + "&date=" + date,
success : function(result) {
if(result.result == "success"){
$(obj).text(result.operatorState);
$(obj).parent().prev().find("a").text(result.tuneState);
}else{
alert("操作失败");
}
},
error : function() {
alert("访问失败");
}
});
}
?页面部分的内容如下:
<c:forEach var="userandlisten" items="${tunelist}" varStatus="count">
<tr>
<td align="right"><a href="selectBroadcast?microblogid=${userandlisten.listenid }">${userandlisten.username}</a> </td>
<td align="right" width="80">${userandlisten.remark} </td>
<td align="left"><a href="remarkName?