让我们考虑以下API。

/school/{schoolId or schoolName}
/school/{schoolId or schoolName}/students/{studentId or studentName}


我必须开发上述API。在春季REST中实现此目标的最佳方法是什么?我可以简单地将URL路径变量获取为字符串,并检查它是id还是名称,然后对其进行处理。

但是,还有其他更好的解决方案吗?

最佳答案

房间里有一头大象,学校名称或学生姓名不是唯一的。因此,建议不要使用它代替id,否则会烫手。


  
  / school / {schoolId或schoolName}
  


我将其分为两个终点

1. / schools / {schoolId}

如果找到,返回学校实体

HTTP-200
{
  "id" : "id-123",
  "name" : "worlds best school ever",
  "address" : "123 somestreet, some city, some state"
}


如果找不到,

HTTP 404 and an empty body


2. / schools?name =“世界上最好的学校”(其他可选内容,例如排序方式,分页等)

如果每个搜索条件至少找到一个实体

HTTP-200
[
    {
      "id" : "id-123",
      "name" : "worlds best school ever",
      "address" : "123 somestreet, some city, some state"
    }
]


如果没有根据搜索条件找到实体

HTTP-200
[]



  
  / school / {schoolId或schoolName} / students / {studentId或studentName}
  


这就引出一个问题,一个学生属于一个以上的学校,我不这么认为。在这种情况下,/ school / {schoolId或schoolName}是不必要/多余的信息。如果是这样,我将其更改为

1. / students / {studentId}

如果发现

HTTP-200
{
  "id" : "studentid-345",
  "name" : "Albert Einstein",
  "school_id" : "id-123"
}


如果找不到

HTTP 404 with empty body


2. / students?name =“ Albert Einstein”(其他可选内容,例如排序方式,分页等)

如果每个搜索条件至少找到一个实体

HTTP-200
[
    {
      "id" : "studentid-345",
      "name" : "Albert Einstein",
      "school_id" : "id-123"
    }
]


如果没有根据搜索条件找到实体

HTTP-200
[]

10-06 01:36