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

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

ただいまの
回答率

88.64%

Spring frameworkで、設定xmlファイルが読み込みができず実行されない

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 8,086

sakuramob

score 16

Spring mvc(Spring Bootではない)で、mavenを使ってwebアプリケーションを新規で作っています。
ですが、ビルドし、実行するときにエラーがでてしまい、実行できません。

バージョン

  • Spring mvc 3.2.3
  • maven 2.6

mainメソッドファイル

package com.example.demo;

import org.springframework.ui.ModelMap;

public class App {
    public static void main(String[] args) {

        TestSpringMVCController tsc = new TestSpringMVCController();
        ModelMap model = new ModelMap();
        tsc.testSpringMVCController(model);
    }
}

Controllerファイル

package com.example.demo;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.List;
import java.util.Map;

import javax.sql.DataSource;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Scope;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Controller;
import org.springframework.stereotype.Repository;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
@Component
@Scope("singleton")
@Repository
public class TestSpringMVCController {

    static ApplicationContext  context = new FileSystemXmlApplicationContext("file:dataSource.xml");

    @Autowired
    protected JdbcTemplate jdbcTemplate = new JdbcTemplate();
    protected DataSource dataSource = (DataSource)context.getBean("dataSource");

    public DataSource getDataSource() {
        return dataSource;
    }

    public void setDataSource(DataSource dataSource) {
        this.dataSource = dataSource;
        jdbcTemplate.setDataSource(getDataSource());
    }

    @Autowired
    @RequestMapping("/")
    public String testSpringMVCController(ModelMap model) {

        Log log = LogFactory.getLog(TestSpringMVCController.class);
    }
}

設定ファイル

<?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"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context-4.2.xsd">

    <context:component-scan base-package="com.example.demo" />

    <bean id="testSpringMVCController" class="com.example.demo.TestSpringMVCController">
        <property name="dataSource" ref="dataSource"/>
    </bean>

    <bean id="dataSource"
        class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://XXXXXXXXXXXXX:3306/table" />
        <property name="username" value="XXX" />
        <property name="password" value="YYY" />
    </bean>

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

    <bean id="main" class="com.example.demo.App" />
</beans>


尚、設定ファイルは別ファイルとして、実行ファイルと同じ階層に配置しています。

ビルドまではできるのですが、jarファイルを実行するときに下記のエラーが出力されます。

10 31, 2018 1:28:08 午後 org.springframework.context.support.AbstractApplicationContext prepareRefresh
情報: Refreshing org.springframework.context.support.FileSystemXmlApplicationContext@66a29884: startup date [Wed Oct 31 13:28:08 JST 2018]; root of context hierarchy
10 31, 2018 1:28:09 午後 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
情報: Loading XML bean definitions from URL [file:dataSource.xml]
10 31, 2018 1:28:14 午後 org.springframework.beans.factory.support.DefaultListableBeanFactory registerBeanDefinition
情報: Overriding bean definition for bean 'testSpringMVCController': replacing [Generic bean: class [com.example.demo.TestSpringMVCController]; scope=singleton; abstract=false; lazyInit=false; autowireMode=0; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null; defined in URL [jar:file:/root/mvc/testspringmvc-0.0.1-SNAPSHOT.jar!/com/example/demo/TestSpringMVCController.class]] with [Generic bean: class [com.example.demo.TestSpringMVCController]; scope=; abstract=false; lazyInit=false; autowireMode=0; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null; defined in URL [file:dataSource.xml]]
10 31, 2018 1:28:15 午後 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons
情報: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@f6c48ac: defining beans [testSpringMVCController,org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor,dataSource,jdbcTemplate,main,org.springframework.context.annotation.ConfigurationClassPostProcessor.importAwareProcessor]; root of factory hierarchy
10 31, 2018 1:28:16 午後 org.springframework.beans.factory.support.DefaultSingletonBeanRegistry destroySingletons
情報: Destroying singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@f6c48ac: defining beans [testSpringMVCController,org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor,dataSource,jdbcTemplate,main,org.springframework.context.annotation.ConfigurationClassPostProcessor.importAwareProcessor]; root of factory hierarchy
Exception in thread "main" java.lang.ExceptionInInitializerError
        at com.example.demo.App.main(App.java:11)
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'testSpringMVCController' defined in URL [file:dataSource.xml]: Instantiation of bean failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [com.example.demo.TestSpringMVCController]: Constructor threw exception; nested exception is java.lang.NullPointerException
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateBean(AbstractAutowireCapableBeanFactory.java:1007)
(略)
        at org.springframework.context.support.FileSystemXmlApplicationContext.<init>(FileSystemXmlApplicationContext.java:140)
        at org.springframework.context.support.FileSystemXmlApplicationContext.<init>(FileSystemXmlApplicationContext.java:84)
        at com.example.demo.TestSpringMVCController.<clinit>(TestSpringMVCController.java:30)
        ... 1 more
