1

Netbeans で JSP プロジェクトのサーブレット フィルターを実行しようとしています。私がしたいのは、ユーザーがログインしているかどうかを確認し、ログインしていない場合は、ログオン ページにリダイレクトすることです。私はこのチュートリアルに従いました:

https://stackoverflow.com/tags/servlet-filters/info

だから私はフィルタークラスとしてこのJavaファイルを持っています(ファイル名はLoginFilter.javaです):

import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

@WebFilter("/app/*")
public class LoginFilter implements Filter {

@Override
public void init(FilterConfig config) throws ServletException {
    // If you have any <init-param> in web.xml, then you could get them
    // here by config.getInitParameter("name") and assign it as field.
}

@Override
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
    HttpServletRequest request = (HttpServletRequest) req;
    HttpServletResponse response = (HttpServletResponse) res;
    HttpSession session = request.getSession(false);

    if (session == null || session.getAttribute("usuario") == null) {
        response.sendRedirect(request.getContextPath() + "/login.jsp"); // No logged-in user found, so redirect to login page.
    } else {
        chain.doFilter(req, res); // Logged-in user found, so just continue request.
    }
}

@Override
public void destroy() {
    // If you have assigned any expensive resources as field of
    // this Filter class, then you could clean/close them here.
}

}

これが私のweb.xmlです

<?xml version="1.0" encoding="UTF-8"?>

<web-app 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"
 version="3.0">
<session-config>
    <session-timeout>
        30
    </session-timeout>
</session-config>

<filter>
    <filter-name>LoginFilter</filter-name>
    <filter-class>LoginFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>LoginFilter</filter-name>
    <url-pattern>/app/*</url-pattern>
</filter-mapping>

ただし、これは機能していません。誰かが私に欠けているものを教えてもらえますか?

4

1 に答える 1

1

私は問題を解決することができました。問題は、ページが読み込まれるたびにフィルターがコードをチェックすることです。私の場合、変数「usuario」をどこにも宣言していませんでした。この変数は、リダイレクトを可能にするものですページにログインするか、現在のページの読み込みを続行します。そのため、ユーザーがログインしたときに変数を設定するように変更しました (補助ページがログインをチェックし、そこに変数が設定されます)。次に、他のすべてのページは変数を設定せず、ログインチェックで設定されたものを取得します。

コメントに答えてくださった方々、本当にありがとうございます。

于 2013-07-02T04:35:53.797 に答える