简单ssh注解模式搭建

项目目录结构如下:

引入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(int 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;
	}
	
	
}
编写测试页测试程序是否成功运行!

。。。。。。。配置完成!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值