Я хочу сначала увидеть страницу входа, даже если любой пользователь хочет получить доступ к любой другой странице, которую нужно перенаправить на страницу входа в весеннюю безопасность - PullRequest
1 голос
/ 08 мая 2020

Вот пример контроллера. Моя проблема в основном заключается в том, что когда я ввожу базовый URL-адрес, он перенаправляется на внутреннюю страницу, а не на страницу входа. Что я хочу. Что мне делать для этого.

Вот пример контроллера. Моя проблема в основном заключается в том, что когда я ввожу базовый URL-адрес, он перенаправляется на внутреннюю страницу, а не на страницу входа. Что я хочу. Что мне нужно сделать для этого.

package com.sushovan.security.controller;

import javax.validation.groups.ConvertGroup;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class HomeController {

    @RequestMapping("/")
    public String home() {
        return "home.jsp";
    }

    @RequestMapping("/login")
    public String loginPage() {
        return "login.jsp";
    }

    @RequestMapping("/logout-success")
    public String logoutPage() {
        return "logout.jsp";
    }
}

Вот пример класса конфигурации безопасности. В основном все настройки были выполнены здесь.

package com.sushovan.security.config;

import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.authentication.AuthenticationProvider;
import org.springframework.security.authentication.dao.DaoAuthenticationProvider;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.core.userdetails.User;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.NoOpPasswordEncoder;
import org.springframework.security.provisioning.InMemoryUserDetailsManager;
import org.springframework.security.web.util.matcher.AntPathRequestMatcher;
import org.springframework.util.AntPathMatcher;

@Configuration
@EnableWebSecurity
public class AppSecurityConfig extends WebSecurityConfigurerAdapter {

    @Autowired
    private UserDetailsService userDetailsService;
    /**This is for authentication from database**/
    @Bean
    public AuthenticationProvider authProvider() {
        DaoAuthenticationProvider provider = new DaoAuthenticationProvider();

        provider.setUserDetailsService(userDetailsService);
        //provider.setPasswordEncoder(NoOpPasswordEncoder.getInstance());//This is for not use any encryption
        provider.setPasswordEncoder(new BCryptPasswordEncoder());//This is for BCryptPasswordEncoder
        return provider;
    }
    @Override
    protected void configure(HttpSecurity http) throws Exception {

        http.csrf().disable();
        http.authorizeRequests().antMatchers("/login")
            .permitAll()
            .and()
            .formLogin()
            .loginPage("/login")
            .usernameParameter("userName").passwordParameter("password")
            .permitAll()
            .and()
            .logout().invalidateHttpSession(true)
            .clearAuthentication(true)
            .logoutRequestMatcher(new AntPathRequestMatcher("/logout"))
            .logoutSuccessUrl("/logout-success").permitAll();

    }
}

1 Ответ

1 голос
/ 08 мая 2020

Алгоритм фильтров безопасности Spring работает следующим образом; защищен ли веб-ресурс? аутентифицирован пользователь? авторизован ли пользователь?

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

Итак, вам следует обновить свой метод настройки

    @Override
    protected void configure(HttpSecurity http) throws Exception {

        http.csrf().disable();
        http.authorizeRequests()
            .anyRequest().authenticated()
            .and()
            .formLogin()
            .loginPage("/login")
            .usernameParameter("userName").passwordParameter("password")
            .permitAll()
            .and()
            .logout().invalidateHttpSession(true)
            .clearAuthentication(true)
            .logoutRequestMatcher(new AntPathRequestMatcher("/logout"))
            .logoutSuccessUrl("/logout-success").permitAll();

    }

Можете ли вы попробовать это и сообщить мне, работает ли это?

...