您的位置:首页 > 其它

简单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"?>
<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 注解配置