初学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三大框架的集成配置操作,接下来进行简单的熟悉就可以熟练使用了。
以上配置方式在一些简单的项目中基本上都是这样配置的,这对于初学者来说是必须掌握的基础操作。

发布了31 篇原创文章 · 获赞 17 · 访问量 4万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览