您的位置:首页 > 编程语言 > Java开发

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

2016-05-12 18:44 645 查看
转载注明出处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下载地址
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: