在SSM架构中,可以采取多种方式处理异常,用户访问控制层,再到服务层,再到DAO层, 每一层都有可能出现异常。可以把每层的异常往上抛,抛给最外面的控制层,然后将这个错误显示到一个error.jsp页面上来提示用户网页出错了, 这样就比较人性化。 有时候控制层的方法是想返回json数据,并不想转到error.jsp界面上, 这种情况也可以处理
控制层中可能返回String,也可能使用@ResponseBody将返回结果封装为JSON字符串,在AJAX情况下发生异常和非AJAX情况下异常处理方式不同,AJAX请求过程中(Controller、Service、Dao)出现异常,这时会将异常返回给前端,包括错误的提示信息,例如登录页面jsp中使用AJAX:
$.ajax({
type : "POST",
url : "${APP_PATH}/doAJAXLogin",
data : {
"loginacct" : loginacct,
"password" : password
},
dataType : "json",
success : function(result){
layer.close(loadingIndex);//关掉效果
if(result.status == 0){
//登陆成功,跳转到主页面
window.location.href = "${APP_PATH}/main";
}else if(result.status == 1){
//登录失败
layer.msg("<em style='color:red'>" + result.message + "</em>", {time:2000, icon:5, shift:6}, function(){});
}
}
});
返回值AJAXResult:
public class AJAXResult implements Serializable{
private static final long serialVersionUID = 1L;
private int status;//返回状态 0-正常 1-失败
private String message;//返回的消息
private Object data;
控制器接收请求如下;
//登录校验
@RequestMapping("/doAJAXLogin")
@ResponseBody
public AJAXResult doAJAXLogin(User user, HttpSession session) throws CustomException{
AJAXResult result = new AJAXResult();
User dbUser = userService.queryForLogin(user);
session.setAttribute("loginUser", dbUser);
//权限待定
result.setStatus(0);
return result;
}
UserService接口:
package com.tedu.service;
import com.tedu.entity.User;
import com.tedu.exception.CustomException;
public interface UserService {
User queryForLogin(User user) throws CustomException;//登录(根据账号和密码查询用户)
}
UserServiceImpl实现类:
package