/**
* @author jeedroid
*/
package com.jeedroid.dao;
import com.jeedroid.model.User;
public interface UserDao
{
public abstract boolean addUser(User user);
}
package com.jeedroid.daoimpl;
import org.hibernate.SessionFactory;
import org.springframework.dao.DataAccessException;
import org.springframework.orm.hibernate3.HibernateTemplate;
import com.jeedroid.dao.UserDao;
import com.jeedroid.model.User;
public class UserDaoImpl implements UserDao
{
private SessionFactory sessionFactory;
public void setSessionFactory(SessionFactory sessionFactory)
{
this.sessionFactory = sessionFactory;
}
@Override
public boolean addUser(User user)
{
try {
HibernateTemplate hibernateTemplate =new HibernateTemplate(sessionFactory);
hibernateTemplate.saveOrUpdate(user);
return true;
} catch (DataAccessException e) {
e.printStackTrace();
return false;
}
}
}
/**
* @author jeedroid
*/
package com.jeedroid.action;
import com.jeedroid.daoimpl.UserDaoImpl;
import com.jeedroid.model.User;
import com.opensymphony.xwork2.ActionSupport;
public class RegisterAction extends ActionSupport
{
private User user;
private UserDaoImpl userDaoImpl;
public User getUser()
{
return user;
}
public void setUser(User user)
{
this.user = user;
}
public void setUserDaoImpl(UserDaoImpl userDaoImpl)
{
this.userDaoImpl = userDaoImpl;
}
@Override
public String execute() throws Exception
{
if(userDaoImpl.addUser(user))
return SUCCESS;
else
return INPUT;
}
}
/success.jsp
/register.jsp
applicationContext.xml:
com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/spring_hibernate
root
123321
org.hibernate.dialect.MySQL5Dialect
true
com/jeedroid/model/User.hbm.xml
之前一直报attempt to create saveOrUpdate event with null entity这个错误,后来把User.java里的含参构造函数去掉就行了 应该是struts2传值过来时实例化的问题
只是一个简单的用户注册 没有加事务了什么的 看看就行了 呵呵
1
顶
1
踩
分享到:
2011-12-03 21:16
浏览 7905
评论