質問をすることでしか得られない、回答やアドバイスがある。

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

ただいまの
回答率

90.33%

  • Java

    14427questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • MySQL

    6180questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • Eclipse

    1743questions

    Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

  • Spring

    735questions

    Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

springのapplication-config.xmlでエラーが出ます。

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 671

y-baminami

score 3

 前提・実現したいこと

質問です。

http://tech.pjin.jp/blog/2016/06/10/springframework8/
上記のサイトでspringの勉強をしており、
STSとMySQLの連携をしたいです。

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

application-config.xmlを指示通り書き換えたところ、
Multiple annotations found at this line:
    - cvc-complex-type.2.4.a: Invalid content was found starting with element 'property'. One of '{"http://
     www.springframework.org/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.

Multiple annotations found at this line:
    - Start tag of element <property>
    - cvc-complex-type.2.4.a: Invalid content was found starting with element 'property'. One of '{"http://
     www.springframework.org/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.

Multiple annotations found at this line:
    - End tag of element <property>
    - The element type "bean" must be terminated by the matching end-tag "</
     bean>".

以上の3つのエラーを吐いてしまいます。

 該当のソースコード

<?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>

 試したこと

終了タグなどがおかしいのかと思い、色々いじってみましたが、
application-config.xmlの書き方もよく分かっておらず、終了タグがいるものといらないものとあって
よく分かりませんでした。

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

macOS Sierra
STS 3.7.3.RELEASE

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

<!-- Uncomment and add your base-


の前って</bean>欲しくないですか?
その後のEntityManagerのところで<bean>始まってるのでネストしてしまうのではないかと


あまり、xmlで設定書いてないので間違ってるかもしれないですが
質問にあった xmlをフォーマットかけてみたものを下に貼ります。
やっぱりDataSourceのプロパティ当たりのネストが深い気がしますが何かの参考になるでしょうか?

<?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">
                    </bean>
                    <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>
                </property>
                <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()">
                                                </property>
                                                <property-placeholder location="classpath:jdbc.properties">
                                                    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
                                                        <property name="dataSource" ref="dataSource">
                                                        </property>
                                                        <bean id="namedParameterJdbcTemplate" class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
                                                            <constructor-arg ref="dataSource">
                                                            </constructor-arg>
                                                            <repositories base-package="jp.ssie.helloworld.repository">
                                                                <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
                                                                    <property name="entityManagerFactory" ref="entityManagerFactory">
                                                                    </property>
                                                                    <annotation-driven>
                                                                    </annotation-driven>
                                                                </bean>
                                                            </repositories>
                                                        </bean>
                                                    </bean>
                                                </property-placeholder>
                                            </property>
                                        </property>
                                    </property>
                                </property>
                            </property>
                        </property>
                    </property>
                </bean>
            </property>
        </property>
    </bean>
</beans>

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/06/28 21:01

    詳しい回答ありがとうございました。
    原因は古い情報をみていたため、インストールするライブラリの名前が違っていたことでした。

    キャンセル

  • 2018/09/06 13:10

    y-baminami様、はじめまして。
    解決済みの投稿へのレス失礼いたします。
    プログラミング初心者で同じサイトを使用して勉強しており、全く同じ3点のエラーで躓いております。
    「インストールするライブラリの名前が間違っていた」とのことですが、具体的にどのように修正されたのでしょうか。
    自分でライブラリ名などを調べてみておりますが、何分知識が至らず、ご教示いただけますと大変助かります。

    キャンセル

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

  • Java

    14427questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • MySQL

    6180questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • Eclipse

    1743questions

    Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

  • Spring

    735questions

    Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。