初學Java三大框架集成需要掌握的基本配置[Spring,MyBatis,Struts]


在我們學習完一些零散的Java WEB的框架知識後,就需要對這些框架進行集成以熟悉他們的使用,在這裏,我寫了一個簡單的練習以熟悉SSM(spring、struts、Mybatis)框架集成的使用。


這裏是一個簡單的業務邏輯代碼,[分爲action、service、dao三層]:


action

import com.ssm.service.MyService;

public class MyAction {
    private MyService ms;
    public String test(){
        System.out.println("進入MyAction******test()");
        ms.test();
        return null;
    }
    public void setMs(MyService ms) {
        this.ms = ms;
    }
}

service


import com.ssm.dao.MyDao;

public class MyService {
    private MyDao md;
    public void test(){
        md.test();
    }
    public void setMd(MyDao md) {
        this.md = md;
    }

}

dao

import org.mybatis.spring.SqlSessionTemplate;

public class MyDao {
    private SqlSessionTemplate sqlTemplate;
    //進行數據庫操作
    public void test(){
        sqlTemplate.insert("ssm.add");
    }
    public void setSqlTemplate(SqlSessionTemplate sqlTemplate) {
        this.sqlTemplate = sqlTemplate;
    }

}

那麼,要在服務器上實現上面的業務邏輯,即通過訪問test.action實現數據的插入,我們需要配置以下的框架進行集成。


、進行web.xml文件的配置,將spring 和 struts聲明在其中

<?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>SSM</display-name>
    <!-- 指定spring配置文件信息位置 -->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:applicationContext.xml</param-value>
    </context-param>  
    <!-- 配置spring 監聽器 該監聽器 會讀取spring 配置文件內容 記住 ContextLoaderListener -->
    <listener>
        <listener-class>                org.springframework.web.context.ContextLoaderListener          </listener-class>
    </listener>

    <!-- 配置 struts -->
    <filter>
        <filter-name>struts</filter-name>
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>struts</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
</web-app>

、spring是一個開源的Java EE開發框架,spring框架核心功能可以應用在任何Java應用程序中,對Java EE平臺上的web程序有更好的擴展性,在進行集成配置的時候,由於要訪問數據庫(以MySQL爲例),所以先配置數據源,然後再聲明bean。下面是applicationContext.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!-- 配置spring 使用applicationContext.xml 文件 -->
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
                       http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
                       http://www.springframework.org/schema/aop 
                       http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
                       http://www.springframework.org/schema/tx 
                       http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
                       http://www.springframework.org/schema/context 
                       http://www.springframework.org/schema/context/spring-context-3.0.xsd" >

    <!-- 配置數據源 -->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName"    value="com.mysql.jdbc.Driver"/>
        <property name="url"                            value="jdbc:mysql://localhost:3306/my1505"/>
        <property name="username"               value="root"/>
        <property name="password"               value=""/>
    </bean>
    <!-- 給MyBatis注入數據源 然後創建相應的對象 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="configLocation" value="classpath:ConfigLocation.xml"/>
    </bean>

    <!-- 創建數據操作對象 -->
    <bean id="sqlTemplate" class="org.mybatis.spring.SqlSessionTemplate">
        <constructor-arg name="sqlSessionFactory" ref="sqlSessionFactory"/>
    </bean>

    <!-- 聲明DAO層和SERVICE層 -->
    <bean id="mydao" class="com.ssm.dao.MyDao">
        <property name="sqlTemplate" ref="sqlTemplate"/>
    </bean>
    <bean id="myservice" class="com.ssm.service.MyService">
        <property name="mydao" ref="mydao"></property>
    </bean>




</beans>

、進行Struts1的配置。
struts是一個基於MVC的框架,通過action響應用戶的請求。在service層用戶可以進行業務邏輯的實現,然後在dao層進行數據持久層的操作。下面是struts.xml文件,把每一個action配置在package標籤中,package默認命名空間是”/”,action的配置方式不止一種,這個我會在接下來的博客中提到。

<?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="Test1" extends="struts-default">
        <action name="test" class="com.ssm.action.MyAction" method="test">
        </action>
    </package>
</struts>

、配置MyBatis。MyBatis是一個進行數據持久層操作的半ORM(對象關係影射)框架。在這裏聲明SQL語句進行對數據庫的操作。在mapper標籤中需要指定namespace和id。這裏是Mapper.xml文件。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  <!-- 需要在xml文件中聲明mapper 指定namespace 用以在 configLocation中確定是哪一個mapper -->
<mapper namespace="ssm">
    <insert id="add">
        insert into stu(sname) values('張三丰')
    </insert>
</mapper>

、把mapper文件聲明在Configuration.xml文件中。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" 
 "http://mybatis.org/dtd/mybatis-3-config.dtd">
 <configuration>
    <mappers>
        <mapper resource="Mapper.xml"/>
    </mappers>

 </configuration> 

以上,就完成了整個項目中SSM三大框架的集成配置操作,接下來進行簡單的熟悉就可以熟練使用了。
以上配置方式在一些簡單的項目中基本上都是這樣配置的,這對於初學者來說是必須掌握的基礎操作。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章