Spring、Spring MVC、MyBatis統合ファイル構成の詳細説明

巴扎黑
リリース: 2017-04-30 10:11:39
オリジナル
1852 人が閲覧しました

SSM フレームワークを使用していくつかの小さなプロジェクトを実行してきましたが、まとめる時期が来たと感じています。まずはSSM連携のファイル構成をまとめてみましょう。実際、具体的な使用方法については公式ドキュメントを読むのが最善です。

春: http://spring.io/docs

MyBatis: http://mybatis.github.io/mybatis-3/

基本的な組織構造と使用法については説明しません。以前のブログと公式ドキュメントは非常に包括的です。 Jar パッケージは、Maven を使用して整理および管理できます。設定ファイルを見てみましょう。

web.xmlの設定

web.xml はプロジェクト全体の最も重要な設定ファイルであるはずですが、servlet3.0 はすでにアノテーション設定をサポートしています。 servlet3.0 より前では、各サーブレットは web.xml でサーブレットとそのマッピング関係を構成する必要があります。しかし、Spring フレームワークではこれは必要ありません。Spring は依存関係の注入 (制御の反転とも呼ばれます) であるためです。ただし、フロントエンド コントローラー (DispatcherServlet) である重要なサーブレットも構成する必要があります。設定方法は基本的には通常のサーブレットと同様です。

設定内容は以下の通りです:

<!-- 配置前端控制器 -->
  <servlet>
      <servlet-name>spring</servlet-name>
      <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
      <init-param>
          <!-- ContextconfigLocation配置springmvc加载的配置文件
          适配器、处理映射器等
           -->
          <param-name>contextConfigLocation</param-name>
          <param-value>WEB-INF/classes/spring/springmvc.xml</param-value>
  </init-param>
  </servlet>
  <servlet-mapping>
      <servlet-name>spring</servlet-name>
      <!-- 1、.action访问以.action结尾的  由DispatcherServlet进行解析
           2、/,所有访问都由DispatcherServlet进行解析
       -->
      <url-pattern>/</url-pattern>
  </servlet-mapping>
ログイン後にコピー

ここで、 springmvc.xml は Spring 構成ファイルであることに注意してください。これについては後で説明します。 の URL が .action の場合、フロントエンド コントローラーは .action で終わるリクエストのみをインターセプトし、静的ファイルを無視します。静的ページの制御には他の手段が必要です。 URL として / を使用すると、静的ページのリクエストを含むすべてのリクエストがインターセプトされます。この方法で、処理したいリクエストをインターセプトできますが、問題があります。すべてのリクエストがインターセプトされ、インターセプターで対応する処理が行われない場合、ページ内で使用されているすべての静的 js、css、画像にアクセスできなくなり、ページが正常に表示されなくなります。ただし、この問題は静的リソースを構成することで解決できます。後述します。

Spring コンテナーの構成:

<context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>WEB-INF/classes/spring/applicationContext-*.xml</param-value>

</context-param>
ログイン後にコピー

このうち、applicationContext-*.xml には、springIoC コンテナーの具体的な構成である 3 つの構成ファイルが含まれています。後述します。

リスナーを設定します:

<listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
ログイン後にコピー

