Написание фильтра авторизации для моего веб-приложения (JSF 2.0) - PullRequest
3 голосов
/ 14 апреля 2011

Следуя некоторым советам, я решил написать свой собственный фильтр авторизации для своего веб-приложения (я не использую безопасность, управляемую контейнером, поэтому я должен сделать это таким образом).

Это мой первый фильтр, поэтому яЯ немного запутался в том, как я должен это реализовать.Это то, что я сделал до сих пор:

package filters;

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.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import entities.Role;

public class RestrictPageFilter implements Filter {

    FilterConfig fc;

    public void init(FilterConfig filterConfig) throws ServletException {
        // The easiest way to initialize the filter
        fc = filterConfig;
    }

    public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain chain) throws IOException, ServletException {

        HttpServletRequest req = (HttpServletRequest) request;
        HttpServletResponse resp = (HttpServletResponse) response;
        HttpSession session = req.getSession(true);
        String pageRequested = req.getRequestURL().toString();

        Role currentUser = (Role) session.getAttribute("userRole");

        //Pages that are allowed with no need to login:
        //-faq.xhtml
        //-index.jsp
        //-login.xhtml
        //-main.xhtml
        //-registration.xhtml

        //NOW pages that are restricted depending on the type of user
        //buyoffer.xhtml(Only BUYER)
        //sellerpanel.xhtml(Only SELLER)
        //adminpanel.xhtml(Only ADMINISTRATOR)

        //HOW SHOULD I IMPLEMENT THAT??
        if(currentUser != null && currentUser.getType().equals("BUYER")) {          

        }
        if(currentUser != null && currentUser.getType().equals("SELLER")) {         

        }
        if(currentUser != null && currentUser.getType().equals("ADMINISTRATOR")) {          

        }


    }

    public void destroy() {
        // Not needed
    }
}

Как видите, я оставил комментарии там, где застрял.Может кто-нибудь помочь мне закончить этот фильтр или дать несколько советов по псевдокоду, как мне его закончить?

Я видел несколько примеров в Интернете, но ни один из них не выполняет различную фильтрацию в зависимости от типа пользователя.

Я буду признателен за вашу помощь:)

Обновление

Я создал XML-файл, чтобы помочь мне выполнить фильтрацию (он находится внутри WEB-INF / classes)

<access>
    <buyer>
        <page>buyoffer.xhtml</page>
        <page>faq.xhtml</page>
        <page>index.jsp</page>
        <page>login.xhtml</page>
        <page>main.xhtml</page>
        <page>registrationSucceded.xhtml</page>     
    </buyer>
    <seller>
        <page>sellerpanel.xhtml</page>
        <page>faq.xhtml</page>
        <page>index.jsp</page>
        <page>login.xhtml</page>
        <page>main.xhtml</page>
        <page>registrationSucceded.xhtml</page>     
    </seller>
    <administrator>
        <page>sellerpanel.xhtml</page>
        <page>faq.xhtml</page>
        <page>index.jsp</page>
        <page>login.xhtml</page>
        <page>main.xhtml</page>
        <page>registrationSucceded.xhtml</page>     
    </administrator>
</access>

<!-- THE REGISTRATION PAGES SHOULD NOT BE ACCESSIBLE IF THE USER IS LOGGED IN -->

Я прочитал файл из метода init ().()

public class RestrictPageFilter implements Filter {

    private FilterConfig fc;
private InputStream in;

    public void init(FilterConfig filterConfig) throws ServletException {
        // The easiest way to initialize the filter
        fc = filterConfig;
        //Get the file that contains the allowed pages
        in = this.getClass().getResourceAsStream("/allowedpages.xml");
    }

    public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain chain) throws IOException, ServletException {

        HttpServletRequest req = (HttpServletRequest) request;
        HttpServletResponse resp = (HttpServletResponse) response;
        HttpSession session = req.getSession(true);
        String pageRequested = req.getRequestURL().toString();

        //Get the value of the current logged user 
        Role currentUser = (Role) session.getAttribute("userRole");
        if (currentUser != null) {

        }
    }

    public void destroy() {
        // Not needed
    }
}

1 Ответ

4 голосов
/ 14 апреля 2011

Если вам нужно разрешить доступ, просто наберите

// it will process request normally, means it will leave the control from Filter
chain.doFilter(request, response);

если вы хотите ограничить пользователя, тогда звоните

//take some action
response.sendRedirect("URL to some page");//it will simply make user redirected 

Некоторые предложения

  • Сделайте его настраиваемым, используя какой-то XML-файл свойств, ваш код кажется мне сложным, завтра может быть добавлена ​​еще одна страница, поэтому вам нужно перекомпилировать ваш фильтр.

  • Если это разрешено, то просто используйте Spring Security, у него есть приятные функции. Также вы не будете заново изобретать колесо

...