使用过PageData 工具类的伙伴都知道 PageData 继承 HashMap 并实现 Map。PageData 的主要作用是将前端传递过来的参数解析并封装成Map, 通过pageData.get(key)就可以很方便取得参数,同样是在Mybatis 的结果类型也可以是PageData。下面介绍PageData工具类的使用。
1.公共的BaseController, 需要使用PageData 工具类必须继承BaseController 类。
public class BaseController {
private static final long serialVersionUID = 6357869213649815390L;
/** new PageData对象
* @return
*/
public PageData getPageData(){
return new PageData(this.getRequest());
}
/**得到ModelAndView
* @return
*/
public ModelAndView getModelAndView(){
return new ModelAndView();
}
/**得到request对象
* @return
*/
public HttpServletRequest getRequest() {
HttpServletRequest request = ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()).getRequest();
return request;
}
}
2 . 重要角色PageData工具类。
/**
* 说明:参数封装Map
*/
public class PageData extends HashMap implements Map{
private static final long serialVersionUID = 1L;
Map map = null;
HttpServletRequest request;
public PageData(HttpServletRequest request){
this.request = request;
Map properties = request.getParameterMap();
Map returnMap = new HashMap();
Iterator entries = properties.entrySet().iterator();
Map.Entry entry;
String name = "";
String value = "";
while (entries.hasNext()) {
entry = (Map.Entry) entries.next();
name = (String) entry.getKey();
Object valueObj = entry.getValue();
if(null == valueObj){
value = "";
}else if(valueObj instanceof String[]){
String[] values = (String[])valueObj;
for(int i=0;i<values.length;i++){
value = values[i] + ",";
}
value = value.substring(0, value.length()-1);
}else{
value = valueObj.toString();
}
returnMap.put(name, value);
}
map = returnMap;
}
public PageData() {
map = new HashMap();
}
//获取值
@Override
public Object get(Object key) {
Object obj = null;
if(map.get(key) instanceof Object[]) {
Object[] arr = (Object[])map.get(key);
obj = request == null ? arr:(request.getParameter((String)key) == null ? arr:arr[0]);
} else {
obj = map.get(key);
}
return obj;
}
//获取类型为String的值
public String getString(Object key) {
return (String)get(key);
}
//添加值
@SuppressWarnings("unchecked")
@Override
public Object put(Object key, Object value) {
return map.put(key, value);
}
//删除值
@Override
public Object remove(Object key) {
return map.remove(key);
}
//清空map
public void clear() {
map.clear();
}
//判断是否包含key
public boolean containsKey(Object key) {
return map.containsKey(key);
}
//判断是否包含value
public boolean containsValue(Object value) {
return map.containsValue(value);
}
public Set entrySet() {
return map.entrySet();
}
//判断是否为空
public boolean isEmpty() {
return map.isEmpty();
}
public Set keySet() {
return map.keySet();
}
@SuppressWarnings("unchecked")
public void putAll(Map t) {
map.putAll(t);
}
//长度
public int size() {
return map.size();
}
public Collection values() {
return map.values();
}
}
3 . UserController类。
@RestController
@RequestMapping("/user")
public class UserController extends BaseController{
@Autowired
private UserService userService;
//添加
@RequestMapping("/insert")
public String insert() {
PageData pd = new PageData();
pd = this.getPageData();
userService.insert(pd);
return "OK";
}
//删除
@RequestMapping("/delete")
public String delete() {
PageData pd = new PageData();
pd = this.getPageData();
userService.delete(pd);
return "OK";
}
//更新
@RequestMapping("/update")
public String update(){
PageData pd = new PageData();
pd = this.getPageData();
userService.update(pd);
return "OK";
}
//通过id查询 ,返回类型是User
@RequestMapping("/findById")
public User findById() {
PageData pd = new PageData();
pd = this.getPageData();
return userService.findById(pd);
}
//通过id查询 ,返回类型是PageData
@RequestMapping("getById")
public PageData getById(){
PageData pd = new PageData();
pd = this.getPageData();
return userService.getById(pd);
}
}
4 .UserService 类。
@Service
public class UserService {
@Autowired
private UserDao userDao;
public void insert(PageData pd) {
userDao.insert(pd);
}
public void delete(PageData pd) {
userDao.delete(pd);
}
public void update(PageData pd) {
userDao.update(pd);
}
public User findById(PageData pd) {
return userDao.findById(pd);
}
public PageData getById(PageData pd) {
return userDao.getById(pd);
}
}
5 . UserDao 类。
@Mapper
public interface UserDao {
void insert(@Param("pd")PageData pd);
void delete(@Param("pd")PageData pd);
void update(@Param("pd")PageData pd);
User findById(@Param("pd")PageData pd);
PageData getById(@Param("pd")PageData pd);
}
6 .最后是UserMapper.xml 。
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.example.demo.dao.UserDao" >
<delete id="delete" >
delete from user
where id = #{pd.id}
</delete>
<insert id="insert" >
insert into user (user_name, age, sex)
values (#{pd.userName},#{pd.age},#{pd.sex})
</insert>
<update id="update">
update user
set user_name = #{pd.userName},
age = #{pd.age},
sex = #{pd.sex}
where id = #{pd.id}
</update>
<select id="findById" resultType="com.example.demo.demain.User">
select id, user_name userName, age, sex
from user
where id = #{pd.id}
</select>
<select id="getById" resultType="com.example.demo.util.PageData">
select id, user_name userName, age, sex
from user
where id = #{pd.id}
</select>
</mapper>
7 . 上面从controller 到 Service 到 Dao 再到 Mapper.xml ,大家可以很清楚的认识到如何使用PageData工具类。
列如添加User
删除User
更新User
查询User,返回的是PageData
上述如有不正确的地方,欢迎各位给予指正。