转载注明出处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的童鞋会知道下面这个配置:
这边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);
}
}
这样子就实现了像手机传递数据无图无真相 ,上图:
数据库表之前的数据:
然后我们先注册一个
现在数据库表的数据为:
最后我们登录看一下:
ok,成功了。
关于RegAction里面的传值,应该发现和上篇博客不同,我们用的是DomainModel(域模型)方法传值(工程中最常用)的方式。通过getUser方法将User对象传给Struts2,Struts2调用setter方法进行赋值。所以使用这个方法传参数的key一般都是确定了这样说也许你们就晕了,上图说:
key一般都是实体类.属性的形式,我们只需把这个传过去,Struts2自己会处理,如果对这个还不是很明白,可以去搜索:Struts2三种传值方法
到这里关于与手机交互就结束了,感谢大家对我的支持,如有疑问,可以给我留言,行业交流,很惭愧只做了这点事情!蟹蟹大家!
所用Demo下载地址