搭建一個(gè)完整的SSH框架

參考文檔1:https://www.cnblogs.com/yzoro/p/5847015.html
參考文檔2:https://blog.csdn.net/pazezhe314/article/details/79691741?utm_source=blogxgwz7

一纺腊、jar包的下載和選擇

第一步:下載jar包

(1)spring框架的jar包:https://repo.spring.io/
image.png

image.png
(2)hibernate框架的jar包:http://hibernate.org/orm/
image.png

image.png
(3)struts2框架的jar包:https://struts.apache.org/
image.png

image.png
(4)數(shù)據(jù)庫(以mysql為例)連接的jar包:https://dev.mysql.com/downloads/connector/j/
image.png

第二步:選擇三個(gè)框架的基礎(chǔ)jar包文件棺亭,準(zhǔn)備放入搭建的項(xiàng)目里

本項(xiàng)目下載的SSH框架的jar包版本违柏,分別為:hibernate-release-5.4.0.Final(hibernate)、mysql-connector-java-8.0.13(mysql連接)齐婴、spring-framework-5.1.3.RELEASE(spring)、struts-2.5.18(struts2)

(1)struts的基礎(chǔ)jar包:
image.png
(2)spring的jar包(應(yīng)為不多樟澜,所以暫時(shí)全部包括):
image.png
(3)hibernate的基礎(chǔ)jar包:
image.png
(4)mysql連接的jar包:
image.png

二、項(xiàng)目搭建

項(xiàng)目搭建工具:eclipse碉京、navicat premium
項(xiàng)目開發(fā)環(huán)境:①Windows10-64位 ②Tomcat 9.0 ③jdk1.8.0_91 ④MySql 8.0.11

第一步:新建項(xiàng)目,導(dǎo)入jar包螟深,并配置web.xml

(1)新建一個(gè)Dynamic Web Project谐宙,可命名為ssh_01,直接點(diǎn)擊finish按鈕
image.png
(2)將選擇的jar包導(dǎo)入到lib(/WebContent/WEB-INF/lib)中
image.png
(3)將導(dǎo)入的jar包添加到項(xiàng)目Libraries中血崭,項(xiàng)目右鍵==》Properties==》Java Build Path==》Libraries==》選中導(dǎo)入的所有jar包添加到進(jìn)Libraries中
image.png

image.png
(4)在/WebContent/WEB-INF/下新建一個(gè)web.xml,配置過濾器和監(jiān)聽器
web.xml:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" 
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" 
id="WebApp_ID" version="3.1">
            
    <display-name>ssh</display-name>
    <welcome-file-list>
      <welcome-file>index.action</welcome-file>
    </welcome-file-list>
  
    <!-- struts2的過濾器 -->
    <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>

    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    
    
    <!-- spring的監(jiān)聽器配置開始 -->
    <context-param>  
        <param-name>contextConfigLocation</param-name>  
        <param-value>classpath:applicationContext.xml</param-value>  
    </context-param>
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
</web-app>

第二步 創(chuàng)建用于分層的四個(gè)基礎(chǔ)包厘灼,并分別添加BookCard的操作類

(1)項(xiàng)目切換到Project Explorer窗口夹纫,在/Java Resources/src/目錄下創(chuàng)建四個(gè)包(package)
image.png
(2)根據(jù)數(shù)據(jù)庫表的字段編寫B(tài)ookCard(實(shí)體類)和BookCard.hbm.xml(映射文件)放到ssh_01.entity包里
BookCard.java:
package ssh_01.entity;

import java.math.BigDecimal;
import java.util.Date;

public class BookCard {
    private int cid  ;
    private String name;
    private String sex ;
    private Date cardDate;
    private BigDecimal deposit;
    
