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

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

ただいまの
回答率

91.76%

  • Spring

    439questions

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

  • Tomcat

    411questions

Springで作成したプロジェクトをTomcatで実行した時に「The requested resource is not available.」が表示されてしまう

解決済

回答 2

投稿 2017/01/26 10:54 ・編集 2017/01/27 10:32

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

oku

score 1

前提・実現したいこと

Spring(Spring Tool Suite)Version3.7.3で、Springレガシー・プロジェクトをテンプレートとしたプログラムを作成しています。
下記URLにある「サンプルPJの作成」、「tcサーバの起動とサンプルの実行」、「Controllerから文字列を渡して表示してみよう」を見ながら、同じものを作っています。
http://qiita.com/yu_eguchi/items/9a56e6c6281c1f0435ff
※SpringKenshuをsp02に変えて作成している。

現在問題になっているのは「Controllerから文字列を渡して表示してみよう」で、Javaクラスを作成し、「mvc-config.xml」を編集後、「http://localhost:8080/sp02/show」をIEで表示したところ、以下のエラーメッセージが発生しているということです。
「http://localhost:8080/sp02-01/show」でも同じエラーです。

最終目標は「Hello World」が表示されるところまでです。

解決方法のご教示お願いいたします。

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

HTTPステータ404-
type ステータスレポート
メッセージ
説明 The requested resource is not available.
Apache Tomcat/7.0.47

該当のソースコード

【pom.xml】
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>sp02</groupId>
  <artifactId>sp02</artifactId>
  <version>01</version>
  <packaging>war</packaging>

    <properties>

      <!-- Generic properties -->
      <java.version>1.7</java.version>
      <maven.compiler.target>${java.version}</maven.compiler.target>
      <maven.compiler.source>${java.version}</maven.compiler.source>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>

      <!-- Web -->
      <jsp.version>2.2</jsp.version>
      <jstl.version>1.2</jstl.version>
      <servlet.version>3.1.0</servlet.version>

      <!-- Spring -->
      <spring-framework.version>4.1.6.RELEASE</spring-framework.version>

      <!-- Hibernate / JPA -->
      <hibernate.version>4.2.1.Final</hibernate.version>

      <!-- Logging -->
      <logback.version>1.0.13</logback.version>
      <slf4j.version>1.7.5</slf4j.version>

      <!-- Test -->
      <junit.version>4.11</junit.version>

    </properties>

    <dependencies>

      <!-- Spring MVC -->
      <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${spring-framework.version}</version>
      </dependency>

      <!-- Other Web dependencies -->
      <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
        <version>${jstl.version}</version>
      </dependency>
      <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>${servlet.version}</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>javax.servlet.jsp</groupId>
        <artifactId>jsp-api</artifactId>
        <version>${jsp.version}</version>
        <scope>provided</scope>
      </dependency>

      <!-- Spring and Transactions -->
      <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>${spring-framework.version}</version>
      </dependency>

      <!-- Logging with SLF4J & LogBack -->
      <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>${slf4j.version}</version>
        <scope>compile</scope>
      </dependency>
      <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>${logback.version}</version>
        <scope>runtime</scope>
      </dependency>

      <!-- Hibernate -->
      <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>${hibernate.version}</version>
      </dependency>

      <!-- Test Artifacts -->
      <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>${spring-framework.version}</version>
        <scope>test</scope>
      </dependency>
      <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>${junit.version}</version>
        <scope>test</scope>
      </dependency>

    </dependencies>
</project>

【TestController.java】
package jp.co.kenshu;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
@Controller
public class TestController {
    @RequestMapping(value = "/show", method = RequestMethod.GET)
    public String showMessage(Model model) {
        model.addAttribute("message", "hello world!!");
        return "showMessage";
    }
}

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

    <!-- Uncomment and your base-package here: -->
    <context:component-scan base-package="jp.co.kenshu"/>
    <mvc:annotation-driven />
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <!-- Example: a logical view name of 'showMessage' is mapped to '/WEB-INF/jsp/showMessage.jsp' -->
      <property name="prefix" value="/WEB-INF/view/"/>
      <property name="suffix" value=".jsp"/>
    </bean>
</beans>

試したこと

Springで作成したwarファイルを、Tomcatがインストールされている場所にwarファイルをコピーしてみたが、結果は変わらず。
Springの場所)C:\A\sts-bundle\sts-3.7.3.RELEASE\WorkSpace\sp02\target\sp02-01.war
Tomcatの場所)C:\A\Tomcat7047\webapps\sp02-01.war

ご回答いただいた情報を元に追加で試したこと

その1)
Springは起動せずに、Tomcatがインストールされている場所にある「startup.bat」をコマンドプロンプトから起動。
Springで作成したwarファイルを、Tomcatがインストールされている場所にwarファイルをコピー。
Springの場所)C:\A\sts-bundle\sts-3.7.3.RELEASE\WorkSpace\sp02\target\sp02-01.war
Tomcatの場所)C:\A\Tomcat7047\webapps\sp02-01.war
IEで「http://localhost:8080/sp02/」にアクセスすると「Click to enter」が表示される。
「Click to enter」を押下すると問題となっている「The requested resource is not available.」が表示される。
この状態で、IEで「http://localhost:8080/sp02/show」にアクセスするも「The requested resource is not available.」が表示される。
なぜ「Hello World」が表示されないのか。。。
疑問:なぜSpringからTomcatを起動した場合は、エラーになるのか。。。

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

