由于代码实例涉及的内容较多,我们将提供实验室预约管理系统的核心功能:实验室查询和预约的接口定义。
// 实验室实体类
public class Lab {
private Long id;
private String name;
private String location;
// 省略其他属性、构造函数、getter和setter
}
// 预约实体类
public class Reservation {
private Long id;
private Lab lab;
private LocalDateTime startTime;
private LocalDateTime endTime;
private String description;
private String creator;
// 省略其他属性、构造函数、getter和setter
}
// 实验室服务接口
public interface LabService {
List<Lab> getAllLabs(); // 获取所有实验室信息
Lab getLabById(Long id); // 根据ID获取实验室详情
}
// 预约服务接口
public interface ReservationService {
List<Reservation> getAllReservations(); // 获取所有预约
Reservation createReservation(Reservation reservation); // 创建新的预约
void deleteReservation(Long id); // 删除预约
}
// 控制器类
@RestController
@RequestMapping("/api/labs")
public class LabController {
@Autowired
private LabService labService;
@GetMapping // 获取所有实验室
public ResponseEntity<List<Lab>> getAllLabs() {
return ResponseEntity.ok(labService.getAllLabs());
}
@GetMapping("/{id}") // 根据ID获取实验室详情
public ResponseEntity<Lab> getLabById(@PathVariable Long id) {
return ResponseEntity.ok(labService.getLabById(id));
}
}
@RestController
@RequestMapping("/api/reservations")
public class ReservationController {
@Autowired
private ReservationService reservationService;
@GetMapping // 获取所有预约
public ResponseEntity<List<Reservation>> getAllReservations() {
return ResponseEntity.ok(reservationService.getAllReservations());
}
@PostMapping // 创建新的预约
public ResponseEntity<Reservation> createReservation(@RequestBody Reservation reservation) {
return ResponseEntity.ok(reservationService.createReservation(reservation));
}
@DeleteMapping("/{id}") // 删除预约
public ResponseEntity<Void> deleteReservation(@PathVariable Long id) {
reservationService.deleteReservation(id);
return ResponseEntity.noContent().build();
}
}
在这个代码实例中,我们定义了实验室和预约的实体类,以及对应的服务接口。然后,我们创建了控制器类,提供了基本的HTTP请求处理方法,例如获取实验室列表、获取特定实验室详情、创建和删除预约等。这个简单的示例展示了如何使用SpringBoot框架和RestController来创建RESTful API,这对于开发实验室预约管理系统非常重要。