質問編集履歴

2 情報追加

oku

oku score 5

2017/01/27 10:32  投稿

Springで作成したプロジェクトをTomcatで実行した時に「The requested resource is not available.」が表示されてしまう
###前提・実現したいこと
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
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
  • Spring

    1033 questions

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

  • Tomcat

    704 questions

    TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

1 アクセスURLを「http://localhost:8080/SpringKenshu/show」から「http://localhost:8080/sp02/show」に変更

oku

oku score 5

2017/01/26 11:22  投稿

Springで作成したプロジェクトをTomcatで実行した時に「The requested resource is not available.」が表示されてしまう
###前提・実現したいこと
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/SpringKenshu/show」をIEで表示したところ、以下のエラーメッセージが発生しているということです。
現在問題になっているのは「Controllerから文字列を渡して表示してみよう」で、Javaクラスを作成し、「mvc-config.xml」を編集後、「http://localhost:8080/sp02/show」をIEで表示したところ、以下のエラーメッセージが発生しているということです。
「http://localhost:8080/sp02-01/show」でも同じエラーです。
解決方法のご教示お願いいたします。
###発生している問題・エラーメッセージ
```
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
###補足情報(言語/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
  • Spring

    1033 questions

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

  • Tomcat

    704 questions

    TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

思考するエンジニアのためのQ&Aサイト「teratail」について詳しく知る