1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Problema ao fazer login com spring security

galera, to com um problema pra fazer login com o spring. qdo eu mudo o link no navegador ele barra a entrada, mas qdo eu tento logar ele mostra q o usuario e a senha estao incorretos. ja rodei as querys 'authorities-by-username-query' e 'users-by-username-query' no mysql e me retornam exatamente oq eu preciso. se alguem souber oq ta errado vai me ajudar bastante. desde ja agradeço

applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>
<b:beans xmlns="http://www.springframework.org/schema/security"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:b="http://www.springframework.org/schema/beans"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
                             http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
                             http://www.springframework.org/schema/security
                            http://www.springframework.org/schema/security/spring-security-3.0.xsd">

    <http auto-config="true">
        <intercept-url pattern="/secretaria/**" access="ROLE_SECRETARIA"/>
        <intercept-url pattern="/professor/**" access="ROLE_PROFESSOR"/>
        <form-login login-page="/index.jsf" authentication-failure-url="/index.jsf?erro=true"/>
    </http>

    <authentication-manager>
        <authentication-provider>
            <jdbc-user-service data-source-ref="dataSource"
               authorities-by-username-query="SELECT pe.usuario, p.descricao FROM pessoa pe, permissao p 
WHERE pe.idPermissao = p.idPermissao and pe.usuario = ?"
               users-by-username-query="SELECT usuario, senha, bloqueado FROM pessoa WHERE usuario = ?"
            />
        </authentication-provider>
    </authentication-manager>

    <b:bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" >
        <b:property name="url" value="jdbc:mysql://localhost:3306/escola" />
        <b:property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <b:property name="username" value="***" />
        <b:property name="password" value="***" />
    </b:bean>

</b:beans>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>Escola</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>index.jsf</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
  <servlet>
    <servlet-name>Faces Servlet</servlet-name>
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Faces Servlet</servlet-name>
    <!-- <url-pattern>/faces/*</url-pattern> -->
    <url-pattern>*.jsf</url-pattern>
  </servlet-mapping>


      <!-- configuração para o filtro -->

    <!-- tema do primefaces -->
    <context-param>  
        <param-name>primefaces.THEME</param-name>  
        <param-value>start</param-value>  
    </context-param>

    <!-- Início das configurações para o Spring Security 3 -->
    <filter>
        <filter-name>springSecurityFilterChain</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <filter-mapping>
        <filter-name>springSecurityFilterChain</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    <!-- Fim das configuração para utilizar o Spring Security 3 -->


</web-app>

login.jsf

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:p="http://primefaces.org/ui">
    <h:head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
        <title>Sistema de Controle Acadêmico</title>
    </h:head>
    <h:body>
        <p:dialog header="Login" visible="true" closable="false" draggable="false" resizable="false" style="font-size: 12px;">
            <center>
                <h:outputText value="Usuário ou senha incorretos!" rendered="#{param.erro}" style="color: red"/>
            </center>
            <form action="j_spring_security_check" method="post">
                <h:panelGrid columns="2" cellpadding="5">
                    <h:outputLabel for="j_username" value="Usuario: *" /> 
                    <h:inputText id="j_username" required="true" style="font-size: 12px;"/>
                    <h:outputLabel for="j_password" value="Senha: * " />
                    <h:inputText id="j_password" required="true" style="font-size: 12px;"/>
                    <h:commandButton value="Login" style="font-size: 12px;"/>
                </h:panelGrid>
            </form>
        </p:dialog>
    </h:body>
</html>
  • Não escreva resolvido no título, no lugar, marque a resposta que te ajudou como correta.

    ViniGodoy   03 de mai de 2014
  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

2 respostas

Não é a resposta que estava procurando? Procure outras perguntas com as tags spring-security jsf ou faça a sua própria pergunta.