Springのapplication-config.xmlでのエラーについて

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,034

silver-

score 7

 前提・実現したいこと

※過去に別の方が投稿されている以下の質問と同様のエラーかと思いますが、
解決方法を突き止めることができなかったため、あらためて投稿させてください。
https://teratail.com/questions/132741

プログラミングを初めて数か月の初心者です。

http://tech.pjin.jp/blog/2016/06/10/springframework8/
上記のサイトの内容に沿ってSpringを学習しており、
STSとMySQLの連携の章でつまづいています。

自分なりに解決方法を調べているのですが知識が至らず、どなたかお知恵を貸していただければ幸いです。

 発生している問題・エラーメッセージ

以下3種のエラーが発生してしまいます。

 schema/beans":description, "http://www.springframework.org/schema/beans":meta, "http://www.springframework.org/
 schema/beans":bean, "http://www.springframework.org/schema/beans":ref, "http://www.springframework.org/schema/
 beans":idref, "http://www.springframework.org/schema/beans":value, "http://www.springframework.org/schema/beans":null, 
 "http://www.springframework.org/schema/beans":array, "http://www.springframework.org/schema/beans":list, "http://
 www.springframework.org/schema/beans":set, "http://www.springframework.org/schema/beans":map, "http://
 www.springframework.org/schema/beans":props, WC[##other:"http://www.springframework.org/schema/beans"]}' is expected.


Description    Resource    Path    Location    Type
Error occured processing XML 'The element type "bean" must be terminated by the matching end-tag "</bean>".'. See Error Log for more details    application-config.xml    /HelloWorld/src/main/resources/spring    Unknown    Spring Beans Problem


The element type "bean" must be terminated by the matching end-tag "</bean>".

 該当のソースコード

<?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:jpa="http://www.springframework.org/schema/data/jpa"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc.xsd
http://www.springframework.org/schema/data/jpa
http://www.springframework.org/schema/data/jpa/spring-jpa.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">

<!-- Uncomment and add your base-package here:
<context:component-scan
base-package="org.springframework.samples.service"> -->

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="dataSource" >
<property name="packagesToScan" value="jp.ssie.helloworld.model" >
<property name="jpaVendorAdapter">
<bean
class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" >
</property>
<property name="jpaProperties">
<props>
<prop key="hibernate.hbm2ddl.auto">none</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect
</prop>
</props>
</property>
</bean>

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="${jdbc.driverClassName}" >
<property name="url" value="${jdbc.url}" >
<property name="username" value="${jdbc.username}" >
<property name="password" value="${jdbc.password}" >
<property name="removeAbandoned" value="true" >
<property name="initialSize" value="3" >
<property name="maxActive" value="30" >
<property name="validationQuery" value="select now()" >
</bean>

<context:property-placeholder location="classpath:jdbc.properties" >

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource" >
</bean>
<bean id="namedParameterJdbcTemplate"
class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
<constructor-arg ref="dataSource" >
</bean>

<jpa:repositories base-package="jp.ssie.helloworld.repository">

<bean id="transactionManager"
class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory" >
</bean>

<tx:annotation-driven >
</beans>

 試したこと

過去の同様の質問を拝見し、ライブラリ名が古かったとの情報がありましたので
ライブラリ名の変更がないかを調べているのですが、まだ解決には至れていません。

 補足情報(FW/ツールのバージョンなど)

Windows10
Spring Tool Suite Version: 3.9.5.RELEASE

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

0

全般的に、閉じタグが足りていないです。フォーマッタをかけてみましたが、最初のbeanの部分だけ見ても

    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource">
            <property name="packagesToScan" value="jp.ssie.helloworld.model">
                <property name="jpaVendorAdapter">
                    <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
                </property>
                <property name="jpaProperties">
                    <props>
                        <prop key="hibernate.hbm2ddl.auto">none</prop>
                        <prop key="hibernate.show_sql">true</prop>
                        <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect
                        </prop>
                    </props>
                </property>
    </bean>

このように、propertyの子要素がないものに対して、閉じる要素が入っていません。

おそらく次のようになるのではないでしょうか。

    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="packagesToScan" value="jp.ssie.helloworld.model" />
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
        </property>
        <property name="jpaProperties">
            <props>
                <prop key="hibernate.hbm2ddl.auto">none</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect
                </prop>
            </props>
        </property>
    </bean>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/09/12 15:49 編集

    ご回答ありがとうございます。もっと複雑な原因かと思っていましたが、仰る通り閉じタグを見直した結果エラーが消えました。

    キャンセル

0

<?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:jpa="http://www.springframework.org/schema/data/jpa"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc.xsd
http://www.springframework.org/schema/data/jpa
http://www.springframework.org/schema/data/jpa/spring-jpa.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">

    <!-- Uncomment and add your base-package here: <context:component-scan base-package="org.springframework.samples.service"> -->

    <bean id="entityManagerFactory"
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource" />
            <property name="packagesToScan"
                value="jp.ssie.helloworld.model" />
                <property name="jpaVendorAdapter">
                    <bean
                        class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" />
                </property>
                <property name="jpaProperties">
                    <props>
                        <prop key="hibernate.hbm2ddl.auto">none</prop>
                        <prop key="hibernate.show_sql">true</prop>
                        <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect
                        </prop>
                    </props>
                </property>
    </bean>

    <bean id="dataSource"
        class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName"
            value="${jdbc.driverClassName}" />
            <property name="url" value="${jdbc.url}" />
                <property name="username" value="${jdbc.username}" />
                    <property name="password" value="${jdbc.password}" />
                        <property name="removeAbandoned" value="true" />
                            <property name="initialSize" value="3" />
                                <property name="maxActive" value="30" />
                                    <property name="validationQuery" value="select now()" />
    </bean>

    <context:property-placeholder
        location="classpath:jdbc.properties" />

        <bean id="jdbcTemplate"
            class="org.springframework.jdbc.core.JdbcTemplate">
            <property name="dataSource" ref="dataSource" />
        </bean>
        <bean id="namedParameterJdbcTemplate"
            class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
            <constructor-arg ref="dataSource" />
        </bean>

        <jpa:repositories
            base-package="jp.ssie.helloworld.repository" />

            <bean id="transactionManager"
                class="org.springframework.orm.jpa.JpaTransactionManager">
                <property name="entityManagerFactory"
                    ref="entityManagerFactory" />
            </bean>

            <tx:annotation-driven />
</beans>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.21%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る