这一节,我们把用户新增的功能继续做一个完善。首先,新增成功后,需要给前台返回一个信息,就是告诉浏览器,这次用户新增的操作到底是成功了呢,还是失败了呢?为此,我们需要专门引入一个结果类,里面只有两个属性,分别为错误码和错误信息,这个类在之前的章节中有提到过。

package com.app.bean;

public class ResultData {
    
    private int errCode = 0;
    private String errMsg;
    
    public int getErrCode() {
        return errCode;
    }
    public void setErrCode(int errCode) {
        this.errCode = errCode;
    }
    public String getErrMsg() {
        return errMsg;
    }
    public void setErrMsg(String errMsg) {
        this.errMsg = errMsg;
    }
}

然后,改写UserController类:

package com.app.controller;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import com.app.bean.ResultData;
import com.app.bean.Student;
import com.app.service.UserService;
import com.app.service.impl.UserServiceImpl;

@Controller
public class UserController {
	
	//用户业务类的引用
	private UserService userService = new UserServiceImpl();
	
	@RequestMapping("/addUser")
	@ResponseBody
	public ResultData addUser(HttpServletRequest request , HttpServletResponse response,Student student){
		ResultData data = new ResultData();
		
		try{
			userService.addUser(student);
		}catch(Exception e){
			data.setErrCode(-1);
			data.setErrMsg(e.getMessage());
		}
		
		return data;
		
		
	}    
}

如果保存操作出现异常,我们就捕获一下异常,并且记录下异常信息,返回给浏览器。注意,这边我们还给addUser方法加了一个@ResponseBody注解。这样一来,当我们return数据的时候,就会自动转换成json对象,然后用IO流的方式写出到浏览器。

后台控制器解决了之后,我们再来修改前台的ajax方法:

//使用ajax传递到后台
$.post("addUser.do",json,function(data){
	//这里是处理返回数据的回调函数 
	
	
	if(data.errCode < 0){
		alert('操作发生错误,原因是:' + data.errMsg);
	}else{
		alert('保存成功');
	}
	
},"json");

效果:

现在,我们故意制造一个异常:

@Controller
public class UserController {
	
	//用户业务类的引用
	private UserService userService = new UserServiceImpl();
	
	@RequestMapping("/addUser")
	@ResponseBody
	public ResultData addUser(HttpServletRequest request , HttpServletResponse response,Student student){
		ResultData data = new ResultData();
		
		try{
			userService.addUser(student);
			int i = 1 / 0; //故意写一句错误代码
		}catch(Exception e){
			data.setErrCode(-1);
			data.setErrMsg(e.getMessage());
		}
		
		return data;
		
		
	}    
}

结果

这样一来,浏览器就能清楚地知道后台报了什么错误了。

但是这样有一个问题,虽然后台报错了,但是数据依然进了数据库。这里我们就需要规定,所有的业务操作不应该放在controller类中,都应该放到service类中。而且,这边还涉及到一个事务回滚的问题。这些知识点会在以后讲到。

现在,我们来看一下数据库:

发现一个问题,两条数据的用户名是重复的,在实际情况下,用户名和ID一样,是唯一的。所以,我们需要判断一下用户名是否重复?

package com.app.controller;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import com.app.bean.ResultData;
import com.app.bean.Student;
import com.app.service.UserService;
import com.app.service.impl.UserServiceImpl;

UserController 

@Controller
public class UserController {
	
	//用户业务类的引用
	private UserService userService = new UserServiceImpl();
	
	@RequestMapping("/addUser")
	@ResponseBody
	public ResultData addUser(HttpServletRequest request , HttpServletResponse response,Student student){
		ResultData data = new ResultData();
		
		try{
			
			//先判断用户名是否重复
			
			int count = userService.getByUserName(student);
			
			if(count > 0){
				data.setErrCode(-1);
				data.setErrMsg("用户名已经存在啦,换一个吧。。。");
			}
			
			userService.addUser(student);
		}catch(Exception e){
			data.setErrCode(-1);
			data.setErrMsg(e.getMessage());
		}
		
		return data;
		
		
	}    
}

UserServiceImpl

package com.app.service.impl;

import com.app.bean.Student;
import com.app.dao.UserDao;
import com.app.dao.impl.UserDaoImpl;
import com.app.service.UserService;

public class UserServiceImpl implements UserService{
	
	private UserDao userDao = new UserDaoImpl();

	@Override
	public void addUser(Student student) {
		
		userDao.addUser(student);
		
	}

	@Override
	public int getByUserName(Student student) {
		
		return userDao.getByUserName(student);
	}

}

UserDaoImpl

package com.app.dao.impl;

import java.util.HashMap;
import java.util.Map;

import com.app.bean.Student;
import com.app.dao.UserDao;
import com.simple.dao.SimpleDao;

public class UserDaoImpl implements UserDao {

	@Override
	public void addUser(Student student) {
		
		SimpleDao dao = new SimpleDao();
		
		Map map = new HashMap();
		
		map.put("id", null);
		map.put("username", student.getUsername());
		map.put("password", student.getPassword());
		map.put("name", student.getName());
		map.put("sex", student.getSex());
		
		dao.save("db_student", "t_student", map);
		
	}

	@Override
	public int getByUserName(Student student) {
		
		String sql = "select count(1) from t_student where username = ?";
		
		SimpleDao dao = new SimpleDao();
		return dao.queryForInt(sql, student.getUsername());
	}

}

效果:

在保存操作之前,我们先判断一下用户名在表里是否存在,只要存在了,就给他返回一个错误。OK,让我们看一下数据库:

我去,怎么还是保存进去啦,喵喵喵?

让我们再回过去看一下controller的方法:

@Controller
public class UserController {
	
	//用户业务类的引用
	private UserService userService = new UserServiceImpl();
	
	@RequestMapping("/addUser")
	@ResponseBody
	public ResultData addUser(HttpServletRequest request , HttpServletResponse response,Student student){
		ResultData data = new ResultData();
		
		try{
			
			//先判断用户名是否重复
			
			int count = userService.getByUserName(student);
			
			if(count > 0){
				data.setErrCode(-1);
				data.setErrMsg("用户名已经存在啦,换一个吧。。。");
			}
			
			userService.addUser(student);
		}catch(Exception e){
			data.setErrCode(-1);
			data.setErrMsg(e.getMessage());
		}
		
		return data;
		
		
	}    
}

发现问题了,我们只是给data对象设置了错误码和错误信息,但是保存方法依然执行了,所以,我们需要及时return:

再来一次,就好了。

我要下载源码

posted on 2018-02-01 08:42  剽悍一小兔  阅读(675)  评论(1编辑  收藏  举报