2

j_security_checkの呼び出しを処理するTomcatをアクティブ化するために何かする必要がありますか?設定とHTMLコードは以下のとおりです。このエラーが発生します:

エラーメッセージ

タイプステータスレポート

メッセージ/(コンテキストパス)/ ProviderManager / j_security_check

description要求されたリソース(/(コンテキストパス)/ ProviderManager / j_security_check)は利用できません。

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
    <session-config>
        <session-timeout>
            30
        </session-timeout>
    </session-config>

    <security-constraint>
        <display-name>Constraint1</display-name>
        <web-resource-collection>
            <web-resource-name>ProviderManager</web-resource-name>
            <description/>
            <url-pattern>/ProviderManager/*</url-pattern>
        </web-resource-collection>
        <auth-constraint>
            <description/>
            <role-name>tomcat</role-name>
        </auth-constraint>
    </security-constraint>
    <login-config>
        <auth-method>FORM</auth-method>
        <form-login-config>
            <form-login-page>/ProviderManager/login.jsp</form-login-page>
            <form-error-page>/ProviderManager/error.jsp</form-error-page>
        </form-login-config>
    </login-config>
    <security-role>
        <description/>
        <role-name>tomcat</role-name>
    </security-role>
</web-app>

tomcat-users.xml

<tomcat-users>

  <role rolename="tomcat"/>
  <role rolename="role1"/>

  <user username="tomcat" password="tomcat" roles="tomcat"/>
  <user username="both" password="tomcat" roles="tomcat,role1"/>
  <user username="role1" password="tomcat" roles="role1"/>

  <user username="ide" password="mgPNx5x5" roles="manager-script,admin"/>
</tomcat-users>

login.html

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <form action="j_security_check" method="POST">
           Username:<input type="text" name="j_username"><br>
           Password:<input type="password" name="j_password">
           <input type="submit" value="Login">
        </form>
    </body>
</html>

前もって感謝します、

Guido

4

3 に答える 3

11

ログイン フォーム ページのactionパラメータは、ログイン ページの URL に関連する URL として解釈されるため、フォームを送信すると、ブラウザは URL を使用して POST リクエストをサーバーに送信します/[context-path]/ProviderManager/j_security_check。サーブレット コンテナーは/[context-path]/j_security_check、webapp への認証要求のパスとして使用します。

次のいずれかでこれを修正する必要があります。

  1. actionログイン ページのパラメータを に変更します../j_security_check
  2. actionログイン ページのパラメータを次のように変更します。/[context-root]/j_security_check
  3. ログイン ページをアプリケーション コンテキストのルート ディレクトリに移動します。
于 2012-05-31T18:12:58.147 に答える
0

tomcat-users.xml が無効です。

<tomcat-users>
  <role rolename="manager-script"/>
  <role rolename="manager-gui"/>
  <role rolename="admin"/>
  <user username="ide" password="whatever" roles="manager-script,admin"/>
</tomcat-users>

空の説明タグを削除する必要があります。<description/>

于 2012-06-01T21:18:06.013 に答える
0

何も設定する必要はありません。

プロジェクトのディレクトリ構造は何ですか? 問題はパスです。

login.jsp と error.jsp を WebContent/pages に入れて試してください:

<login-config>
<auth-method>FORM</auth-method>
<form-login-config>
    <form-login-page>/pages/login.jsp</form-login-page>
    <form-error-page>/pages/error.jsp</form-error-page>
</form-login-config>

于 2012-05-31T17:46:48.480 に答える