OS:Windows7 32bit版
Spring(Spring Tool Suite)純正開発ツール Version 3.7.3
Java(JDK):Version 1.7.0_80
Apache Maven:Version 3.3.9
Apache Tomcat:Version 7.0.47

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

0

アクセスしたのは、
http://localhost:8080/sp02-01/show
ではなく
http://localhost:8080/SpringKenshu/show
ですか?

sp02-01.warをtomcatのwebappsにそのまま置いたのならば、コンテキストパスはsp02-01になると思うので、
http://localhost:8080/sp02-01/show
でアクセスする必要があるかと思います。

投稿 2017/01/26 11:04

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

    以下のような回答は評価を下げられます

    • 間違っている回答
    • 質問の回答になっていない投稿
    • 不快な投稿

    評価を下げる際はその理由をコメントに書き込んでください。

  • 2017/01/26 11:16

    すいません。URLの記載ミスです。
    「http://localhost:8080/sp02/show」でアクセスしてエラーが出ました。
    「http://localhost:8080/sp02-01/show」でアクセスしても同じエラーが出ました。

    キャンセル

  • 2017/01/26 11:42

    記載されていたQiitaの投稿を参考に私の環境で試してみましたが、正しく/showにアクセスできました。
    mvc-config.xmlのcontext:component-scanとbase-packageの文字がくっついていたのでそこだけは直したのですが、提示されているmvc-config.xmlを見る限りそこも修正されていると思います。
    「http://localhost:8080/sp02/」でアクセスした場合は、404にならずに「Click to enter」などが表示されると思いますが、どうでしょうか。

    キャンセル

  • 2017/01/27 10:02

    以下の手順だと「Click to enter」が表示されました。
    1.Tomcatがインストールされている場所のbinにあるstartup.batをコマンドプロンプトから実行。
    2.Tomcatがインストールされている場所のwebappsにsp02-01.warをコピー。
    3.IEから「http://localhost:8080/sp02/」をアクセスすると「Click to enter」が表示された。
    4.ただし「Click to enter」を押下すると「The requested resource is not available.」エラーが表示されてしまう。
    疑問1.なぜSpringからTomcatを起動した場合は、うまくいかないのか。
    疑問2.最終目標は「Hello World」が表示されることなのですが、なぜ表示されないのか。
    引き続き、ご教示いただけると助かりますので、お願いいたします。

    キャンセル

  • 2017/01/27 12:03

    4.ただし「Click to enter」を押下すると「The requested resource is not available.」エラーが表示されてしまう。
    ⇒「Click to enter」の遷移先は/showMessage.htmlとなっているので、これは正しい動きだと思います。

    疑問1,2についてですが、tomcat起動時に以下のようなログは出力されているでしょうか。
    出力されていない場合、TestControllerの登録に失敗しているということなので、TestControllerもしくはmvc-config.xmlを見直すとよいかもしれません。
    1 27, 2017 11:57:42 午前 org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping registerHandlerMethod
    情報: Mapped "{[/show],methods=[GET],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public java.lang.String jp.co.kenshu.TestController.showMessage(org.springframework.ui.Model)

    キャンセル

  • 2017/01/27 15:35

    Tomcat起動時のログを確認したところ「情報: Mapped・・・」というログが出力されていませんでした。mvc-config.xmlのファイルが編集されていませんでした(targetフォルダ以下にあるmvc-config.xmlを修正していました)。srcフォルダ以下にあるmvc-config.xmlを修正した結果、Tomcat起動時のログに「情報: Mapped・・・」が表示されていることが確認でき、「Click to enter」も表示されるようになりました。

    最後の疑問点なんですが、今回参照したHP(http://qiita.com/yu_eguchi/items/9a56e6c6281c1f0435ff)よると、この段階で「http://localhost:8080/sp02/show」にアクセスすると「Hello World」が表示されるとの記載がありますが、この記載が間違っているのでしょうか。

    キャンセル

  • 2017/01/27 16:30

    間違ってないと思います。
    TestControllerクラスを作成し、mvc-config.xmlに作成したTestControllerのパッケージ(jp.co.kenshu)をcomponent-scanの対象として設定すれば「/show」へのリクエストで「Hello World」は表示されます。
    ちなみに「Click to enter」押下時の遷移先は該当ページの手順では設定していないため、手順通り最後まで実装しても404になります。

    キャンセル

  • 2017/01/30 08:44

    上記の件、了解しました。
    丁寧なご回答ありがとうございました。
    とても助かりました。

    キャンセル

0

>※SpringKenshuをsp02に変えて作成している。

で、あれば、URLは、「http://localhost:8080/SpringKenshu/show」ではなく、
「http://localhost:8080/sp02/show」に、なっているのではないでしょうか?

投稿 2017/01/26 11:11

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

    以下のような回答は評価を下げられます

    • 間違っている回答
    • 質問の回答になっていない投稿
    • 不快な投稿

    評価を下げる際はその理由をコメントに書き込んでください。

  • 2017/01/26 11:15

    すいません。URLの記載ミスです。
    「http://localhost:8080/sp02/show」で表示しても同じエラーが出ました。

    キャンセル

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

ただいまの回答率

91.76%

関連した質問

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

  • Spring

    439questions

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

  • Tomcat

    411questions

  • トップ
  • Springに関する質問
  • Springで作成したプロジェクトをTomcatで実行した時に「The requested resource is not available.」が表示されてしまう