API 端点的命名约定

问题描述

我有这个实体。

@Entity
public class Dealer{
    @EmbeddedId
    private DealerIdKey idKey;
   
    @NotNull
    
    private LocalDate date;
}
@Embeddable
@Data
public class DealerIdKey implements Serializable {

    private static final long serialVersionUID = 1L;
    @NotNull
    @Size(max = 6)
    private String code;
    @NotNull
    @Size(max = 4)
    private String des;
}

我想在控制器中创建一个删除映射

@Autowired
private DealerRepository repo;
@DeleteMapping("/dealer/{id}")
    @ResponseBody
    public void delete(@NotNull @PathVariable(name = "id",required = true) DealerIdKey id) {
        repo.deleteById(id);
    }

控制器的终点应该是什么? 还是我写的方法是正确的?

解决方法

由于您的端点操作(HTTP 操作)属于 DELETE 类型,因此您已经向端点声明了您的意图。所以你写端点的方式在我看来(和一般惯例)是正确的。

但是,如果您已经有一个约定,请使用您的项目中已经使用的任何约定。一致性是关键。

如果它是一个干净的石板,不要在端点中添加 CRUD 函数名称。

如果您想要更深入的答案,我会通读 this 资源。但主要的收获是在项目中保持一致。因此,如果您选择该约定,请坚持下去。