一篇文章上手SSH開發,單表全過程,全程式碼
阿新 • • 發佈:2019-02-19
更多SSH開發在框架開發
1 SSH專案的一些部署
1.1 專案目標與版本介紹
目標: 使用者單表的新增,查詢與刪除操作
版本: hibernate-release-5.0.12.Final
,spring-framework-4.2.4.RELEASE-dist
,struts-2.3.24-all
1.2 SSH知識分析
Spring的一些提醒點:
- 讓Spring的配置檔案在伺服器啟動的時候載入,所以需要在web.xml中配置監聽器和指定spring配置檔案的位置。
- Spring的配置檔案可以弄成多模組開發。即,將程式碼過多的spring配置檔案分成多個小的配置檔案,這些小配置檔案在總配置檔案中引入即可。
Spring整合Struts2的一些提醒點:
- 不要忘記web.xml中要引入過濾器
- 整合後要將Struts2中的action交給Spring管理,並且將action配置成多例項的。
Spring整合Hibernate的一些提醒點:
- Hibernate的SessionFactory交給Spring配置。Hibernate的SessionFactory物件建立在第一次呼叫的時候建立,會造成第一次訪問很慢,而Spring配置檔案會在伺服器啟動時載入,所以將SessionFactory的建立交給Spring以增加速度。
- Hibernate的資料庫配置交給Spring配置。
- HibernateTemplate的使用需要Spring事務管理的加持。
2 SSH專案
2.0 專案的前期部署
開發工具 :tomcat9.0+jdk8+eclipse+mysql8.0+linux(ubuntu18.04)平臺
資料庫建立:
create database db_sshUser;
導jar包操作:
包 | 包 |
---|---|
2.1 建立專案
本文專案所有目錄結構如下:
2.2 前端的一些jsp
listAll.jsp, 主頁面。
功能:
- 顯示查詢的所有使用者: 用到struts2的OGNL+值棧
- 根據id刪除使用者: 超連結形式向action中傳遞了一個使用者id。
- 跳轉新增頁面的超連結 : 超連結到另一個新增jsp頁面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!--引入struts標籤庫 -->
<%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>所有使用者</title>
</head>
<body>
<a href="${pageContext.request.contextPath}/user_findAll">檢視所有使用者</a>
<table>
<tr>
<td>名字</td>
<td>地址</td>
<td>操作</td>
</tr>
<!-- 使用OGNL+struts標籤的方式取到值棧中的內容,常用 -->
<s:iterator value="userList" var="user">
<tr>
<td><s:property value="#user.username"/></td>
<td><s:property value="#user.useraddress"/></td>
<td>
<a href="${pageContext.request.contextPath}/user_delUser?uid=<s:property value="#user.uid"/>">刪除該使用者</a>
</td>
</tr>
</s:iterator>
</table>
<a href="${pageContext.request.contextPath}/jsp/addUser.jsp">新增使用者</a>
</body>
</html>
addUser.jsp, 新增頁面
功能:
- 提交新增屬性表單到action中處理
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>新增使用者</title>
</head>
<body>
<form action="${pageContext.request.contextPath}/user_addUser.action" method="post">
使用者名稱:<input type="text" name="username" /><br>
地 址:<input type="text" name="useraddress" /><br>
<input type="submit" value="新增"/>
</form>
</body>
</html>
2.3 web.xml
web.xml 中引入 struts2的過濾器配置,讓Spring配置檔案隨伺服器一起啟動的監聽器配置和指定Spring配置檔案的路徑配置。
<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_9" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>User</display-name>
<!-- 指定Spring配置檔案的位置 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:bean1.xml</param-value>
</context-param>
<!-- 過濾器 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<!-- 監聽器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
</web-app>
2.4 實體類
User,要符合hibernate要求的實體類建立規則
package edu.kmust.user.entity;
/**
* 使用者實體類
* @author zhaoyuqiang
*
*/
public class User {
private Integer uid;
private String username;
private String useraddress;
。。。因為程式碼過長,省略set和get方法,讀者自行新增
}
2.5 hibernate的一些配置
User.hbm.xml ,配置實體類與表的對映關係
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="edu.kmust.user.entity">
<!--建立類和表的對映關係 -->
<class name="User" table="tb_users">
<!--建立實體類屬性與主鍵的對映關係 -->
<id name="uid" column="id">
<generator class="native"/>
</id>
<!--建立實體類其餘屬性與表字段的對映關係 -->
<property name="username" />
<property name="useraddress" />
</class>
</hibernate-mapping>
hibernate.cfg.xml ,hibernate的核心對映配置檔案,引入上述的對映配置檔案。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property> <!--配置方言 -->
<property name="hibernate.hbm2ddl.auto">update</property> <!--在SessionFactory建立時自動更新表結構,沒有建立,不一樣就修改 -->
<!-- 載入對映配置 -->
<mapping resource="edu/kmust/user/entity/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
2.6 web層的action
UserAction
功能:
- 採用模型驅動的方式封裝表單資料
- 採用傳統Servlet的方式獲取超連結中的引數
- 新增,刪除,查詢功能的web層處理
package edu.kmust.user.action;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;
import edu.kmust.user.entity.User;
import edu.kmust.user.service.UserService;
/**
* 使用者表示層
* @author zhaoyuqiang
*
*/
public class UserAction extends ActionSupport implements ModelDriven<User>{
//注入service
private UserService userService ;
public void setUserService(UserService userService) {
this.userService = userService;
}
//封裝表單屬性
private User user = new User();
//定義返回的userList
private List<User> userList ;
public List<User> getUserList() {
return userList;
}
/**
* 刪除使用者
* @return
*/
public String delUser() {
HttpServletRequest request = ServletActionContext.getRequest();
Integer uid = Integer.valueOf(request.getParameter("uid"));
user.setUid(uid);
userService.delUser(user);
return "del" ;
}
/**
* 使用者新增
* @return
*/
public String addUser() {
userService.addUser(user);
return "add" ;
}
/**
* 查詢所有使用者
* @return
*/
public String findAll() {
userList = userService.findAll();
return "findAll" ;
}
/**
* 實現ModelDriven介面中的方法
*/
@Override
public User getModel() {
return user;
}
}
2.7 Struts的一些配置檔案
Struts.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<package name="user" extends="struts-default" namespace="/">
<action name="user_*" class="userAction" method = "{1}">
<result name="add" type="redirectAction">user_findAll</result>
<result name="findAll">/jsp/listAll.jsp</result>
<result name="del" type="redirectAction">user_findAll</result>
</action>
</package>
</struts>
2.8 service層
UserService
package edu.kmust.user.service;
import java.util.List;
import org.springframework.transaction.annotation.Transactional;
import cn.kmust.user.dao.userDao;
import edu.kmust.user.entity.User;
/**
* 使用者業務層
* @author zhaoyuqiang
*
*/
@Transactional
public class UserService {
//service注入dao
private userDao userDao ;
public void setUserDao(userDao userDao) {
this.userDao = userDao;
}
/**
* 新增使用者業務
* @param user
*/
public void addUser(User user) {
userDao.addUser(user);
}
/**
* 查詢所有使用者業務
*/
public List<User> findAll() {
List<User> userList = userDao.findAll();
return userList ;
}
/**
* 刪除使用者
* @param user
*/
public void delUser(User user) {
userDao.delUser(user);
}
}
2.9 dao層
UserDao介面
package cn.kmust.user.dao;
import java.util.List;
import edu.kmust.user.entity.User;
/**
* 使用者介面
* @author zhaoyuqiang
*
*/
public interface userDao {
/**
* 新增使用者
* @param user
*/
public void addUser(User user);
/**
* 查詢所有使用者
* @return
*/
public List<User> findAll();
/**
* 根據id查詢使用者
* @param user
* @return
*/
public User findById(User user);
/**
* 條件查詢_根據使用者名稱查詢
* @param user
* @return
*/
public List<User> findByCondi(User user);
/**
* 根據id刪除使用者
* @param user
*/
public void delUser(User user);
}
UserDaoImpl,UserDao介面的實現類
使用hibernateTemplate
package cn.kmust.user.dao;
import java.util.List;
import org.springframework.orm.hibernate5.HibernateTemplate;
import edu.kmust.user.entity.User;
/**
* 使用者介面實現類
* @author zhaoyuqiang
*
*/
public class UserDaoImpl implements userDao {
private HibernateTemplate hibernateTemplate ;
public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {
this.hibernateTemplate = hibernateTemplate;
}
/**
* 新增使用者
*/
public void addUser(User user) {
hibernateTemplate.save(user);
}
/**
* 查詢所有使用者
*/
public List<User> findAll() {
String hql = "from User" ;
return (List<User>) hibernateTemplate.find(hql) ;
}
/**
* 根據id查詢使用者
*/
public User findById(User user) {
return hibernateTemplate.get(User.class, user.getUid());
}
/**
* 條件查詢_根據使用者名稱查詢
*/
public List<User> findByCondi(User user) {
String hql = "from User where username=?" ;
return (List<User>) hibernateTemplate.find(hql, user.getUsername());
}
/**
* 根據uid刪除使用者
*/
public void delUser(User user) {
hibernateTemplate.delete(user);
}
}
2.10 Spring的一些配置
Spring分模組的思想就是將大的配置檔案拆分成幾個小的,小的檔案在主檔案中引入即可,主配置檔案就是web.xml中指定的那個檔案。一般將每個模組如User的三層架構作為一個子模組。
2.10.1 配置主配置檔案
bean1.xml ,Spring的主配置檔案。
包含:
- 引入全約束
- 配置c3p0與資料庫的資訊
- 負責建立hibernate中sessionFactory的建立
- 負責hibernateTemplate模板的建立
- 事務管理的配置
- 引入spring模組配置檔案
<?xml version="1.0" encoding="UTF-8"?>
<!-- 引入一個全面的Spring約束,包含了beans,aop,事務等基本操作 -->
<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:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
<!-- 配置c3p0資料庫相關 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql:///db_sshUser?useSSL=false"></property>
<property name="user" value="root"></property>
<property name="password" value="root"></property>
</bean>
<!--配置Hibernate中的sessionFactory的建立,該類在Spring中有現成的建立-->
<bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
<!-- hibernate核心配置檔案沒有資料庫了,所以sessionFactory中先注入資料庫 -->
<property name="dataSource" ref="dataSource"></property>
<!-- 指定使用hibernate核心配置檔案-->
<property name="configLocations" value="classpath:hibernate.cfg.xml"></property>
</bean>
<!-- 建立hibernate模板物件 -->
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate5.HibernateTemplate">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<!-- 事務配置,hibernateTransactionManager,最好注入sessionFactory,也可以注入dataSource -->
<bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
<!--引入userBean1.xml -->
<import resource="classpath:userBean1.xml"/>
</beans>
3.10.2 Spring模組配置檔案
userBean1.xml
包含:
- User相關的 :struts中action的建立,service的建立,dao的建立,以及這三層架構的相互注入
- dao層需要注入hibernateTemplate
<?xml version="1.0" encoding="UTF-8"?>
<!-- 引入一個全面的Spring約束,包含了beans,aop,事務等基本操作 -->
<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:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
<!--User三層框架的相互注入 -->
<bean id="userAction" class="edu.kmust.user.action.UserAction" scope="prototype">
<property name="userService" ref="userService"></property>
</bean>
<bean id="userService" class="edu.kmust.user.service.UserService">
<property name="userDao" ref="userDaoImpl"></property>
</bean>
<bean id="userDaoImpl" class="cn.kmust.user.dao.UserDaoImpl">
<property name="hibernateTemplate" ref="hibernateTemplate"></property>
</bean>
</beans>