Próbuję zintegrować Spring Security w mojej wiosennej aplikacji internetowej. Zasadniczo muszę ukryć niektóre menu na podstawie pozwolenia użytkownika. Oto co zrobiłem.Wiosenne bezpieczeństwo hasPermission nie działa
Dodałem poniżej JARS w ścieżce klas.
spring-security-acl-4.0.2.RELEASE.jar
spring-security-config-4.0.2.RELEASE.jar
spring-security-core-4.0.2.RELEASE.jar
spring-security-taglibs-4.0.1.RELEASE.jar
spring-security-web-4.0.2.RELEASE.jar
Poniżej znajdują się wpisy w web.xml
<context-param>
<param-name>log4jConfiguration</param-name>
<param-value>/WEB-INF/web_log4j.xml</param-value>
</context-param>
<listener>
<listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class>
</listener>
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring-root.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
Napisałem CustomPermissionEvaluator klasy jak poniżej.
public class CustomPermissionEvaluator implements PermissionEvaluator{
@Override
public boolean hasPermission(Authentication authentication, Object targetDomainObject, Object permission) {
HttpServletRequest request = (HttpServletRequest) targetDomainObject;
Profile userProfile = (Profile) request.getSession().getAttribute("testprofile");
if (userProfile.getPermissionMap().get(String.valueOf(permission)) != null) {
return true;
} else {
return false;
}
}
@Override
public boolean hasPermission(Authentication arg0, Serializable arg1,
String arg2, Object arg3) {
// TODO Auto-generated method stub
return false;
}
}
Po tym pisałem plik SecurityConfig.
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Override
public void configure(WebSecurity web) throws Exception {
DefaultWebSecurityExpressionHandler handler = new DefaultWebSecurityExpressionHandler();
handler.setPermissionEvaluator(new CustomPermissionEvaluator());
web.expressionHandler(handler);
}
}
mam poniżej wpisów w moim wiosna-root.xml
<sec:global-method-security pre-post-annotations="enabled">
<sec:expression-handler ref="expressionHandler" />
</sec:global-method-security>
<bean id="expressionHandler"
class="org.springframework.security.access.expression.method.DefaultMethodSecurityExpressionHandler">
<property name="permissionEvaluator" ref="permissionEvaluator" />
</bean>
<bean id="permissionEvaluator" class="main.java.com.config.CustomPermissionEvaluator" />
Teraz w moim pliku JSP Używam poniżej TagLib.
i poniżej kod
<sec:authorize access="hasPermission('cadastra_categoria', #request)">
<div id="TEST">
</div>
</sec:authorize>
Ale to nie działa. Wszelkie sugestie zostaną docenione.
Czy istnieje wskaźnik, błąd czy coś? Czy wywołanie hasPermission osiągnęło implementację po umieszczeniu punktu przerwania? Myślę, że brakuje filtrów bezpieczeństwa https://docs.spring.io/spring-security/site/docs/4.2.3.RELEASE/reference/htmlsingle/# ns-web-xml, ale jest to założenie – David
Nie, nie dostaję żadnego błędu ani nie zadzwonię do osiągnięcia CustomPermissionEvaluator. –
Czy jesteś pewien, że odwołujesz się do komponentu bean poprawnie? 'class =" main.java.com.config.CustomPermissionEvaluator "' - czy nie powinno to być bez 'main.java'? – aturkovic