1. 程式人生 > >一篇文章上手SSH開發,單表全過程,全程式碼

一篇文章上手SSH開發,單表全過程,全程式碼

更多SSH開發在框架開發

1 SSH專案的一些部署

1.1 專案目標與版本介紹

目標: 使用者單表的新增,查詢與刪除操作

版本: hibernate-release-5.0.12.Finalspring-framework-4.2.4.RELEASE-diststruts-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>

3 本文相關程式碼參考