微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

API 端点的命名约定

如何解决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 资源。但主要的收获是在项目中保持一致。因此,如果您选择该约定,请坚持下去。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。