    public int getCid() {
        return cid;
    }
    public void setCid(int cid) {
        this.cid = cid;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getSex() {
        return sex;
    }
    public void setSex(String sex) {
        this.sex = sex;
    }
    public Date getCardDate() {
        return cardDate;
    }
    public void setCardDate(Date cardDate) {
        this.cardDate = cardDate;
    }
    public BigDecimal getDeposit() {
        return deposit;
    }
    public void setDeposit(BigDecimal deposit) {
        this.deposit = deposit;
    }
}
BookCard.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>
    <class name="ssh_01.entity.BookCard" table="BookCard">
        <!-- 卡號(hào) -->
        <id name="cid" column="cid">
            <generator class="native"></generator>
        </id>
        <!-- 姓名 -->
        <property name="name" column="name"></property>
        <!-- 性別 -->
        <property name="sex" column="sex"></property>
        <!-- 辦卡日期 -->
        <property name="cardDate" column="cardDate"></property>
        <!-- 押金 -->
        <property name="deposit" column="deposit"></property>
    </class>
</hibernate-mapping>
(3)在ssh_01.dao包里編寫B(tài)ookCardDao(接口類)和BookCardDaoImpl(實(shí)現(xiàn)類)。
BookCardDao.java:
package ssh_01.dao;

import java.util.List;

import ssh_01.entity.BookCard;

public interface BookCardDao {
    public List<BookCard> getAllBookCard();
}

BookCardDaoImpl.java:
package ssh_01.dao;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.query.Query;

import ssh_01.entity.BookCard;

public class BookCardDaoImpl implements BookCardDao {
    //在SSH的設(shè)計(jì)理念:要使用某個(gè)實(shí)例设凹,那么就定義聲明一個(gè)對(duì)象舰讹,然后
    //給它添加set方法(用于spring注入進(jìn)來)
    //實(shí)現(xiàn)不要關(guān)注這個(gè)實(shí)例來自于那里,以及怎么創(chuàng)建闪朱,或者它是誰    
    private SessionFactory sessionFactory;
    
    public void setSessionFactory(SessionFactory sessionFactory) {
        this.sessionFactory = sessionFactory;
    }


    @Override
    public List<BookCard> getAllBookCard() {
        
        //sessionFactory這個(gè)實(shí)例可以自己按常規(guī)的hibernate傳統(tǒng)寫法創(chuàng)建
        //也可以交給spring去托管
        
        Configuration cfg = new Configuration().configure();
        sessionFactory = cfg.buildSessionFactory();
        
        
        //獲取session
        Session session = sessionFactory.openSession();
            
        //后面當(dāng)使用JPA的時(shí)候月匣,EntityManager 類似于 Session
        Query<BookCard> query = session.createQuery("from BookCard");
        
        //將所有的數(shù)據(jù)查詢出來并放到List集合里
        List<BookCard> list = query.getResultList();
        
        //將集合遍歷循環(huán)
        for(BookCard bookCard:list){
            //打印輸出到控制臺(tái)
            System.out.println(bookCard);
        }
        
        //關(guān)閉session
        session.close();
        //關(guān)閉sessionFactory
        sessionFactory.close();
        //返回list集合
        return list;
    }
}
(4)在ssh_01.service包里編寫B(tài)ookCardService(接口類)和BookCardServiceImpl(實(shí)現(xiàn)類)。
BookCardService.java:
package ssh_01.service;

import java.util.List;

import ssh_01.entity.BookCard;

public interface BookCardService {
    public List<BookCard> getAllBookCard();
}
BookCardServiceImpl.java:
package ssh_01.service;

import java.util.List;

import ssh_01.dao.BookCardDao;
import ssh_01.entity.BookCard;

public class BookCardServiceImpl implements BookCardService{
    //dao實(shí)例使用注入方式
    private BookCardDao id;
    //用于注入使用
    public void setId(BookCardDao id) {
        this.id = id;
    }


    @Override
    public List<BookCard> getAllBookCard() {
        //本類應(yīng)該編寫業(yè)務(wù)邏輯的代碼奋姿,
        //但本例沒有業(yè)務(wù)邏輯锄开,就不用寫。
        
        //訪問數(shù)據(jù)庫的代碼称诗,不會(huì)出現(xiàn)在service這一層
        //交給dao來操作數(shù)據(jù)庫
        List<BookCard> myBookCardList = id.getAllBookCard();
        
        //進(jìn)行其它的業(yè)務(wù)邏輯操作萍悴,比如增加多一個(gè)選項(xiàng),是否過期
        //本例不需要
        //....
        
        return myBookCardList;
    }
}
(5)在ssh_01.action包里編寫IndexAction(action類)寓免。
IndexAction.java:
package ssh_01.action;

import java.text.DecimalFormat;
import java.util.List;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;

import ssh_01.entity.BookCard;
import ssh_01.service.BookCardService;

//創(chuàng)建IndexAction(action類)繼承ActionSupport接口
public class IndexAction extends ActionSupport {
    
