RestFul API is the basic knowledge that every programmer should understand and master, and we should at least meet the most basic requirements of RestFul API when designing API in the development process (for example, try to use nouns in interface, use POST request to create resources, DELETE request to DELETE resources, etc.). Example: GET /notes/ ID: GET information about a note with a specified ID. Recently I came into contact with these things in the learning process, and I have no time to summarize, so I share some good articles for you.

Related reading: http://www.ruanyifeng.com/blog/2014/05/restful_api.html (nguyen piece, This article mostly content sources), https://www.baeldung.com/spring-hateoas-tutorial (RestFul API Tutorial), https://aisensiy.github.io/2017/06/04/spring-boot-and-hateoas/ (bases used in Spring) https://spring.io/guides/tutorials/bookmarks/ (Building REST services with Spring) https://www.baeldung.com/spring-hateoas-tutorial (https://www.baeldung.com/spring-hateoas-tutorial)Copy the code

Remark: HATEOAS may not be familiar to you before. I have read a lot of project source code and it does not meet the requirements of HATEOAS design. In fact, RestFul apis better meet the requirements of HATEOAS design, which is to provide links to other API methods in the return result, so that users do not check the document. And I know what to do next.

I. Important Concepts:

REST, an acronym for Representational State Transfer, translates as “Representational State transformation.”

  • Resource: A single instance of an object. For example, an animal. It can be a text, a picture, a song, a service, or a concrete reality. You can point to it with a URI (uniform resource Locator), and each resource has a specific URI. To get the resource, access its URI, which becomes the address or unique identifier for each resource.

  • Collection: A collection of objects. For example, animals.

  • Third party: developers who use our interface

  • Representation: Resources are information entities that can take a variety of representations. We call a resource’s Representation of a Representation its’ Representation ‘.

  • State Transfer visiting a website represents an interactive process between the client and the server. In this process, data and state changes are inevitably involved. Internet Communication protocol HTTP is a stateless protocol. This means that all state is kept on the server side. Therefore, if the client wants to operate the server, it must somehow make a State Transfer happen on the server side. And this transformation is built on top of the presentation layer, so it is “presentation layer state transformation”.

Putting this together, we can summarize what RESTful architecture is: (1) Each URI represents a resource; (2) between the client and the server, the transfer of some kind of representation layer of this resource; (3) The client operates on the server-side resources through HTTP verbs (GET,POST, etc.) to achieve “state transformation of the presentation layer”.

2. REST interface specifications

1, the action,

GET (SELECT) : Retrieves a specific resource, or a list of resources, from the server. POST (CREATE) : Creates a new resource on the server. PUT (UPDATE) : Updates the resource on the server (the client provides the updated entire resource). PATCH (UPDATE) : Updates resources on the server (the client provides the changed properties, which can be regarded as partial updates). DELETE (DELETE) : deletes resources from the server.Copy the code

2. Path (interface naming)

The path, also known as the endpoint, represents the specific URL of the API. In a RESTful architecture, each url represents a resource, so there can be no verbs in the url, only nouns, and the nouns usually correspond to the table names in the database. Generally speaking, tables in a database are “collections” of the same records, so nouns in apis should also be plural. For example, if there is an API that provides information about zoos, as well as information about various animals and employees, its path should look like this. Use nouns instead of verbs. Here are some examples.

GET /zoos: lists all zoos POST /zoos: creates a new zoo GET /zoos/ID: obtains information about a specified zoo PUT /zoos/ID: updates information about a specified zoo (provides all information about the zoo) PATCH /zoos/ID: DELETE /zoos/ID: deletes a zoo GET /zoos/ID/animals: lists all animals for a specified zoo DELETE /zoos/ID/animals/ID: Delete the specified animal replication code of a specified zoo ======== Example: ======== /getAllCars /createNewCar /deleteAllRedCars Replication codeCopy the code

Clarify the hierarchical structure of resources. For example, if the scope of business is school, then school will be the first-level resources (/school), teachers (/school/teachers), and students (/school/students) will be the second-level resources.

3. Versioning

