This commit is contained in:
mepiphana2023
2024-04-23 15:48:44 +02:00
10 changed files with 95 additions and 37 deletions

View File

@@ -16,6 +16,7 @@ repositories {
} }
dependencies { dependencies {
implementation 'org.springframework.boot:spring-boot-starter-thymeleaf' implementation 'org.springframework.boot:spring-boot-starter-thymeleaf'
developmentOnly 'org.springframework.boot:spring-boot-devtools' developmentOnly 'org.springframework.boot:spring-boot-devtools'
testImplementation 'org.springframework.boot:spring-boot-starter-test' testImplementation 'org.springframework.boot:spring-boot-starter-test'

View File

@@ -48,9 +48,4 @@ public class AccueilController {
return viewAccueil(searchTitle, searchCategory, model); return viewAccueil(searchTitle, searchCategory, model);
} }
@GetMapping("/login")
public String login(Model modele) {
return "login";
}
} }

View File

@@ -0,0 +1,40 @@
package fr.eni.enchere.controllers;
import fr.eni.enchere.bll.UserService;
import fr.eni.enchere.bo.UserProfil;
import fr.eni.enchere.dal.UserRepository;
import jakarta.servlet.http.HttpSession;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
@Controller
public class LoginController {
@Autowired
private UserService userService;
public LoginController(UserService userService) {
super();
this.userService = userService;
}
@GetMapping("/login")
public String login(Model modele) {
return "security/login";
}
@PostMapping("/login")
public String login(@RequestParam("username") String username, @RequestParam("password") String password, HttpSession session) {
UserProfil user = userService.utilisateurByName(username);
System.out.println("test");
if (user != null && user.getPassword().equals(password)) {
return "redirect:/accueil";
} else {
return "redirect:/security/login?error";
}
}
}

View File

@@ -0,0 +1,12 @@
package fr.eni.enchere.controllers;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class MvcConfig implements WebMvcConfigurer {
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/login").setViewName("security/login");
}
}

View File

