简单ssh注解模式搭建
2017-12-14 14:43
274 查看
项目目录结构如下:
引入jar包到WebContent----->WEB-INF----->lib下:
配置web.xml文件,在WEB-INF下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>studyssh04</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>SetCharacterEncoding</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>SetCharacterEncoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
</filter-class>
<!-- 自动扫描action -->
<init-param>
<param-name>actionPackages</param-name>
<param-value>com.aishang.action</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
</web-app>配置在WEB-INF下spring和hibernate的application.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"
"http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
<!-- 将对象交给spring管理 -->
<constant name="struts.objectFactory" value="spring" />
<!-- 指定资源编码类型 -->
<constant name="struts.i18n.encoding" value="UTF-8" />
</struts>配置User.java实体类:
package com.aishang.domain;
import java.io.Serializable;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import org.hibernate.annotations.Cascade;
//注解声明实体类
@Entity
//对应数据库的指定表
@Table(name="tb_ssh_user")
public class User implements Serializable {
/**
*
*/
private static final long serialVersionUID = 7277944810719217303L;
//指定id
@Id
//id自增
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
//对象属性与数据库表的列名相对应
@Column(name="userName")
private String userName;
@Column(name="userPass")
private String userPass;
@OneToMany(mappedBy = "user") //指定一对多关系
@Cascade(value=org.hibernate.annotations.CascadeType.SAVE_UPDATE) //设定级联关系
@JoinColumn(name="uid")
private Set<User_Menu> menus;
public User() {
super();
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getUserPass() {
return userPass;
}
public void setUserPass(String userPass) {
this.userPass = userPass;
}
public Set<User_Menu> getMenus() {
return menus;
}
public void setMenus(Set<User_Menu> menus) {
this.menus = menus;
}
}
User_Menu.java实体类:
package com.aishang.domain;
import java.io.Serializable;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
@Entity
@Table(name="tb_ssh_user_menu")
public class User_Menu implements Serializable{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
@ManyToOne
@JoinColumn(name="uid")
private User user;
@ManyToOne
@JoinColumn(name="mid")
private Menu menu;
public User_Menu() {
super();
// TODO Auto-generated constructor stub
}
public int getId() {
return id;
}
public void setId(in
a4b3
t id) {
this.id = id;
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public Menu getMenu() {
return menu;
}
public void setMenu(Menu menu) {
this.menu = menu;
}
}
Menu.java实体类
package com.aishang.dao;
import java.util.List;
import javax.annotation.Resource;
import org.hibernate.Hibernate;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.stereotype.Repository;
import com.aishang.domain.User;
@Repository
public class UserDao {
@Resource(name="sessionFactory")
private SessionFactory sessionFactory;
private Session session;
public UserDao() {
super();
}
/**
* 查询用户信息方法
* @return list<User> 集合
*/
@SuppressWarnings("unchecked")
public List<User> queryUsers(){
session = sessionFactory.openSession();
String hql = "from User";
Query query = session.createQuery(hql);
return (List<User>)query.list();
}
/**
* 用户登录
* @param user
* @return user
*/
public User loginUser(User user){
session = sessionFactory.openSession();
String hql = "from User where userName = ? and userPass = ?";
Query query = session.createQuery(hql);
query.setParameter(0, user.getUserName(),Hibernate.STRING);
query.setParameter(1, user.getUserPass(),Hibernate.STRING);
return (User) query.uniqueResult();
}
public SessionFactory getSessionFactory() {
return sessionFactory;
}
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
public Session getSession() {
return session;
}
public void setSession(Session session) {
this.session = session;
}
}配置UserService.java业务逻辑层:
package com.aishang.service;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.aishang.dao.UserDao;
import com.aishang.domain.User;
@Service
@Transactional
public class UserService {
@Resource
private UserDao userdao;
public UserService() {
super();
}
//查询用户信息
public List<User> showUsers(){
return userdao.queryUsers();
}
//用户登陆
public User isLoginUser(User user){
return userdao.loginUser(user);
}
public UserDao getUserdao() {
return userdao;
}
public void setUserdao(UserDao userdao) {
this.userdao = userdao;
}
}配置UserAction.java控制层
package com.aishang.service;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.aishang.dao.UserDao;
import com.aishang.domain.User;
@Service
@Transactional
public class UserService {
@Resource
private UserDao userdao;
public UserService() {
super();
}
//查询用户信息
public List<User> showUsers(){
return userdao.queryUsers();
}
//用户登陆
public User isLoginUser(User user){
return userdao.loginUser(user);
}
public UserDao getUserdao() {
return userdao;
}
public void setUserdao(UserDao userdao) {
this.userdao = userdao;
}
}编写测试页测试程序是否成功运行!
。。。。。。。配置完成!
引入jar包到WebContent----->WEB-INF----->lib下:
配置web.xml文件,在WEB-INF下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>studyssh04</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>SetCharacterEncoding</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>SetCharacterEncoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
</filter-class>
<!-- 自动扫描action -->
<init-param>
<param-name>actionPackages</param-name>
<param-value>com.aishang.action</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
</web-app>配置在WEB-INF下spring和hibernate的application.xml:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"> <!-- 自动扫描与装配bean --> <context:component-scan base-package="com.aishang"></context:component-scan> <!-- 定义c3p0数据源 --> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <!-- 指定连接数据库驱动 --> <property name="driverClass" value="com.mysql.jdbc.Driver" /> <!-- 指定连接数据库url --> <property name="jdbcUrl" value="jdbc:mysql://127.0.0.1:3306/db_ssh" /> <!-- 指定连接数据库用户名 --> <property name="user" value="root" /> <!-- 密码 --> <property name="password" value="root" /> </bean> <!-- 定义Hibernate的sessionFactory --> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> <!-- 指定数据源 --> <property name="dataSource" ref="dataSource" /> <property name="hibernateProperties"> <props> <!-- 指定使用方言 --> <prop key="hibernate.dialect"> org.hibernate.dialect.MySQLDialect </prop> <!-- 是否在控制台输出sql语句 --> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <!-- 自动创建表 --> <prop key="hibernate.hbm2ddl.auto">update</prop> <!-- 连接池 --> <prop key="hibernate.jdbc.batch_size">1</prop> </props> </property> <!--自动扫描实体 --> <property name="packagesToScan" value="com.aishang.domain" /> </bean> <!-- 用注解来实现事务管理 --> <bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory"></property> </bean> <tx:annotation-driven transaction-manager="txManager"/> </beans>配置在src下struts2的struts.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"
"http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
<!-- 将对象交给spring管理 -->
<constant name="struts.objectFactory" value="spring" />
<!-- 指定资源编码类型 -->
<constant name="struts.i18n.encoding" value="UTF-8" />
</struts>配置User.java实体类:
package com.aishang.domain;
import java.io.Serializable;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import org.hibernate.annotations.Cascade;
//注解声明实体类
@Entity
//对应数据库的指定表
@Table(name="tb_ssh_user")
public class User implements Serializable {
/**
*
*/
private static final long serialVersionUID = 7277944810719217303L;
//指定id
@Id
//id自增
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
//对象属性与数据库表的列名相对应
@Column(name="userName")
private String userName;
@Column(name="userPass")
private String userPass;
@OneToMany(mappedBy = "user") //指定一对多关系
@Cascade(value=org.hibernate.annotations.CascadeType.SAVE_UPDATE) //设定级联关系
@JoinColumn(name="uid")
private Set<User_Menu> menus;
public User() {
super();
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getUserPass() {
return userPass;
}
public void setUserPass(String userPass) {
this.userPass = userPass;
}
public Set<User_Menu> getMenus() {
return menus;
}
public void setMenus(Set<User_Menu> menus) {
this.menus = menus;
}
}
User_Menu.java实体类:
package com.aishang.domain;
import java.io.Serializable;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
@Entity
@Table(name="tb_ssh_user_menu")
public class User_Menu implements Serializable{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
@ManyToOne
@JoinColumn(name="uid")
private User user;
@ManyToOne
@JoinColumn(name="mid")
private Menu menu;
public User_Menu() {
super();
// TODO Auto-generated constructor stub
}
public int getId() {
return id;
}
public void setId(in
a4b3
t id) {
this.id = id;
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public Menu getMenu() {
return menu;
}
public void setMenu(Menu menu) {
this.menu = menu;
}
}
Menu.java实体类
package com.aishang.domain; import java.io.Serializable; import java.util.Set; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToMany; import javax.persistence.Table; import org.hibernate.annotations.Cascade; @Entity @Table(name="tb_ssh_menu") public class Menu implements Serializable { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private int id; @Column(name="menuName") private String menuName; @Column(name="menuURL") private String menuURL; @OneToMany(mappedBy = "menu") //指定一对多关系 @Cascade(value=org.hibernate.annotations.CascadeType.SAVE_UPDATE) @JoinColumn(name="mid") private Set<User_Menu> user_menu; public Menu() { super(); // TODO Auto-generated constructor stub } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getMenuName() { return menuName; } public void setMenuName(String menuName) { this.menuName = menuName; } public String getMenuURL() { return menuURL; } public void setMenuURL(String menuURL) { this.menuURL = menuURL; } public Set<User_Menu> getUser_menu() { return user_menu; } public void setUser_menu(Set<User_Menu> user_menu) { this.user_menu = user_menu; } }配置UserDao.java持久层
package com.aishang.dao;
import java.util.List;
import javax.annotation.Resource;
import org.hibernate.Hibernate;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.stereotype.Repository;
import com.aishang.domain.User;
@Repository
public class UserDao {
@Resource(name="sessionFactory")
private SessionFactory sessionFactory;
private Session session;
public UserDao() {
super();
}
/**
* 查询用户信息方法
* @return list<User> 集合
*/
@SuppressWarnings("unchecked")
public List<User> queryUsers(){
session = sessionFactory.openSession();
String hql = "from User";
Query query = session.createQuery(hql);
return (List<User>)query.list();
}
/**
* 用户登录
* @param user
* @return user
*/
public User loginUser(User user){
session = sessionFactory.openSession();
String hql = "from User where userName = ? and userPass = ?";
Query query = session.createQuery(hql);
query.setParameter(0, user.getUserName(),Hibernate.STRING);
query.setParameter(1, user.getUserPass(),Hibernate.STRING);
return (User) query.uniqueResult();
}
public SessionFactory getSessionFactory() {
return sessionFactory;
}
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
public Session getSession() {
return session;
}
public void setSession(Session session) {
this.session = session;
}
}配置UserService.java业务逻辑层:
package com.aishang.service;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.aishang.dao.UserDao;
import com.aishang.domain.User;
@Service
@Transactional
public class UserService {
@Resource
private UserDao userdao;
public UserService() {
super();
}
//查询用户信息
public List<User> showUsers(){
return userdao.queryUsers();
}
//用户登陆
public User isLoginUser(User user){
return userdao.loginUser(user);
}
public UserDao getUserdao() {
return userdao;
}
public void setUserdao(UserDao userdao) {
this.userdao = userdao;
}
}配置UserAction.java控制层
package com.aishang.service;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.aishang.dao.UserDao;
import com.aishang.domain.User;
@Service
@Transactional
public class UserService {
@Resource
private UserDao userdao;
public UserService() {
super();
}
//查询用户信息
public List<User> showUsers(){
return userdao.queryUsers();
}
//用户登陆
public User isLoginUser(User user){
return userdao.loginUser(user);
}
public UserDao getUserdao() {
return userdao;
}
public void setUserdao(UserDao userdao) {
this.userdao = userdao;
}
}编写测试页测试程序是否成功运行!
。。。。。。。配置完成!
相关文章推荐
- 简单搭建注解ssh项目(二)
- 简单搭建注解ssh项目(一)
- 【SSH进阶之路】Hibernate搭建开发环境+简单实例(二)
- SSH环境搭建好的情况下的简单总结
- 简单的SSH整合(基于注解和xml文件的配置)
- [ASP.NET 设计模式] 用Visual Studio2010搭建一个简单的分层结构示例Step by Step —— 05 表现层
- 【SSH 框架项目的搭建--简化版】使用注解代替xml中的<bean>,减少代码量
- SSH(Struts2+Spring+Hibernate)框架搭建流程<注解的方式创建Bean>
- Spring MVC 4.1.3 + MyBatis 零基础搭建Web开发框架(注解模式哦)
- 从零开始搭建 一个完善的 MVP模式开发框架(一),MVP模式的简单介绍篇
- 【SSH进阶之路】Hibernate搭建开发环境+简单实例(二)
- Spring MVC + MyBatis+Maven 零基础搭建Web开发框架(注解模式哦)
- ######crm01_最快速:搭建纯注解ssh整合环境(只用一个Spring配置)素材提供jar包,只有两步工作:①写Spring配置②写ssh注解+简单逻辑=遇到action创建失败问题
- 【SSH进阶之路】Hibernate搭建开发环境+简单实例(二)
- ssh项目使用注解搭建
- [ASP.NET 设计模式] 用Visual Studio2010搭建一个简单的分层结构示例Step by Step —— 06 用户界面层
- 搭建基于注解方式的SSH项目框架
- Spring MVC 4.1.3 + MyBatis 零基础搭建Web开发框架(注解模式)
- SSH整合案例------使用idea maven搭建 非注解版
- 关于ftp,ssh,nfs平台搭建的简单总结