You should put the VERSION number of the API in the URL. Such as: https://api.example.com/v1/ duplicate code

The alternative is to put the version number in the HTTP header, but it’s not as convenient and intuitive as putting it in the URL. Github takes this approach.

4. Information Filtering

If there are many records, the server cannot return them all to the user. The API should provide parameters that filter the return results. Here are some common parameters.

? limit=10: Specifies the number of records to return? offset=10: Specifies the starting position of the return record. ? page_number=2&page_size=100: Specifies the page number and the number of records per page. ? Sortby = name&ORDER = ASC: Specifies by which attribute the return results are sorted, and in what order. ? animal_type_id=1: The design of the specified filter parameters allows for redundancy, that is, occasional duplication of API path and URL parameters. For example, GET /zoo/ID/animals versus GET /animals? Zoo_id =ID has the same meanings.Copy the code

5. Status Codes

Status code range

1Xx message, request received, continue processing. The scope reserves things for the underlying HTTP that you will most likely never use.2Xx succeeds and the behavior is successfully accepted, understood and adopted3Xx redirect, the further action that must be performed in order to complete the request4Xx client error, request contains syntax error or request cannot be implemented. Scopes are reserved in response to errors made by clients, for example. They provide bad data or demand things that don't exist. These requests should be idempotent rather than changing the state of the server.5Status codes in the xx range are reserved for server-side errors. These errors are often thrown from the underlying functions and are often beyond the reach of even the developer. The purpose of sending such status codes is to ensure that the client gets some kind of response. When I received5When XX responds, the client cannot know the status of the server, so such status codes should be avoided as much as possible.Copy the code

The status code and prompt message returned by the server to the user are as follows (the corresponding HTTP verb is in square brackets).

200OK - [GET] : The server successfully returns the requested data, which is Idempotent.201CREATED - [POST/PUT/PATCH] : data is CREATED or modified successfully.202Accepted - [*] : indicates that a request has been queued in the background (asynchronous task)204NO CONTENT - [DELETE] : Indicates that data is deleted successfully.400INVALID REQUEST - [POST/PUT/PATCH] : An error occurs in the REQUEST sent by the user. The server does not create or modify data. The operation is idempotent.401Unauthorized - [*] : Indicates that the user does not have permissions (the token, user name, or password is incorrect).403Forbidden-[*] Indicates that the user is authorized (and401Error relative), but access is forbidden.404NOT FOUND - [*] : The user sent a request for a record that did NOT exist, the server did NOT do the operation, the operation is idempotent.406Not Acceptable - [GET] : The format requested by the user is Not available (for example, the user requested JSON format, but only XML format).410Gone -[GET] : Indicates that the requested resource is permanently deleted and cannot be retrieved.422Unprocesable Entity - [POST/PUT/PATCH] An authentication error occurred while creating an object.500INTERNAL SERVER ERROR - [*] : An ERROR occurs on the SERVER, and users cannot determine whether the request is successful.502Gateway error503 Service Unavailable
504Gateway timeoutCopy the code

Three, the bases for

These are the basics of RESTful apis, and the ones that are easiest to put into practice during normal development. In fact, RESTful apis are best for Hypermedia, providing links to other API methods in the results so that the user knows what to do next without looking up the documentation. For example, when a user makes a request to the root directory of api.example.com, they get a document like this.

{"link": {
  "rel":   "collection https://www.example.com/zoos",
  "href":  "https://api.example.com/zoos",
  "title": "List of zoos",
  "type":  "application/vnd.yourformat+json"
}}
Copy the code

The above code shows that the document has a link property that the user reads to know what API to call next. Rel represents the relationship between the API and the current url (and gives the url of the collection), href represents the path to the API, title represents the title of the API, and type represents the return type. The design of the Hypermedia API is called HATEOAS. There is an API library in Spring called HATEOAS that makes it easier to create apis that conform to HATEOAS designs.

Source: author: XXX links: https://mp.weixin.qq.com/s/NY9zmuZdTAxjXRPb81i1fQ WeChat public - Java program luca brasi's homeCopy the code