REST Web Services API Design

后端 未结 5 1482
轻奢々
轻奢々 2021-02-01 23:13

Just wanted to get feedback on how I am planning to architect my API. Dummy methods below. Here\'s the structure:

GET http://api.domain.com/1/users/ <-- retur         


        
5条回答
  •  孤街浪徒
    2021-02-01 23:45

    Before you dig into REST, here are some terms you really need to grasp:

    Resource - The things/data you want to make available in your API (in your case a "User")

    URI - A universally unique ID for a resource. Should mention nothing about the method being performed (e.g. shouldn't contain "add" or "delete"). The structure of your URI however doesn't make your app any more or less RESTful - this is a common misconception.

    Uniform Interface - A fixed set of operations you can perform on your resources, in most cases this is HTTP. There are clear definitions for the purpose of each of these HTTP methods.

    The most unrestful thing about your URIs as they are right now is that they have information about the operation being performed right in them. URIs are IDs and nothing more!

    Let's take a real world example. My name is Nathan. "Nathan" could be considered my ID (or in restful terms URI – for the purpose of this example assume I'm the only "Nathan"). My name/ID doesn't changed based on how you would like to interact with me, e.g. My name wouldn't change to "NathanSayHello" when you wanted to greet me.

    It's the same for REST. Your user identified by http://api.domain.com/users/1 doesn't change to http://api.domain.com/users/1/update.xml when you want to update that user. The fact that you want to update that user is implied by the method you're using (e.g. PUT).

    Here is my suggestion for your URIs

    # Retrieve info about a user 
    GET http://api.domain.com/user/
    
    # Retrieve set all users
    GET http://api.domain.com/users
    
    # Update the user IDed by api.domain.com/user/
    PUT http://api.domain.com/user/
    
    # Create a new user.  The details (even ) are based as the body of the request
    POST http://api.domain.com/users
    
    # Delete the user ID'd by api.domain.com/user/
    DELETE http://api.domain.com/user/
    

    As for your questions:

    1. Use PUT and DELETE when appropriate and avoid overloading POST to handle these functions as it breaks HTTP's definition of POST. HTTP is your uniform interface. It is your contract with the API user about how they can expect to interact with your service. If you break HTTP, you break this contract.

    2. Remove "add" altogether. Use HTTP's Content-Type header for specifying the mime-type of posted data.

    3. Are you referring to the version of your API or the version of the resource? ETag and other response headers can be used to version the resources.

    4. Many options here. Basic HTTP Auth (easy but insecure), Digest Auth, custom auth like AWS. OAuth is also a possibility. If security is of main importance, I use client side SSL certs.

提交回复
热议问题