Caused by: org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [com.example.demo.TestSpringMVCController]: Constructor threw exception; nested exception is java.lang.NullPointerException
        at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:163)
        at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:87)
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateBean(AbstractAutowireCapableBeanFactory.java:1000)
        ... 14 more
Caused by: java.lang.NullPointerException
        at com.example.demo.TestSpringMVCController.<init>(TestSpringMVCController.java:34)
(略)
        ... 16 more

恐らくdataSource.xmlファイルの中身に問題があると思い、調べて修正したのですが、原因がわかりませんでした。
どなたかわかる方、ご教授いただきたいです。よろしくお願いいたします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

xml定義は特に大きな問題はないのですが、テスト対象のクラスのアノテーションや起動クラスの書き方が良くありません。特にアノテーションで不要なものがいくつかあり、また、Controllerで必要なものはDataSourceではなくJdbcTemplateを使った処理が必要ではないかと思います。
JdbcTemplateにDataSourceをバインドするのは、すでにdataSource.xmlで書かれているので、Controllerには記載は不要です。

Controllerの書き方は例えば以下のようになるでしょう。

import java.util.List;
import java.util.Map;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class TestSpringMVCController {

    @Autowired
    protected JdbcTemplate jdbcTemplate;

    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
    this.jdbcTemplate = jdbcTemplate;
    }

    @RequestMapping("/")
    public String testSpringMVCController(ModelMap model) {

        List<Map<String,Object>> result = jdbcTemplate.queryForList("SELECT 1");

        return "";
    }
}

これを呼び出しているAppクラスは、xmlファイルからSpringの管理下に置かれたクラスを呼び出すのが便利なので、

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.ui.ModelMap;

import com.github.apz.controller.TestSpringMVCController;

public class App {

    public static void main(String[] args) {
        ApplicationContext context = new FileSystemXmlApplicationContext("file:dataSource.xml");
    TestSpringMVCController tsc =(TestSpringMVCController)context.getBean("testSpringMVCController");
        ModelMap model = new ModelMap();
        tsc.testSpringMVCController(model);
    }
}

とするのが一番シンプルでしょう。

Springの定義ファイルである、dataSource.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"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context-4.2.xsd">

    <context:component-scan base-package="com.github.apz" />

    <bean id="testSpringMVCController" class="com.github.apz.controller.TestSpringMVCController">
        <property name="jdbcTemplate" ref="jdbcTemplate"/>
    </bean>

    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="org.mariadb.jdbc.Driver" />
        <property name="url" value="jdbc:mariadb://127.0.0.1:3306/test" />
        <property name="username" value="root" />
        <property name="password" value="password" />
    </bean>

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

    <bean id="main" class="com.github.apz.App" />
</beans>

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • この投稿は削除されました

  • 2018/10/31 21:12

    回答ありがとうございます。
    頂いたもので、javaは動くようになりました^^

    ただ、urlで実行したいのですが、java内で処理が終了してしまいます。
    その質問をこちらに新規で作成したので、もしお時間があるようでしたらご確認をお願いいたします。

    キャンセル

  • キャンセル

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

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

関連した質問

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