基于已构建S2SH项目配置全注解方式简化配置文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于已构建S2SH项目配置全注解方式简化配置文件相关的知识,希望对你有一定的参考价值。

如果还不熟悉s2sh项目搭建的朋友可以先阅读

eclipse环境下基于已构建struts2项目整合spring+hibernate

这两篇文章熟悉一下。

本文是基于以上两篇文章的基础构建的,以下给出全注解方式配置S2SH项目的参考步骤。

第一步:实体类映射数据库表,简化hibernate通过xml配置文件映射

首先我们新建实体类作为测试,包结构如图所示:

技术分享图片

新建User到model包下,实体类字段信息如下所示:

package wjt.com.test.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;

import org.hibernate.annotations.GenericGenerator;

import java.util.Date;

@Entity
@Table(name="wjt_user")
public class User {
    
    @Id
    @Column(name="ID",length=32)
    //主键生成策略
    @GeneratedValue(generator = "paymentableGenerator")
    //hibernate的主键生成策略,name属性与@GeneratedValue的generator = "paymentableGenerator"对应,
    //strategy 指定具体生成器的类名(指定生成策略)
    @GenericGenerator(name="paymentableGenerator",strategy="uuid")
    private String id;
    
    private String name;
    
    private String types;
    
    @Temporal(value=TemporalType.DATE)
    private Data date;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getTypes() {
        return types;
    }

    public void setTypes(String types) {
        this.types = types;
    }
    
}

hibernate各注解的用途及其属性参考前辈的文章:

hibernate用注解配置实体类的映射

实体类准备完毕,我们需要将其交给hibernate工厂扫描映射到数据库表,需要在hibernate的session工厂中配置packagesToScan属性,给出applicationContect.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:context="http://www.springframework.org/schema/context"
    xmlns:task="http://www.springframework.org/schema/task" xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="
http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
http://www.springframework.org/schema/context 
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/task  
http://www.springframework.org/schema/task/spring-task-3.1.xsd
http://www.springframework.org/schema/tx 
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/aop 
http://www.springframework.org/schema/aop/spring-aop-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/wjt_test?useUnicode=true&amp;characterEncoding=UTF-8&amp;zeroDateTimeBehavior=convertToNull&amp;autoReconnect=true" />
        <property name="username" value="root" />
        <property name="password" value="wujingtao" />

    </bean>

    <!-- 配置hibernate session工厂 -->
    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
                <prop key="hibernate.show_sql">false</prop>
                <prop key="hibernate.format_sql">true</prop>
            </props>
        </property>

        <!-- 扫描实体类映射数据库表的包 -->
        <property name="packagesToScan">
            <list>
                <value>com.wjt.model</value>
            </list>
        </property>

    </bean>


</beans>

第二步:基于注解方式配置IOC

在原项目中service层、dao层中实现类添加注解完成bean对spring容器的注册,去掉采用set访问器属性注入的方式,增加注解声明,代码改写如下:

dao层:

package wjt.com.test.dao.impl;

import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

import wjt.com.test.dao.TestDaoI;

@Repository("testDao")//这里是bean注册到spring容器
public class TestDaoImpl implements TestDaoI{
    
    @Autowired//这里是将声明的bean注入,其中sessionFactory依旧是在配置文件中注册的
    private SessionFactory sessionFactory;

    private Session getCurrentSession() {
        try {
            return sessionFactory.getCurrentSession();
        } catch (HibernateException e) {
            return sessionFactory.openSession();
        }
    }

    @Override
    public void testDaoMethod() {
        System.out.println("dao层测试方法...");
        if(getCurrentSession()!=null) {
            System.out.println("session工厂注入成功!");
        }
        
    }
    
    

}

service层:

package wjt.com.test.service.impl;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import wjt.com.test.dao.TestDaoI;
import wjt.com.test.service.TestServiceI;

@Service("testService")
public class TestServiceImpl implements TestServiceI{
    
    @Autowired
    private TestDaoI testDao;
    
    @Override
    public void testServiceMethod() {
        System.out.println("service层测试方法...");
        testDao.testDaoMethod();
    }

}

action层:

package wjt.com.test.action;

import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.Namespace;
import org.apache.struts2.convention.annotation.Result;
import org.springframework.beans.factory.annotation.Autowired;

import com.opensymphony.xwork2.ActionSupport;

import wjt.com.test.service.TestServiceI;

@Namespace("/")
@Action(value = "testAction", results = { 
        @Result(name = "success", location = "/index.jsp"),
    })
public class TestAction extends ActionSupport {

    @Autowired
    private TestServiceI testService;

    public String execute() throws Exception {
        System.out.println("struts==========================");
        testService.testServiceMethod();
        return "success";
    }
}

TestAction类名上方的注解在后文中有解释,这里先挂问号。

到这里还需要在applicationContext.xml中声明spring对注解的支持以及spring容器对已注册bean进行扫描完成属性的注入从而达到控制反转的目的,

在<beans></beans>节点下增加如下配置:

    <!-- 注解支持 -->
    <context:annotation-config />
    <!-- 扫描注册bean并注入属性 -->
    <context:component-scan base-package="wjt.com.**"></context:component-scan>

其中*号表示扫描wjt.com包及其子包下所有注册的bean。到这里spring+hibernate注解方式配置已全部完成,对上述注解不太熟悉的可以参考前辈文章:

Spring 注解详解

第三步:struts2中action的注解方式配置

首先我们需要引入struts2对注解支持的jar包:技术分享图片

这个时候需要我们在TestAction类名上方添上刚才挂问号的注解,对于Action注解的解释请参考:

Struts2注解详解

我们这里注解的意义为当TestAction中默认方法返回“success”时页面跳转到index.jsp

接着我们需要简化struts2的配置文件,给出简化后的配置文件如下:

<?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"><!-- 这里要和struts2版本号统一 -->

<struts>

    <!-- 告知Struts2运行时使用Spring来创建对象 -->
    <constant name="struts.objectFactory" value="spring" />
    
    <package name="default" namespace="/" extends="struts-default">
        
    </package>

</struts>

第三步:测试

到这里一个完整的基于全注解方式配置s2sh项目就完成了,启动项目测试是否达到我们的要求:

一、项目启动数据库应当已建立一张wjt_user表

二、访问TestAction时应当跳转到index.jsp页面

为了验证测试我们在index.jsp的body标签内写入“这是Mr至简的第一个全注解方式配置S2SH项目”。

启动项目后数据库截图如下:

技术分享图片

浏览器地址栏输入:http://localhost:8080/SSHDemo/testAction 请求后截图如下:

技术分享图片

以上就是关于S2SH项目全注解配置的参考方案,有不合理的地方还请各位读者指出。

以上是关于基于已构建S2SH项目配置全注解方式简化配置文件的主要内容,如果未能解决你的问题,请参考以下文章

关于Spring注解开发教程,打包全送你

5Hibernate配置及使用方法----青软S2SH(笔记)

Spring基于纯注解方式的使用

还怕不记得Spring Boot注解吗?5类注解全在这里了(建议收藏)

基于VuePress构建高基于markdown语法的网站全教程

Spring实践第六天(Spring全注解的方式)