IdentifiantMot de passe
Loading...
Mot de passe oubli� ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les r�ponses en temps r�el, voter pour les messages, poser vos propres questions et recevoir la newsletter

Spring Java Discussion :

[Upgrade spring boot 3] Apr�s suivi guide migration : 401 sur mes url


Sujet :

Spring Java

  1. #1
    Membre confirm�
    �tudiant
    Inscrit en
    Avril 2009
    Messages
    171
    D�tails du profil
    Informations professionnelles :
    Activit� : �tudiant

    Informations forums :
    Inscription : Avril 2009
    Messages : 171
    Par d�faut [Upgrade spring boot 3] Apr�s suivi guide migration : 401 sur mes url
    Bonjour,

    J'avais une appli spring boot 2.7.6 avec spring security 5.7.5 qui tournait sans probl�me : l'authentification fonctionne, je navigue dans les diff�rentes pages en fonction des r�les, swagger ui est utilisable, etc.
    Je n'ai pas de warning de d�precaded pour info
    J'ai fait la migration vers spring boot 3.0.0 et donc spring security 6.0.0. J'ai suivi les guides de migration et le serveur d�marre sans erreur. Mais mes URL ne fonctionnent plus : 401

    Probl�me n� 1 : GET http://localhost:8080/swagger-ui/index.html entraine un 401
    Dans les logs j'ai un
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    DEBUG org.springframework.web.servlet.DispatcherServlet  : Completed 404 NOT_FOUND
    Probl�me n� 2 : Je ne peux plus m'authentifier
    L'authentification se fait en 2 temps
    1. POST http://localhost:8080/api/v1/auth/login ==> 200
    2. GET http://localhost:8080/api/v1/auth/me ==> 401

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
     
    @RestController
    @RequestMapping(path = "/api/v1/auth", produces = MediaType.APPLICATION_JSON_VALUE)
    public class AuthenticationController {
     
      ...
     
      @PostMapping("/login")
      public ResponseEntity<UserDto> login(@NotNull @Valid @RequestBody LoginDto loginDto) {
        final Authentication authentication = this.authenticationManager.authenticate(new UsernamePasswordAuthenticationToken(loginDto.getLogin(), loginDto.getPassword()));
        SecurityContextHolder.getContext().setAuthentication(authentication);
        return ResponseEntity.ok(this.userDtoMapper.modelToDto((UserEntity) authentication.getPrincipal()));
      }
     
      @GetMapping("/me")
      public ResponseEntity<UserDto> getAuthenticatedUser() throws NotFoundException {
        final Authentication authentication = SecurityContextHolder.getContext().getAuthentication();
        if (null == authentication || !authentication.isAuthenticated() || !(authentication.getPrincipal() instanceof UserEntity)) {
          throw new SessionAuthenticationException("UNAUTHORIZED");
        }
        return ResponseEntity.ok(this.userDtoMapper.modelToDto(this.userService.findById(((UserEntity) authentication.getPrincipal()).getId())));
      }
    pom.xml + SecurityConfig + WebMvcConfig
    pom.xml :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
     
            ...
    	<parent>
    		<groupId>org.springframework.boot</groupId>
    		<artifactId>spring-boot-starter-parent</artifactId>
    		<version>3.0.0</version>
    		<relativePath /> <!-- lookup parent from repository -->
    	</parent>
    	...
    	<properties>
    		<java.version>17</java.version>
    		<jjwt.version>0.11.5</jjwt.version>
    		<springdoc.version>1.6.0</springdoc.version>
    		<docx4j.version>11.3.2</docx4j.version>
    	</properties>
    	<dependencies>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-data-jpa</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-mail</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-security</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.session</groupId>
    			<artifactId>spring-session-core</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-thymeleaf</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-validation</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-web</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.liquibase</groupId>
    			<artifactId>liquibase-core</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.apache.commons</groupId>
    			<artifactId>commons-collections4</artifactId>
    			<version>4.4</version>
    		</dependency>
    		<dependency>
    			<groupId>org.apache.commons</groupId>
    			<artifactId>commons-lang3</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-devtools</artifactId>
    			<scope>runtime</scope>
    			<optional>true</optional>
    		</dependency>
    		<dependency>
    			<groupId>com.h2database</groupId>
    			<artifactId>h2</artifactId>
    			<scope>runtime</scope>
    		</dependency>
    		<dependency>
    			<groupId>org.postgresql</groupId>
    			<artifactId>postgresql</artifactId>
    			<scope>runtime</scope>
    		</dependency>
    		<dependency>
    			<groupId>org.projectlombok</groupId>
    			<artifactId>lombok</artifactId>
    			<optional>true</optional>
    		</dependency>
    		<dependency>
    			<groupId>io.jsonwebtoken</groupId>
    			<artifactId>jjwt-api</artifactId>
    			<version>${jjwt.version}</version>
    		</dependency>
    		<dependency>
    			<groupId>io.jsonwebtoken</groupId>
    			<artifactId>jjwt-impl</artifactId>
    			<version>${jjwt.version}</version>
    			<scope>runtime</scope>
    		</dependency>
    		<dependency>
    			<groupId>io.jsonwebtoken</groupId>
    			<artifactId>jjwt-jackson</artifactId>
    			<version>${jjwt.version}</version>
    			<scope>runtime</scope>
    		</dependency>
    		<dependency>
    			<groupId>org.springdoc</groupId>
    			<artifactId>springdoc-openapi-ui</artifactId>
    			<version>${springdoc.version}</version>
    		</dependency>
    		 <dependency>
    			<groupId>org.springdoc</groupId>
    			<artifactId>springdoc-openapi-security</artifactId>
    			<version>${springdoc.version}</version>
    		</dependency>
     
    		<dependency>
    			<groupId>org.docx4j</groupId>
    			<artifactId>docx4j-export-fo</artifactId>
    			<version>${docx4j.version}</version>
    		</dependency>
    		<dependency>
    			<groupId>org.docx4j</groupId>
    			<artifactId>docx4j-JAXB-ReferenceImpl</artifactId>
    			<version>${docx4j.version}</version>
    		</dependency>
    		<dependency>
    			<groupId>jakarta.xml.bind</groupId>
    			<artifactId>jakarta.xml.bind-api</artifactId>
    			<version>3.0.1</version>
    		</dependency>
    		<dependency>
    			<groupId>jakarta.xml.bind</groupId>
    			<artifactId>jakarta.xml.bind-api-parent</artifactId>
    			<version>3.0.1</version>
    			<type>pom</type>
    		</dependency>
     
    	</dependencies>
     
    ...
    </project>
    SecurityConfig :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
     
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.http.HttpStatus;
    import org.springframework.security.authentication.AuthenticationManager;
    import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
    import org.springframework.security.config.annotation.authentication.configuration.AuthenticationConfiguration;
    import org.springframework.security.config.annotation.method.configuration.EnableMethodSecurity;
    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.WebSecurityCustomizer;
    import org.springframework.security.core.userdetails.UserDetailsService;
    import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
    import org.springframework.security.crypto.password.PasswordEncoder;
    import org.springframework.security.web.SecurityFilterChain;
    import org.springframework.security.web.authentication.HttpStatusEntryPoint;
    import org.springframework.security.web.context.RequestAttributeSecurityContextRepository;
    import org.springframework.security.web.savedrequest.HttpSessionRequestCache;
     
    @Configuration
    @EnableWebSecurity
    @EnableMethodSecurity(securedEnabled = true, jsr250Enabled = true)
    public class SecurityConfig {
     
      @Autowired
      UserDetailsService userDetailsService;
     
      @Autowired
      public void configureGlobal(AuthenticationManagerBuilder authenticationManagerBuilder) throws Exception {
        authenticationManagerBuilder.getDefaultUserDetailsService();
      }
     
      // @Override
      // public void configure(AuthenticationManagerBuilder authenticationManagerBuilder) throws Exception {
      // authenticationManagerBuilder.userDetailsService(this.userDetailsService)
      // .passwordEncoder(passwordEncoder());
      // }
     
      @Bean
      public AuthenticationManager authenticationManager(AuthenticationConfiguration authenticationConfiguration) throws Exception {
        return authenticationConfiguration.getAuthenticationManager();
      }
     
      @Bean
      public PasswordEncoder passwordEncoder() {
        return new BCryptPasswordEncoder();
      }
     
      @Bean
      SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
        // @formatter:off
        http.headers().frameOptions().disable().and()
        .cors().and()
        .csrf().disable()
        .exceptionHandling().authenticationEntryPoint(new HttpStatusEntryPoint(HttpStatus.UNAUTHORIZED)).and()
        .formLogin().disable()
        .authorizeHttpRequests(authz -> authz.requestMatchers("/api/*/auth/**").permitAll()
                                              .requestMatchers("/api/*/public/**").permitAll()
                                              .requestMatchers("/api/*/catalogs/*/documents/*/file").permitAll()
                                              .requestMatchers(req -> req.getRequestURI()
                                                .contains("swagger-ui")).permitAll()
                                              .anyRequest().authenticated());
        // @formatter:on
     
        return http.build();
      }
     
      @Bean
      public WebSecurityCustomizer webSecurityCustomizer() {
        return (web) -> web.ignoring()
          .requestMatchers(req -> req.getRequestURI()
            .contains("mail-images"))
          .requestMatchers(req -> req.getRequestURI()
            .contains("api-docs"))
          // .requestMatchers(req -> req.getRequestURI()
          // .contains("swagger-ui"))
          .requestMatchers(req -> req.getRequestURI()
            .contains("h2-console"));
      }
    }
    WebMvcConfig :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
     
    import java.util.List;
     
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.http.HttpMethod;
    import org.springframework.web.servlet.config.annotation.CorsRegistry;
    import org.springframework.web.servlet.config.annotation.EnableWebMvc;
    import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
     
    @Configuration
    @EnableWebMvc
    public class WebMvcConfig implements WebMvcConfigurer {
     
      @Value("#{'${cors.allowedOrigins}'.split(',')}")
      private List<String> allowedOrigins;
     
      @Override
      public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
          .allowCredentials(true)
          .allowedHeaders("*")
          .allowedOriginPatterns("http://*", "https://*")
          .allowedOrigins(this.allowedOrigins.toArray(String[]::new))
          .allowedMethods(HttpMethod.GET.name(), HttpMethod.POST.name(), HttpMethod.PUT.name(), HttpMethod.PATCH.name(), HttpMethod.DELETE.name(), HttpMethod.OPTIONS.name());
      }
     
      private static final String[] CLASSPATH_RESOURCE_LOCATIONS = {"classpath:/static/"};
     
      @Override
      public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/**")
          .addResourceLocations(CLASSPATH_RESOURCE_LOCATIONS);
      }
     
    }
    Auriez vous une piste de recherche parce que je s�che apr�s plusieurs tentatives ?

  2. #2
    Membre tr�s actif

    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    486
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 486
    Billets dans le blog
    5
    Par d�faut
    J'ai fait un update de Spring il n'y a pas longtemps.

    Je l'ai fait par �tape, et avec v�rifications de tests qui passent. J'y ai pass� 4H.

    Mais la premi�re fois, j'ai essuy� un �chec (j'y suis arriv� la seconde fois).

    Pour commenc�, pourquoi j'ai vite chang� la version de Spring (de la 5.?.? � la 6.?.?)?

    A cause d'Oracle.

    Oracle a pass� JEE � la fondation Eclipse. Si ils n'en veulent plus, pourquoi pas.

    Sauf qu'oracle a d�cid� de faire chier son monde (comme d'habitude) en insistant que les packages ne devaient pas commencer par javax.

    Donc tous les packages ont �t� renomm�s en javax.

    On pourrait dire que l'on s'en fout vu que personne n'utilise les EJB et CDI (ce que je faisait au d�but).

    Sauf qu'il y a aussi JPA (traduction Hibernate) et les Servlet. L�, on s'en fout moins.

    Pour y arriver (par �tape, je pr�cise, v�rifiant les TU aux fur et � mesure), et que �a marche, j'ai monter 3 versions de Spring:
    • Spring Core
    • Spring Boot
    • Spring Security


    Effectivement, ces 3 Spring sont ind�pendants.
    Je l'ai fait pour mon projet:
    https://bitbucket.org/philippegibaul...r40k/src/main/

    Il fonctionne et les TU passent, le client lourd fonctionne. Les versions (Spring, Spring Boot, Hibernate) sont les bonnes.

    Les derniers commits sont ici:
    https://bitbucket.org/philippegibaul...9702c16c2814f4

  3. #3
    Membre confirm�
    �tudiant
    Inscrit en
    Avril 2009
    Messages
    171
    D�tails du profil
    Informations professionnelles :
    Activit� : �tudiant

    Informations forums :
    Inscription : Avril 2009
    Messages : 171
    Par d�faut
    J'ai trouv� la solution au probl�me 1 : swagger innaccessible.
    Avec spring boot 3 il faut utiliser la d�pendance springdoc-openapi-starter-webmvc-ui

    springdoc-openapi-ui et springdoc-openapi-security ne sont pas des d�pendances faites pour spring boot 3

Discussions similaires

  1. Probl�me apr�s la reponse d'un post spring boot
    Par dibax10 dans le forum Spring
    R�ponses: 11
    Dernier message: 12/11/2021, 16h20
  2. Migration de spring vers Spring boot
    Par eloibru dans le forum Spring Boot
    R�ponses: 0
    Dernier message: 22/01/2021, 12h13
  3. R�ponses: 0
    Dernier message: 01/01/2021, 09h59
  4. R�ponses: 1
    Dernier message: 18/07/2006, 11h58
  5. Réinstaller le boot loader après réinstall de Windows
    Par roger12 dans le forum Administration syst�me
    R�ponses: 1
    Dernier message: 28/10/2005, 11h55

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo