Java之基于S2SH与手机数据交互(二)

转载注明出处http://blog.csdn.net/SnowWitch/article/details/51280141

在上篇博客,由于各种原因,说的不是很详细,其实大家看一下代码,就能明白了。今天说一下如何从数据库获取数据,并传递给手机端进行数据交互。上篇博客是传的固定数据,然后转成json格式,其实有开发的经验的童鞋,应该就能看出来,我们只需要在那个action方法里面实现数据处理,然后把要返回的数据转成json,然后手机端就获取到了想要的结果。上篇博客不说与数据库交互,是想让有想法的童鞋,去尝试,有些看懂和经历过,感觉不一样哦~。
进入正题,我们用的S2SH框架,其中H代表的啥,这个我就不用说了吧!首先我们要创建一个实体类,并创建hibernate映射表。
首先创建User实体类。

    public class User {
        private Integer id;
        private String name;
        private String pwd;
        private String userName;
        private String status;
        /....../ //此处省略get和set及构造方法
    }   

里面的参数,要与user表字段一一对应,然后就是写映射表User.hbm.xml

<?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    <!-- Mapping file autogenerated by MyEclipse Persistence Tools -->
    <hibernate-mapping>
        <class name="com.hy.entity.User" table="user">
            <id name="id">
                <column name="ID" />
                <generator class="increment" />
            </id>
            <property name="userName" type="java.lang.String">
                <column name="userName" />
            </property>
            <property name="pwd" type="java.lang.String">
                <column name="pwd" />
            </property>
            <property name="name" type="java.lang.String">
                <column name="name" />
            </property>
            <property name="status" type="java.lang.String">
                <column name="status" />
            </property>
        </class>
    </hibernate-mapping>

映射表不清楚的小伙伴, Java之基于Eclipse搭建SSH框架(下)去这篇博客里学习一下。
接下来就是DAO数据访问层,首先创建一个UserDao接口:

    public interface UserDao {
        //查询
        public List<User> queryUser(String hql);
        //插入
        public void insertUser(User user);

    }

然后创建一个类UserDaoImpl,这个类继承HibernateDaoSupport,并实现UerDao这个接口。

public class UserDaoImpl extends HibernateDaoSupport implements UserDao {

        @Override
        public List<User> queryUser(String hql) {
            try {
                return super.getHibernateTemplate().find(hql);
            } catch (Exception e) {
                e.printStackTrace();
                return null;
            }
        }

        @Override
        public void insertUser(User user) {
            this.getHibernateTemplate().save(user);
        }

    }

配置过Spring的童鞋会知道下面这个配置:
Java之基于S2SH与手机数据交互(二)_第1张图片
这边sessionFactory依赖注入的不是给Dao层中的类,而是给HibernateDaoSupport,在spring源文件里面org/springframework/orm/hibernate3/support/HibernateDaoSupport.java里面,就有sessionFactory的set、get操作:

public final void setSessionFactory(SessionFactory sessionFactory) {
    this.hibernateTemplate = createHibernateTemplate(sessionFactory);//通过sessionFactory来生成hibernateTemplate
}

public final SessionFactory getSessionFactory() {
    return (this.hibernateTemplate != null ? this.hibernateTemplate.getSessionFactory() : null);
}

所以在Dao层中类继承HibernateDaoSupport,即可通过this.getHibernateTemplate()来对数据库进行操作。
更新数据:this.getHibernateTemplate().update(user);
查询数据:this.getHibernateTemplate().find(user);
添加数据:this.getHibernateTemplate().save(user) ;
删除数据:this.getHibernateTemplate().delete(user)
下面到了Service业务层,首先创建一个UserService接口:

public interface UserService {
        // 登陆
        public User login(User user);

        // 插入
        public void insertUser(User user);

}

然后新建一个类UserServiceImpl,实现这个接口;

    public class UserServiceImpl implements UserService {
        private UserDao userDao;

        public UserDao getUserDao() {
            return userDao;
        }

        public void setUserDao(UserDao userDao) {
            this.userDao = userDao;
        }

        @Override
        public User login(User user) {
            // hql查询语句
            String hql = "from User u where u.name = '" + user.getName() + "'"
                    + " and u.pwd = '" + user.getPwd() + "'";
            List<User> list = (List<User>) userDao.queryUser(hql);
            if (list.size() == 0) {
                User us = new User();
                return us;
            }
            return list.get(0);
        }

        // 插入
        @Override
        public void insertUser(User user) {
            userDao.insertUser(user);
        }

    }   

业务层主要就是把从action层传过来的数据,然后调用dao层去做相应操作。
最后就到了action层了。
新建一个RegAction

public class RegAction extends ActionSupport {
        /** * */
        private static final long serialVersionUID = 1L;
        private UserService userService;
        private User user;

        public UserService getUserService() {
            return userService;
        }

        public void setUserService(UserService userService) {
            this.userService = userService;
        }

        public User getUser() {
            return user;
        }

        public void setUser(User user) {
            this.user = user;
        }

        public void login() {
            User result = userService.login(user);
            ActionContext.getContext().put("list", result);
            ResponseJsonUtils.json(ServletActionContext.getResponse(), result);

        }

        public void insert() {
            userService.insertUser(user);
        }
    }   

这样子就实现了像手机传递数据无图无真相 这里写图片描述,上图:
数据库表之前的数据:
Java之基于S2SH与手机数据交互(二)_第2张图片

然后我们先注册一个

Java之基于S2SH与手机数据交互(二)_第3张图片

现在数据库表的数据为:

Java之基于S2SH与手机数据交互(二)_第4张图片

最后我们登录看一下:

Java之基于S2SH与手机数据交互(二)_第5张图片
ok,成功了。
关于RegAction里面的传值,应该发现和上篇博客不同,我们用的是DomainModel(域模型)方法传值(工程中最常用)的方式。通过getUser方法将User对象传给Struts2,Struts2调用setter方法进行赋值。所以使用这个方法传参数的key一般都是确定了这样说也许你们就晕了,上图说:
Java之基于S2SH与手机数据交互(二)_第6张图片
key一般都是实体类.属性的形式,我们只需把这个传过去,Struts2自己会处理,如果对这个还不是很明白,可以去搜索:Struts2三种传值方法

到这里关于与手机交互就结束了,感谢大家对我的支持,如有疑问,可以给我留言,行业交流,很惭愧只做了这点事情!蟹蟹大家!

所用Demo下载地址

你可能感兴趣的:(java,数据库,数据,手机,s2sh)