web.xml の完全な構成は次のとおりです:



      
  
  
  
    404
    /error404.jsp
  
  
  
    500
    /error500.jsp
  
  
  
    
        contextConfigLocation
        WEB-INF/classes/spring/applicationContext-*.xml
    
    
        org.springframework.web.context.ContextLoaderListener
    

    
  <!-- 配置前端控制器 -->
  <servlet>
      <servlet-name>spring</servlet-name>
      <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
      <init-param>
          <!-- ContextconfigLocation配置springmvc加载的配置文件
          适配器、处理映射器等
           -->
          <param-name>contextConfigLocation</param-name>
          <param-value>WEB-INF/classes/spring/springmvc.xml</param-value>
  </init-param>
  </servlet>
  <servlet-mapping>
      <servlet-name>spring</servlet-name>
      <!-- 1、.action访问以.action结尾的  由DispatcherServlet进行解析
           2、/,所有访问都由DispatcherServlet进行解析
       -->
      <url-pattern>/</url-pattern>
  </servlet-mapping>
    
  
  
      CharacterEncodingFilter
      org.springframework.web.filter.CharacterEncodingFilter
      
          encoding
          utf-8
      
  
  
      CharacterEncodingFilter
      /*
  
  
    welcome.jsp
    
    
ログイン後にコピー

構成ファイルにはさらに 2 つのコンテンツがあることを確認してください。1 つはエラー ページであり、エラー コードを使用してエラーを区別し、対応する処理ページにジャンプできます。この構成コードはフロントに配置し、フロントエンド コントローラーがインターセプトする前に処理するのが最適です。

もう 1 つのコンテンツは、投稿の文字化けの問題を解決するフィルターです。投稿リクエストをインターセプトし、utf8 にエンコードします。

springmvc.xmlの構成 リゾルバー構成を表示:

<!-- 配置视图解析器 -->
     <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
         <!-- 使用前缀和后缀 -->
         <property name="prefix" value="/"></property>
         <property name="suffix" value=".jsp"></property>
</bean>
ログイン後にコピー
コントローラーでビュー名を設定すると、プレフィックスとサフィックスが自動的に追加されます。

コントローラー設定

自動スキャン モードでは、パッケージ内のすべてのコントローラーがスキャンされ、アノテーションを使用してアクセス パスを指定できます。

りー

単一の構成方法を使用することもでき、コントローラーの完全修飾名を指定する必要があります。

りー

注釈付きのプロセッサー・アダプターとプロセッサー・マッパーを構成します:

<!-- 使用组件扫描的方式可以一次扫描多个Controller -->
<context:component-scan base-package="com.wxisme.ssm.controller">
ログイン後にコピー

次の簡素化された構成を使用することもできます:

<bean name="/queryUser.action" class="com.wxisme.ssm.controller.Controller1"/>
ログイン後にコピー

インターセプターを構成します。すべてのリクエストをインターセプトするように直接定義することも、インターセプト パスをカスタマイズすることもできます。

りー

グローバル例外ハンドラーを構成する

<!-- 注解的处理器适配器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
<!-- 注解的处理器映射器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
ログイン後にコピー

ファイル アップロード データ パーサーを構成します。これは、ファイルをアップロードするときに構成する必要があります。

りー

日付型バインディングを例として、いくつかのカスタム パラメーター タイプを構成することもできます。

りー

前述したように、フロントエンド コントローラーの構成時にすべてのリクエストがインターセプトされると、一部の静的リソースは特別な処理を行わないと使用できなくなります。この場合、次の構成を使用して静的リソース ファイルにアクセスできます。

りー

デフォルトを使用することもできますが、web.xml で設定する必要があります。

りー

すべてのパスをブロックしないことで、この問題を回避できます。

完全な構成はおそらく次のようになります。xml ファイルの名前空間に注意する必要があります。これは影響を与える場合があります。

りー

applicationContext-*.xmlの設定

  applicationContext-*.xml包括三个配置文件,分别对应数据层控制、业务逻辑service控制和事务的控制。

  数据访问层的控制,applicationContext-dao.xml的配置:

  配置加载数据连接资源文件的配置,把数据库连接数据抽取到一个properties资源文件中方便管理。

  配置为:

<!-- 加载数据库连接的资源文件 -->
<context:property-placeholder location="/WEB-INF/classes/jdbc.properties"/>
ログイン後にコピー

  其中jdbc.properties文件的内容如下:

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/database
jdbc.username=root
jdbc.password=1234
ログイン後にコピー

  配置数据库连接池,这里使用的是dbcp,别忘了添加jar包!

<!-- 配置数据源   dbcp数据库连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="${jdbc.driver}"/>
    <property name="url" value="${jdbc.url}"/>
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
</bean>
ログイン後にコピー

  Spring和MyBatis整合配置,jar包由MyBatis提供。

  配置sqlSessionFactory

<!-- 配置sqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!-- 数据库连接池 -->
    <property name="dataSource" ref="dataSource"/>
    <!-- 加载Mybatis全局配置文件 -->
    <property name="configLocation" value="/WEB-INF/classes/mybatis/SqlMapConfig.xml"/>

</bean>
ログイン後にコピー

  SqlMapConfig.xml文件是MyBatis的配置文件,后面会提到。

  配置Mapper扫描器,扫描mapper包下的所有mapper文件和类,要求mapper配置文件和类名需要一致。

<!-- 配置mapper扫描器 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <!-- 扫描包路径,如果需要扫描多个包中间用半角逗号隔开 -->
    <property name="basePackage" value="com.wxisme.ssm.mapper"></property>
    <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean>
ログイン後にコピー

  整个applicationContext-dao.xml配置文件应该是这样的:




<!-- 加载数据库连接的资源文件 -->
<context:property-placeholder location="/WEB-INF/classes/jdbc.properties"/>

<!-- 配置数据源   dbcp数据库连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="${jdbc.driver}"/>
    <property name="url" value="${jdbc.url}"/>
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
</bean>



    
    
    
    


<!-- 配置mapper扫描器 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <!-- 扫描包路径,如果需要扫描多个包中间用半角逗号隔开 -->
    <property name="basePackage" value="com.wxisme.ssm.mapper"></property>
    <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean>
ログイン後にコピー

  业务逻辑控制,applicationContext-service.xml的配置:

  这个文件里暂时只需要定义service的实现类即可。

<!-- 定义service -->
<bean id="userService" class="com.wxisme.ssm.service.impl.UserServiceImpl"/>
ログイン後にコピー

  事务控制,applicationContext-transaction.xml的配置

  配置数据源,使用JDBC控制类。

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <!-- 配置数据源 -->
    <property name="dataSource" ref="dataSource"/>
</bean>
ログイン後にコピー

  配置通知,事务控制。

<!-- 通知 -->
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <!-- 传播行为 -->
            <tx:method name="save*" propagation="REQUIRED"/>
            <tx:method name="insert*" propagation="REQUIRED"/>
            <tx:method name="update*" propagation="REQUIRED"/>
            <tx:method name="delete*" propagation="REQUIRED"/>
            <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
            <tx:method name="select*" propagation="SUPPORTS" read-only="true"/>
        </tx:attributes>
    </tx:advice>
ログイン後にコピー

  配置AOP切面

<!-- 配置aop  -->
    <aop:config>
        <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.wxisme.ssm.service.impl.*.*(..))"/>
    </aop:config>
ログイン後にコピー

  整个事务控制的配置是这样的:



    


<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <!-- 配置数据源 -->
    <property name="dataSource" ref="dataSource"/>
</bean>
    
    
    
        
            
            
            
            
            
            
                        
        
    
    
    <!-- 配置aop  -->
    <aop:config>
        <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.wxisme.ssm.service.impl.*.*(..))"/>
    </aop:config>
ログイン後にコピー

  MyBatis的配置                                                                                                                                             

  SqlMapConfig.xml的配置   全局setting配置这里省略,数据库连接池在spring整合文件中已经配置,具体setting配置参考官方文档。

  别名的定义:

<typeAliases>
    <!-- 批量定义别名 ,指定包名,自动扫描包中的类,别名即为类名,首字母大小写无所谓-->
    <package name="com.wxisme.ssm.po"/>
</typeAliases>
ログイン後にコピー

  mapper映射文件的配置:

<mappers>
    <!-- 加载映射文件 -->
    <!-- 这里也可以使用class来加载映射文件,前提是:使用mapper代理的方法,遵循规范,
    并且两个文件必须同名且在同一目录
    <mapper class="com.wxisme.mybatis0100.mapper.UserMapper"/>
    基于class加载,可以进行批量加载
    -->
    <!-- 通过扫描包的方式来进行批量加载映射文件 -->
    <package name="com.wxisme.ssm.mapper"/>     
</mappers>
ログイン後にコピー

  整个文件的配置应该是这样的:








<typeAliases>
    <!-- 批量定义别名 ,指定包名,自动扫描包中的类,别名即为类名,首字母大小写无所谓-->
    <package name="com.wxisme.ssm.po"/>
</typeAliases>




    
    

ログイン後にコピー

  具体mapper文件的配置,在使用mapper代理的方法时,命名空间需要是对应的Mapper类。

<?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" >
<mapper namespace="com.wxisme.ssm.mapper.AlbumMapper" >
  
</mapper>
ログイン後にコピー

  以上只是对SSM框架简单使用时的配置文件,如果需要深入使用或者需要理解其内部机理需要参考官方文档和其源代码。

以上がSpring、Spring MVC、MyBatis統合ファイル構成の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!