在SpringBoot项目中,前端请求到最终返回的完整数据流转一般包括以下几个步骤:
前端发送HTTP请求到后端Controller。
Controller接收到请求后,调用相关Service处理业务逻辑。
Service调用DAO层获取数据。
DAO层访问数据库获取数据。
数据库返回数据给DAO层。
DAO层将数据返回给Service层。
Service层将处理结果返回给Controller。
Controller将结果封装为HTTP响应,返回给前端。
下面我们通过一个简单的例子来演示完整的数据流转:
在前端页面上,我们发送一个GET请求到后端Controller,请求获取所有的用户数据:
$.ajax({
url: "/users",
type: "GET",
dataType: "json",
success: function(data) {
// 处理返回的数据
}
});
2.Controller接收到请求后,调用相关Service处理业务逻辑
在后端,我们定义一个UserController类来处理请求:
@RestController
@RequestMapping("/users")
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/")
public ResponseEntity> getAllUsers() {
List users = userService.getAllUsers();
return new ResponseEntity<>(users, HttpStatus.OK);
}
}
在该类中,我们使用@Autowired
注解注入了一个UserService
对象,并定义了一个@GetMapping
注解的方法来处理GET请求。该方法调用了UserService
对象的getAllUsers()
方法。
3.Service调用DAO层获取数据
在UserService类中,我们实现getAllUsers()方法:
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserDao userDao;
@Override
public List getAllUsers() {
return userDao.getAllUsers();
}
}
在该类中,我们使用@Autowired
注解注入了一个UserDao
对象,并实现了UserService
接口的getAllUsers()
方法。
4.DAO层访问数据库获取数据
在UserDao类中,我们使用JdbcTemplate访问数据库:
@Repository
public class UserDaoImpl implements UserDao {
@Autowired
private JdbcTemplate jdbcTemplate;
@Override
public List getAllUsers() {
String sql = "SELECT * FROM user";
List users = jdbcTemplate.query(sql, new UserMapper());
return users;
}
private static final class UserMapper implements RowMapper {
@Override
public User mapRow(ResultSet rs, int rowNum) throws SQLException {
User user = new User();
user.setId(rs.getLong("id"));
user.setUsername(rs.getString("username"));
user.setEmail(rs.getString("email"));
return user;
}
}
}
在该类中,我们使用@Autowired
注解注入了一个JdbcTemplate
对象,并实现了UserDao
接口的getAllUsers()
方法。该方法执行了一条查询SQL语句,将结果集映射为一个List
对象。
5.数据库返回数据给DAO层
JdbcTemplate会将查询结果封装为一个ResultSet
对象返回。
6.DAO层将数据返回给Service层
UserDao将ResultSet
对象映射为List
7.Service层将处理结果返回给Controller
UserService将List
8.Controller将结果封装为HTTP响应,返回给前端
UserController将List
[
{
"id": 1,
"username": "user1",
"email": "[email protected]"
},
{
"id": 2,
"username": "user2",
"email": "[email protected]"
}
]
通过上述步骤,我们成功实现了SpringBoot项目中前端请求到数据库再返回前端的完整数据流转。