springboot+bootstrap实现登录注册
时间: 2023-09-19 13:08:03 浏览: 96
Spring Boot 和 Bootstrap 都是非常流行的技术,用于开发 Web 应用程序。下面是一个简单的示例,演示如何使用 Spring Boot 和 Bootstrap 实现用户登录和注册功能。
1. 创建一个 Spring Boot 项目,并添加 Web,Thymeleaf 和 Spring Security 依赖。
2. 在 src/main/resources 目录下创建 application.properties 文件,并配置数据库、端口、日志等信息。
3. 创建一个 User 实体类,用于映射用户信息到数据库。示例代码如下:
```
@Entity
@Table(name = "users")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String username;
private String password;
private String email;
// 省略 getter 和 setter 方法
}
```
4. 创建一个 UserRepository 接口,用于操作用户信息。示例代码如下:
```
@Repository
public interface UserRepository extends JpaRepository<User, Long> {
User findByUsername(String username);
}
```
5. 创建一个 UserService 接口和实现类,用于处理用户信息的业务逻辑。示例代码如下:
```
public interface UserService {
void save(User user);
User findByUsername(String username);
}
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserRepository userRepository;
@Override
public void save(User user) {
userRepository.save(user);
}
@Override
public User findByUsername(String username) {
return userRepository.findByUsername(username);
}
}
```
6. 创建一个 UserController 类,用于处理用户登录和注册的请求。示例代码如下:
```
@Controller
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/login")
public String login() {
return "login";
}
@GetMapping("/register")
public String register(Model model) {
model.addAttribute("user", new User());
return "register";
}
@PostMapping("/register")
public String register(@ModelAttribute("user") User user) {
userService.save(user);
return "redirect:/login";
}
}
```
7. 创建一个 login.html 文件和 register.html 文件,用于显示登录和注册页面。示例代码如下:
login.html
```
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Login</title>
<link rel="stylesheet" href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/4.6.0/css/bootstrap.min.css">
</head>
<body>
<div class="container">
<div class="row justify-content-center mt-5">
<div class="col-md-6">
<div class="card">
<div class="card-header">Login</div>
<div class="card-body">
<form th:action="@{/login}" method="post">
<div class="form-group">
<label for="username">Username:</label>
<input type="text" class="form-control" id="username" name="username" required>
</div>
<div class="form-group">
<label for="password">Password:</label>
<input type="password" class="form-control" id="password" name="password" required>
</div>
<button type="submit" class="btn btn-primary">Login</button>
</form>
</div>
</div>
</div>
</div>
</div>
</body>
</html>
```
register.html
```
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Register</title>
<link rel="stylesheet" href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/4.6.0/css/bootstrap.min.css">
</head>
<body>
<div class="container">
<div class="row justify-content-center mt-5">
<div class="col-md-6">
<div class="card">
<div class="card-header">Register</div>
<div class="card-body">
<form th:action="@{/register}" method="post" th:object="${user}">
<div class="form-group">
<label for="username">Username:</label>
<input type="text" class="form-control" id="username" name="username" th:field="*{username}" required>
</div>
<div class="form-group">
<label for="password">Password:</label>
<input type="password" class="form-control" id="password" name="password" th:field="*{password}" required>
</div>
<div class="form-group">
<label for="email">Email:</label>
<input type="email" class="form-control" id="email" name="email" th:field="*{email}" required>
</div>
<button type="submit" class="btn btn-primary">Register</button>
</form>
</div>
</div>
</div>
</div>
</div>
</body>
</html>
```
8. 启动应用程序,访问 http://localhost:8080/register,输入用户名、密码和电子邮件地址,点击注册按钮,即可将用户信息保存到数据库中。然后访问 http://localhost:8080/login,输入用户名和密码,点击登录按钮,即可登录成功。
上述示例代码仅供参考,实际开发过程中可能需要根据具体需求进行修改和优化。