    private static final long serialVersionUID = 1L;
    
    //聲明service癣诱,但不給它創(chuàng)建具體的實(shí)現(xiàn)類的實(shí)例,
    private BookCardService is = null;
    //添加set()方法
    public void setIs(BookCardService is) {
        this.is = is;
    }
    
    //編寫execute()方法
    public String execute() {
        
        //獲取IndexService實(shí)例袜香,調(diào)用getAllBookCard()方法
        //將結(jié)果保存到List集合里
        List<BookCard> myBookCardList = is.getAllBookCard();
        
        //將查詢出來的結(jié)構(gòu)集打印到控制臺(tái)
        System.out.println("結(jié)果集:"+myBookCardList.size());
        
        //獲取Context上下文對(duì)象
        ActionContext ac = ActionContext.getContext();
        
        //將myBookCardList集合添加到上下文對(duì)象里
        ac.put("myBookCardList", myBookCardList);
        
        //返回一個(gè)字符串
        return "success";
    }
    
    //金額格式轉(zhuǎn)換
    public String formatDouble(double s){
        DecimalFormat fmat=new DecimalFormat("\u00A4##.0"); 
        return fmat.format(s);
    }
}

第三步 編寫struts.xml(struts配置文件)撕予、applicationContext.xml(spring配置文件)、hibernate.cfg.xml(hibernate配置文件)

(1)在/src/目錄下新建配置文件struts.xml蜈首、applicationContext.xml实抡、hibernate.cfg.xml
image.png
(2)編寫各配置文件
struts.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC 
    "-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"
    "http://struts.apache.org/dtds/struts-2.5.dtd">

<!-- 上面的頭,注意版本欢策,從樣例里復(fù)制過來 showcase.war\WEB-INF\src\java\struts.xml -->

<struts>
    <!-- 告知Struts2運(yùn)行時(shí)使用Spring來創(chuàng)建對(duì)象 -->
    <constant name="struts.objectFactory" value="spring" />
    
    <package name="default" namespace="/" extends="struts-default">
        <action name="Index" class="myIndexAction">
            <result name="success">/WEB-INF/jsp/index.jsp</result>
        </action>
    </package>
</struts>
applicationContext.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:p="http://www.springframework.org/schema/p"  
        xmlns:aop="http://www.springframework.org/schema/aop"   
        xmlns:context="http://www.springframework.org/schema/context"  
        xmlns:jee="http://www.springframework.org/schema/jee"  
        xmlns:tx="http://www.springframework.org/schema/tx"  
        xsi:schemaLocation="    
            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd  
            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/jee http://www.springframework.org/schema/jee/spring-jee.xsd  
            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">
            
    <!-- 類似于財(cái)務(wù)部門一樣澜术,類就是錢,所有需要類的實(shí)例都由spring去管理 -->
    <bean id="myIndexAction" class="ssh_01.action.IndexAction" scope="prototype">
        <!-- setIs(myIndexService) -->
        <property name="is" ref="myIndexService"/>
    </bean>
    
    <!-- myIndexService = new ssh_01.service.IndexServiceImpl() -->
    <bean id="myIndexService" class="ssh_01.service.BookCardServiceImpl" scope="prototype">
        <property name="id" ref="myIndexDao"/>
    </bean>
    
    <bean id="myIndexDao" class="ssh_01.dao.BookCardDaoImpl" scope="prototype">
        <!-- 把sessionFactory 注入給IndexDao -->
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>
    
     <!-- 添加sessionFactory bane 猬腰,注意鸟废,該類是Spring提供的 -->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean" scope="prototype">
        <!-- 注入Hibernate 配置文件路徑,前面要加上  classpath:-->
        <property name="configLocation" value="classpath:hibernate.cfg.xml"/>
    </bean>
    
</beans>
hibernate.cfg.xml:
<?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>
        <!-- 數(shù)據(jù)庫連接配置 -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/ssh_01</property>
        <property name="connection.username">root</property>
        <property name="connection.password">123456</property>
        <!-- dialect翻譯為方言 Hibernate根據(jù)你選擇的“方言”,針對(duì)每種數(shù)據(jù)庫姑荷,作調(diào)整盒延,如生成不同的SQL語句等 -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        
        <!-- 設(shè)置默認(rèn)的數(shù)據(jù)庫連接池 -->
        <property name="connection.pool_size">5</property>
        
