运用spring boot框架用@RestController@RequestBody@Autowired@PostMapping@Service@Mapper@Data注解和xml<select>语句用resultType数据库mysql实现用户登录案例
时间: 2024-02-13 19:33:38 浏览: 23
首先,我们需要创建一个Spring Boot项目,并添加相关依赖,包括Spring MVC、MyBatis、MySQL连接驱动等。
接下来,创建一个User实体类,使用@Data注解自动生成getter、setter和toString方法。
```java
@Data
public class User {
private Long id;
private String username;
private String password;
}
```
然后,创建一个Mapper接口和对应的XML文件,用于查询用户信息。
```java
@Mapper
public interface UserMapper {
@Select("SELECT * FROM user WHERE username = #{username}")
User getUserByUsername(String username);
}
```
```xml
<mapper namespace="com.example.demo.mapper.UserMapper">
<select id="getUserByUsername" resultType="com.example.demo.model.User">
SELECT * FROM user WHERE username = #{username}
</select>
</mapper>
```
接着,创建一个UserService,用于处理用户登录逻辑。
```java
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public User login(String username, String password) {
User user = userMapper.getUserByUsername(username);
if (user != null && user.getPassword().equals(password)) {
return user;
}
return null;
}
}
```
最后,创建一个Controller,用于接收用户登录请求,并调用UserService进行处理。
```java
@RestController
public class UserController {
@Autowired
private UserService userService;
@PostMapping("/login")
public User login(@RequestBody Map<String, String> request) {
String username = request.get("username");
String password = request.get("password");
return userService.login(username, password);
}
}
```
在MySQL中创建一个名为user的表,包含id、username和password字段,用于存储用户信息。
最后,启动应用程序,并使用Postman等工具发送POST请求到http://localhost:8080/login,请求体为JSON格式的数据:{"username": "admin", "password": "123456"},即可完成用户登录操作。