Versioning RESTful services?

前端 未结 4 1960
旧时难觅i
旧时难觅i 2021-02-04 11:22

I have a RESTful web service deployed at http://example.com/v1/SomeResource. One day, a new protocol version (that is not backwards compatible) is deployed to h

相关标签:
4条回答
  • 2021-02-04 12:01

    I would recomend instead the use of the 301 (301 Moved Permanently). Read why.

    Hope it helps, Bruno Figueiredo

    0 讨论(0)
  • 2021-02-04 12:09

    I think you shouldn't do this in the first place, but probably it's too late.

    URIs should also be static so that when the resource changes or the implementation of the service changes, the link stays the same. This allows bookmarking. It's also important that the relationship between resources that's encoded in the URIs remains independent of the way the relationships are represented where they are stored.

    From the article RESTful Web services: The basics.

    0 讨论(0)
  • 2021-02-04 12:17

    I recommend the following article by Peter Williams

    • Versioning REST Web Services
    0 讨论(0)
  • 2021-02-04 12:27

    Best practice:

    It's probably better to keep the versioning out of the URL and to make the new resources backwards compatible with the old.

    Backwards compatible:

    If you must keep the v1 in the URL, and are making v2 URLs, then you have to decide whether you want to support both formats, or make the old v1 obsolete. If you decide on making the old v1 obsolete then I would recommend to return 303 or 401 for anyone requesting a v1 URL.

    Making old URLs obsolete:

    I would recommend using 303 See Other. Or if there is no associated redirect, then use 410 Gone.

    Source

    303 See Other

    The response to the request can be found under a different URI and SHOULD be retrieved using a GET method on that resource. This method exists primarily to allow the output of a POST-activated script to redirect the user agent to a selected resource. The new URI is not a substitute reference for the originally requested resource. The 303 response MUST NOT be cached, but the response to the second (redirected) request might be cacheable.

    The different URI SHOULD be given by the Location field in the response. Unless the request method was HEAD, the entity of the response SHOULD contain a short hypertext note with a hyperlink to the new URI(s).

    Note: Many pre-HTTP/1.1 user agents do not understand the 303 status. When interoperability with such clients is a concern, the 302 status code may be used instead, since most user agents react to a 302 response as described here for 303.

    Document everything:

    The main thing to be concerned about is whatever you chose to return, just document it in your documentation. You can decide how you want your service to work, others that want to consume it will follow the documentation.

    0 讨论(0)
提交回复
热议问题