Spring Security: поставщик аутентификации базы данных - PullRequest
0 голосов
/ 07 декабря 2011

Невозможно заставить Spring Security работать с поставщиком аутентификации БД.
Провайдер аутентификации в памяти работает нормально.

Шаг для воспроизведения:
когда я вошел в систему с учетными данными sb, sb, login() метод AuthenticationService вернул false.
Нет связанных логинов Tomcat.

applicationContext.xml:

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost/chirokDB?useUnicode=true&amp;characterEncoding=utf8"/>
    <property name="username" value="root"/>
    <property name="password" value="root"/>
</bean>

<bean id="userDetailsService" class="org.springframework.security.core.userdetails.jdbc.JdbcDaoImpl">
        <property name="dataSource" ref="dataSource"/>
</bean>

уровень обслуживания:

@Service("authenticationService")
   public class AuthenticationServiceImpl implements AuthenticationService {
    @Resource(name = "authenticationManager")
    private AuthenticationManager authenticationManager;
        public boolean login(String username, String password) {
        try {
        Authentication authenticate = authenticationManager.authenticate(new UsernamePasswordAuthenticationToken(
                    username, password));
            if (authenticate.isAuthenticated()) {
    SecurityContextHolder.getContext().setAuthentication(authenticate);
                    return true;
                }
            } catch (AuthenticationException e) {
            }
            return false;
   }

уровень управляемого бина:

public String doLogin() {
    boolean isLoggedIn = authenticationService.login(name, password);
    if (isLoggedIn) {
        return "index";
    }
    FacesContext.getCurrentInstance().addMessage("login failure", new FacesMessage());
    return "failureLogin";
}

ApplicationContext-security.xml:

<global-method-security pre-post-annotations="enabled"/>  
    <http auto-config="true">
    <form-login login-page="/login.xhtml" default-target-url="/index.xhtml"/>
        <intercept-url pattern="/contacts.xhtml" access="ROLE_ANONYMOUS,ROLE_USER"/>
        <intercept-url pattern="/delivery.xhtml" access="ROLE_USER"/>
        <logout invalidate-session="true"/>
        <session-management>
            <concurrency-control max-sessions="1" error-if-maximum-exceeded="true"/>
        </session-management>   
    </http>          

    <authentication-manager alias="authenticationManager">
        <authentication-provider>
            <jdbc-user-service data-source-ref="dataSource"/>
        </authentication-provider>
    </authentication-manager>

уровень устойчивости:
MySql DB имеет следующие стандартные таблицы (требуется Spring):
1. пользователи
2. органы власти

users таблица содержит запись с именем пользователя = 'sb' и паролем = 'sb'
authorities таблица содержит запись с именем пользователя = 'sb' и полномочиями = 'ROLE_USER'

примечание
с пользовательской памятью все работает нормально со следующей конфигурацией:

    <authentication-manager alias="authenticationManager">
        <authentication-provider>
            <user-service>
                <user name="sb" password="sb" authorities="ROLE_USER"/>
            </user-service>
        </authentication-provider>
    </authentication-manager>

предположение:
dataSource введено в org.springframework.security.core.userdetails.jdbc.JdbcDaoImpl
Что касается Hibernate ORM, возможно, следует использовать что-то отличное от JdbcDaoImpl?

1 Ответ

1 голос
/ 07 декабря 2011

Проверьте, получаете ли вы Exception в своем пустом блоке catch (что всегда является плохой идеей).

...