自定义 PageData 工具类

使用过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
在这里插入图片描述
上述如有不正确的地方,欢迎各位给予指正。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.model; import javax.servlet.http.HttpServletRequest; import java.util.*; /** * 说明:参数封装Map * @version */ 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(); Entry entry; String name = ""; String value = ""; while (entries.hasNext()) { entry = (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; } public static boolean hasVal(PageData pd,String key){ return pd!=null&&pd;.containsKey(key)&&!pd.getString(key).isEmpty(); } public String getString(Object key) { return (String)get(key); } public Integer getInt(Object key) { return Integer.parseInt(getString(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); } public void clear() { map.clear(); } public boolean containsKey(Object key) { // TODO Auto-generated method stub
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值