@@ -27,11 +27,11 @@ public class ProfileController {
// Obtenez l'authentification actuelle // Obtenez l'authentification actuelle
Authentication authentication = SecurityContextHolder.getContext().getAuthentication(); Authentication authentication = SecurityContextHolder.getContext().getAuthentication();
// Vérifiez si l'utilisateur est authentifié // Vérifiez si l'utilisateur est authentifié
if (!authentication.getName().equals("anonymousUser") || true) { //Retirer le true pour le bon fonctionnement if (!authentication.getName().equals("anonymousUser")) { //Retirer le true pour le bon fonctionnement
// Obtenez les détails de l'utilisateur authentifié // Obtenez les détails de l'utilisateur authentifié
String username = authentication.getName(); String username = authentication.getName();
// Utilisez le service approprié pour récupérer les informations de l'utilisateur à partir du nom d'utilisateur // Utilisez le service approprié pour récupérer les informations de l'utilisateur à partir du nom d'utilisateur
UserProfil userProfile = userService.utilisateurByName("Jojo"); UserProfil userProfile = userService.utilisateurByName(username);
// Ajoutez les informations du profil à l'objet Model pour les afficher dans la page HTML // Ajoutez les informations du profil à l'objet Model pour les afficher dans la page HTML
model.addAttribute("user", new UserProfil()); model.addAttribute("user", new UserProfil());
model.addAttribute("userProfile", userProfile); model.addAttribute("userProfile", userProfile);
@@ -47,7 +47,7 @@ public class ProfileController {
// Obtenez les détails de l'utilisateur authentifié // Obtenez les détails de l'utilisateur authentifié
String username = authentication.getName(); String username = authentication.getName();
// Utilisez le service approprié pour récupérer les informations de l'utilisateur à partir du nom d'utilisateur // Utilisez le service approprié pour récupérer les informations de l'utilisateur à partir du nom d'utilisateur
UserProfil userProfile = userService.utilisateurByName("Jojo"); UserProfil userProfile = userService.utilisateurByName(username);
System.out.println(userProfile.getId()); System.out.println(userProfile.getId());
//Supprimer le compte //Supprimer le compte
userService.deleteUtilisateur(userProfile.getId()); userService.deleteUtilisateur(userProfile.getId());

View File

@@ -2,13 +2,10 @@ package fr.eni.enchere.security;
import fr.eni.enchere.bo.UserProfil; import fr.eni.enchere.bo.UserProfil;
import fr.eni.enchere.dal.UserRepository; import fr.eni.enchere.dal.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.core.userdetails.User; import org.springframework.security.core.userdetails.User;
import org.springframework.security.core.userdetails.User.UserBuilder;
import org.springframework.security.core.userdetails.UserDetails; import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService; import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
@Component @Component
@@ -16,7 +13,6 @@ public class LoginService implements UserDetailsService {
private UserRepository userRep; private UserRepository userRep;
@Autowired
public LoginService(UserRepository userRep) { public LoginService(UserRepository userRep) {
this.userRep = userRep; this.userRep = userRep;
} }
@@ -24,20 +20,19 @@ public class LoginService implements UserDetailsService {
@Override @Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException { public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
// Charger l'utilisateur depuis la base de données // Charger l'utilisateur depuis la base de données
UserProfil utilisateur = userRep.findByUsername(username); UserProfil utilisateur = this.userRep.findByUsername(username);
UserDetails userDetails = null;
// Créer un nouvel objet UserBuilder // Créer un nouvel objet UserBuilder
UserBuilder userBuilder = User.builder() if (utilisateur != null) {
.username(utilisateur.getPseudo()) userDetails = User.builder()
.password(utilisateur.getPassword()); .username(utilisateur.getPseudo())
// Ajouter les rôles en fonction de isAdmin() .password(utilisateur.getPassword())
if(utilisateur.isAdmin()) { .roles(utilisateur.isAdmin() ? "ADMIN" : "MEMBRE")
userBuilder.roles("ADMIN", "MEMBRE"); .build();
} else { } else {
userBuilder.roles("MEMBRE"); throw new UsernameNotFoundException("Les identifiants sont incorrect !");
} }
return userDetails;
// Retourner l'utilisateur UserDetails construit
return userBuilder.build();
} }
} }

View File

@@ -8,9 +8,9 @@ import org.springframework.security.crypto.password.PasswordEncoder;
@Configuration @Configuration
public class SecurityConfig { public class SecurityConfig {
@Bean // @Bean
public PasswordEncoder passwordEncoder() { // public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder(); // return new BCryptPasswordEncoder();
} // }
} }

View File

@@ -4,27 +4,35 @@ import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity; 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.EnableWebSecurity;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.factory.PasswordEncoderFactories;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.web.SecurityFilterChain; import org.springframework.security.web.SecurityFilterChain;
import org.springframework.security.web.util.matcher.AntPathRequestMatcher; import org.springframework.security.web.util.matcher.AntPathRequestMatcher;
@Configuration @Configuration
@EnableWebSecurity @EnableWebSecurity
public class WebSecurityConfig { public class WebSecurityConfig{
@Bean @Bean
public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception { public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {
http.authorizeHttpRequests((requests) -> requests http.authorizeHttpRequests((requests) -> requests.requestMatchers("/", "/accueil").permitAll()
.requestMatchers("/", "/accueil").permitAll() .requestMatchers("/login").permitAll()
.requestMatchers("/accueil", "/login", "/inscription/**", "/searchArticle", "/profile/**").permitAll()
.requestMatchers("/css/**", "/images/**", "/assets/**", "/img/**", "/js/**").permitAll() .requestMatchers("/css/**", "/images/**", "/assets/**", "/img/**", "/js/**").permitAll()
.requestMatchers("/article/**").authenticated()
.requestMatchers("/admin").hasRole("ADMIN") .requestMatchers("/admin").hasRole("ADMIN")
.anyRequest().authenticated()) .anyRequest().authenticated())
.formLogin((form) -> form.loginPage("/login").defaultSuccessUrl("/", true)) .formLogin((form) -> form.loginPage("/login").defaultSuccessUrl("/", true))
.logout((logout) -> logout.clearAuthentication(true).invalidateHttpSession(true) .logout((logout) -> logout.clearAuthentication(true).invalidateHttpSession(true).deleteCookies("JSESSIONID").logoutSuccessUrl("/filmLogout")
.deleteCookies("JSESSIONID").logoutSuccessUrl("/logout")
.logoutRequestMatcher(new AntPathRequestMatcher("/logout")).permitAll()); .logoutRequestMatcher(new AntPathRequestMatcher("/logout")).permitAll());
return http.build(); return http.build();
} }
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
} }

View File

@@ -25,7 +25,7 @@
<a class="nav-link" href="#">Vendre un article</a> <a class="nav-link" href="#">Vendre un article</a>
</li> </li>
<li class="nav-item"> <li class="nav-item">
<a class="nav-link" href="#">Mon profile</a> <a class="nav-link" href="/profile">Mon profile</a>
</li> </li>
<li class="nav-item"> <li class="nav-item">
<a class="nav-link disabled" href="#" tabindex="-1" aria-disabled="true">Déconnection</a> <a class="nav-link disabled" href="#" tabindex="-1" aria-disabled="true">Déconnection</a>
@@ -88,6 +88,7 @@
© 2024 Copyright: © 2024 Copyright:
</div> </div>
</footer> </footer>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="js/bootstrap/bootstrap.min.js"></script> <script src="js/bootstrap/bootstrap.min.js"></script>
</body> </body>
</html> </html>

View File

@@ -8,8 +8,14 @@
<h2>Pour se Connecter :</h2> <h2>Pour se Connecter :</h2>
<br> <br>
<form th:action="@{/login}" method="post"> <form th:action="@{/login}" method="post">
<div><label>Identifiant: <input type="text" name="username"/> </label></div> <div>
<div><label>Mot de passe: <input type="password" name="password"/> </label></div> <label for="username">Identifiant: </label>
<input type="username" name="username" id="username"/>
</div>
<div>
<label for="password">Mot de passe:</label>
<input type="password" name="password" id="password"/>
</div>
<div><input type="checkbox" id="remember-me" name="remember-me"/><label for="remember-me"> Se souvenir de moi</label></div> <div><input type="checkbox" id="remember-me" name="remember-me"/><label for="remember-me"> Se souvenir de moi</label></div>
<div><a href="/mot-de-passe-oublie">Mot de passe oublié</a></div> <div><a href="/mot-de-passe-oublie">Mot de passe oublié</a></div>
<div><input type="submit" value="Connexion"/></div> <div><input type="submit" value="Connexion"/></div>