        <!-- 顯示SQL -->
        <property name="show_sql">true</property>
        
        <!-- 格式化SQL -->
        <property name="format_sql">true</property>
        
        <!-- 根據(jù)schema更新數(shù)據(jù)表的工具 -->
        <property name="hbm2ddl.auto">update</property>        
        
        <!-- 數(shù)據(jù)表映射配置文件 -->
        <mapping resource="ssh_01/entity/BookCard.hbm.xml"/>
        
    </session-factory>
</hibernate-configuration>

第四步 顯示結(jié)果

(1)在/WebContent/WEB-INF/目錄下創(chuàng)建文件夾jsp缩擂,再在/jsp/目錄下創(chuàng)建一個(gè)index.jsp頁面
image.png
(2)將所有數(shù)據(jù)取出來顯示到index.jsp頁面上
index.jsp:
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ 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>Insert title here</title>
</head>
<body>

<table border="1">
    <tr>        
        <td>卡號(hào)</td>
        <td>姓名</td>
        <td>性別</td>
        <td>辦卡日期</td>
        <td>押金</td>
    </tr>
    <!-- 使用struts2標(biāo)簽庫中的iterator將所有數(shù)據(jù)遍歷循環(huán)顯示出來 -->
    <s:iterator value="#myBookCardList" status="bcs">
        <tr>    
            <td><s:property value="cid"></s:property></td>
            <td><s:property value="name"></s:property></td>
            <td><s:property value="sex"></s:property></td>
            <td><s:date name="cardDate" format="yyyy年MM月dd日"></s:date></td>
            <td><s:property value="%{formatDouble(deposit)}"></s:property></td>
        </tr>
    </s:iterator>
    <!-- 判斷查詢出來等于0,就顯示“沒有查找到數(shù)據(jù)” -->
    <s:if test="myBookCardList.size()==0">
        <tr>                    
            <td colspan="7">沒有查找到數(shù)據(jù)</td>
        </tr>
    </s:if>
</table>
</body>
</html>
(3)運(yùn)行項(xiàng)目并顯示結(jié)果
表中無數(shù)據(jù)時(shí):
image.png
表中有數(shù)據(jù)時(shí):
image.png

總結(jié)

雖然按照該步驟完成了SSH框架的整合和搭建添寺,并顯示出相應(yīng)的結(jié)果胯盯,并對(duì)其中某些步驟的細(xì)節(jié)仍需要研究,特別是配置文件的使用计露。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末博脑,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子票罐,更是在濱河造成了極大的恐慌叉趣,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件该押,死亡現(xiàn)場(chǎng)離奇詭異疗杉,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)蚕礼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門烟具,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人奠蹬,你說我怎么就攤上這事朝聋。” “怎么了囤躁?”我有些...
    開封第一講書人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵玖翅,是天一觀的道長。 經(jīng)常有香客問我割以,道長金度,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任严沥,我火速辦了婚禮猜极,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘消玄。我一直安慰自己跟伏,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開白布翩瓜。 她就那樣靜靜地躺著受扳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪兔跌。 梳的紋絲不亂的頭發(fā)上勘高,一...
    開封第一講書人閱讀 51,541評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼华望。 笑死蕊蝗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的赖舟。 我是一名探鬼主播蓬戚,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼宾抓!你這毒婦竟也來了子漩?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤石洗,失蹤者是張志新(化名)和其女友劉穎幢泼,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體劲腿,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡旭绒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年鸟妙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了焦人。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡重父,死狀恐怖花椭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情房午,我是刑警寧澤矿辽,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布,位于F島的核電站郭厌,受9級(jí)特大地震影響袋倔,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜折柠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一宾娜、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧扇售,春花似錦前塔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至困乒,卻和暖如春寂屏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來泰國打工凑保, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留冈爹,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓欧引,卻偏偏與公主長得像频伤,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子芝此,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355