前提・実現したいこと
現在JavaでServletとJSPを用いたWebアプリケーションを作成しています。
eclipse/tomcat9サーバ上で開発を行い、eclipse上ではjsp,Servletのページ遷移など全て問題なくできています。
リンクボタン(Servlet指定)を押すとServlet内で指定したjspに遷移するという機能についてなのですが、仮想環境にデプロイして実行したところ、Servletを指定したボタンを実行するとHTTPステータス404エラーが出てしまいます。
(下記のソースコード:main.html内のレシピ管理ボタンを実行して、RecipesServlet.java → recipe_manage.jspに遷移したい)
仮想環境内でURLを指定すれば全てのjspには飛べるので、Servletの実行先のjspなどに問題があるわけではなさそうです。
自分で調べた結果、おそらくweb.xmlのURLパターン(?)あたりに原因があるのかなというところまでは絞れたのですが、eclipse上で実行した際は遷移も問題なくできているため、具体的な原因が特定できておりません。
ソースコードについては、サンプルを元に作成したものなので、web.xmlの設定の多くはコピーしてきたもののうち必要な部分を書き換えたのみで、自分では一部理解できていない箇所もあります。
問題なくページを遷移させるために具体的な解決策・アドバイスなどありましたらお願いいたします。
発生している問題・エラーメッセージ
エラーメッセージ http://192.168.33.10:8080/WebApp/basic/recipes/RecipesServlet を実行した際、 HTTPステータス404が表示される(オリジンサーバーは、ターゲットリソースの現在の表現を見つけられなかったか、またはそれが存在することを開示するつもりはありません。)。 ```### ソースコード
main.html
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <title>MyレシピTOP</title> <link rel="stylesheet" type="text/css" href="css/styles.css"> <link href="https://fonts.googleapis.com/css?family=Baloo+Tamma+2&display=swap" rel="stylesheet"> <link href="https://fonts.googleapis.com/css?family=M+PLUS+1p&display=swap" rel="stylesheet"> </head> <body> <div class="top-wrapper"> <div class="top-title"><h1>MyRecipe</h1></div></body> </html> ``` ``` RecipesServlet.java package recipes.servlet;<div class="top-contents"> <div class="recipe-management"><a href="basic/recipes/RecipesServlet">レシピ管理</a></div> <div class="user-management"><a href="auth/UserUpdateServlet">ユーザ管理</a></div> <form class="logout-btn top-logout-btn" action="auth/logout" method="post"> <input type="submit" value="ログアウト"> </form> </div> </div>
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import recipes.beans.RecipesInfoBean;
/**
- Servlet implementation class RecipesServlet
*/
@WebServlet("/basic/recipes/RecipesServlet")
public class RecipesServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
/** * @see HttpServlet#HttpServlet() */ public RecipesServlet() { super(); // TODO Auto-generated constructor stub } /** * 初期表示 */ protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { System.out.println("RecipesServlet.doGet()"); System.out.println("【レシピ一覧初期表示】"); // 【レシピ一覧の作成】 ArrayList<RecipesInfoBean> recipesList = new ArrayList<>(); // ■DB接続 Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; // 接続情報 String url="jdbc:mysql://localhost:3306/myrecipe_db"; String user="(ユーザ名)"; String password="(パスワード)"; try { // 接続処理 conn = DriverManager.getConnection(url, user, password); // ■検索処理実行 // SQL作成 String sql = "SELECT\r\n" + " recipe_table.recipe_id,\r\n" + " recipe_table.recipe_name,\r\n" + " recipe_table.budget,\r\n" + " recipe_table.ingredients,\r\n" + " recipe_table.ingredients_memo,\r\n" + " recipe_table.howto\r\n" + "FROM\r\n" + " recipe_table\r\n" + "WHERE recipe_table.del_flag = 0"; System.out.println(sql); // SQL準備 ps = conn.prepareStatement(sql); // SQL実行 rs = ps.executeQuery(); // データを読込み、レシピ一覧(ArrayList)に設定する System.out.println("■一覧データを設定"); while(rs.next()) { // データ読込 int recipeId = rs.getInt("recipe_id"); String recipeName = rs.getString("recipe_name"); int budget = rs.getInt("budget"); String ingredients = rs.getString("ingredients"); String ingredientsMemo = rs.getString("ingredients_memo"); String howto = rs.getString("howto"); // レシピ情報(JavaBeans)に追加 RecipesInfoBean recipesInfo = new RecipesInfoBean(); recipesInfo.setRecipeId(recipeId); recipesInfo.setRecipeName(recipeName); recipesInfo.setBudget(budget); recipesInfo.setIngredients(ingredients); recipesInfo.setIngredientsMemo(ingredientsMemo); recipesInfo.setHowto(howto); System.out.println(recipesInfo); // レシピ一覧(ArrayList)に追加 recipesList.add(recipesInfo); } } catch(SQLException e) { // 接続失敗時の処理 e.printStackTrace(); } finally { try { // ■クローズ処理 // 検索結果 if(rs!=null) { rs.close(); } // SQL文 if(ps!=null) { ps.close(); } // DB接続 if(conn!=null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } // 【表示値を設定する】 System.out.println(recipesList); request.setAttribute("recipesList", recipesList); // 【画面に遷移する】 request.getRequestDispatcher("recipe_manage.jsp").forward(request, response); } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); }
}
```web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" id="WebApp_ID" version="4.0"> <display-name>Myrecipe</display-name> <welcome-file-list> <welcome-file>main.html</welcome-file> </welcome-file-list> <error-page> <error-code>403</error-code> <location>/auth/login_err.jsp</location> </error-page> <login-config> <auth-method>FORM</auth-method> <form-login-config> <form-login-page>/auth/login.jsp</form-login-page> <form-error-page>/auth/login_err.jsp</form-error-page> </form-login-config> </login-config> <security-role> <role-name>myrecipe</role-name> </security-role> <!-- ■認証をかけるURL ○/main.html[メイン画面]※「/」も同じURLに今回は設定 ○/basic/~ ■認証をかけないURL ○/auth/~[認証関連] --> <security-constraint> <web-resource-collection> <web-resource-name>Authentication of FormAuth</web-resource-name> <url-pattern>/main.html</url-pattern> <url-pattern>/basic/*</url-pattern> <!-- <url-pattern>/object/*</url-pattern> --> </web-resource-collection> <auth-constraint> <role-name>myrecipe</role-name> </auth-constraint> </security-constraint> <session-config> <session-timeout>30</session-timeout> </session-config> </web-app>
server.xml <?xml version="1.0" encoding="UTF-8"?> <Server port="8005" shutdown="SHUTDOWN"> <Listener className="org.apache.catalina.startup.VersionLoggerListener" /> <!--APR library loader. Documentation at /docs/apr.html --> <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" /> <!-- Prevent memory leaks due to use of particular java/javax APIs--> <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /> <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /> <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" /> <GlobalNamingResources> <Resource name="UserDatabase" auth="Container" type="org.apache.catalina.UserDatabase" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" pathname="conf/tomcat-users.xml" /> </GlobalNamingResources> <Service name="Catalina"> <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> <Engine name="Catalina" defaultHost="localhost"> <Realm className="org.apache.catalina.realm.LockOutRealm"> <Realm className="org.apache.catalina.realm.JDBCRealm" connectionName="(ユーザ名)" connectionPassword="(パスワード)" connectionURL="jdbc:mysql://localhost:3306/myrecipe_db" driverName="com.mysql.jdbc.Driver" roleNameCol="rolename" userCredCol="password" userNameCol="username" userRoleTable="auth_roles" userTable="auth_users"> <CredentialHandler algorithm="SHA-256" className="org.apache.catalina.realm.MessageDigestCredentialHandler"/> </Realm> </Realm> <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true"> <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t "%r" %s %b" /> </Host> </Engine> </Service> </Server>
試したこと
各jspを指定して実行(エラーなく遷移した)
Servletのurlをいろいろ変えて実行(404エラー)
補足情報(FW/ツールのバージョンなど)
仮想環境:CentOS6.6
サーバ:tomcat9.0.34
アプリのWebApp.warファイルは
/opt/tomcat/apache-tomcat-9.0.34/webappsに配置
回答1件
あなたの回答
tips
プレビュー