我有簡單的WebApp誰有兩個表Clothes
和Shoes
。
創建控制器的最佳做法是什麼,因爲它們都具有CRUD方法。
我有兩個控制器這樣的:實現相同功能的控制器的最佳實踐是什麼?
@Controller
@RequestMapping("/shoes")
@Component
public class ShoesController {
private ShoesService shoesService;
@Autowired
public void setShoesService(ShoesService shoesService) {
this.shoesService = shoesService;
}
public ShoesService getShoesService() {
return shoesService;
}
@RequestMapping(value = "/view/all", method = RequestMethod.GET)
public @ResponseBody
List<Shoes> getAllShoes(){
return shoesService.getAllShoes();
}
@RequestMapping(value = "/byId/{id}", method = RequestMethod.GET)
public @ResponseBody
Shoes getShoesById(@PathVariable ("id") Integer id, Shoes shoes){
//TODO remove hardcoded values
return shoesService.getShoesByID(id, shoes);
}
@RequestMapping(value = "/view/{columnName}={value}", method =
RequestMethod.GET)
public @ResponseBody
List<Shoes> getByColumnValue(@PathVariable ("columnName") String colunmName,
@PathVariable("value") String columnValue, Shoes shoes){
//TODO remove hardcoded values
return shoesService.getByColumnValue(colunmName, columnValue, shoes);
}
@RequestMapping(value = "/edit/id={id}", method = RequestMethod.GET)
public @ResponseBody
Shoes update(@PathVariable ("id") Integer id, Shoes shoes){
shoes = getShoesById(id, shoes);
shoes.setShoesSeason("SPRINGGG");
shoesService.updateShoes(shoes);
return shoes;
}
@RequestMapping(value = "/delete/{id}", method =RequestMethod.GET)
public @ResponseBody
List<Shoes> delete(@PathVariable ("id") Integer id, Shoes shoes){
shoes = getShoesById(id, shoes);
shoesService.delete(shoes, id);
return getAllShoes();
}
@RequestMapping(value = "/add", method = RequestMethod.GET)
public @ResponseBody
List<Shoes> add (Shoes shoes){
shoes = new Shoes(333666, "Blue", "Autumn", "Noski", "URL");
shoesService.add(shoes);
return shoesService.getAllShoes();
}
}
Clothes
控制器具有相同的實現。
具有相同功能的實現控制器的最佳實踐是什麼?
爲什麼沒有抽象控制器... –
你不需要控制器上的'@ Component'。 '@ Controller'是一個更具體的版本,使你的'@ Component'變得冗餘 – zero01alpha