RESTful
2 minutes of reading
APIs that we refer to as RESTful meet certain criteria, such as using HTTP as the primary means of communication and having structure and resources that can be referenced via URLs.
RESTful means that the API in question is fully compatible with the REST standard. The REST software development standard refers in particular to websites. In order to claim that the API we wrote meets the REST standards, it must meet the following requirements in practice:
- Unique methods by which it queries the API such as GET, PUT, DELETE, PATCH defined as a unified interface.
- The given query is independent of the state of the application, it always returns the same thing, i.e. if we ask for a resource with ID=1 in the API then regardless of whether we are user A or B we should get the same thing
- The API returns messages about whether the query was successful or returned an error. The API should indicate exactly what the error was.
- The query to the API should explicitly state what type of resource it is querying, and for book querying we will use a different one
- The client does not directly interact with the server's resources in any way
- Ability to use cache. The API must return information whether the resource is stored and whether it can be stored
It is worth remembering that REST is not the same as HTTP, and also REST does not impose in any way the type of data that is returned from the API. It can be either JSON or plain text.
What a REST query to the API looks like
Each API query should have the following elements:
- Endpoint name
- Type of method
- Headers
- Data
An example query of type GET would be
curl -H "Authorization: OAuth <ACCESS_TOKEN>" http://www.example.com/users/2
Practical RESTful tips
There are a lot of generalities about RESTful APIs, but it's hard to find good resources on what to do to actually make our APIs meet REST standards.
URL construction in a RESTful API
One of the most important things is the construction of the URL. The url should have:
- use only lowercase letters
- use a hyphen ( - ) instead of an underline ( _ )
- do not add the return data type to our url, instead you should use Content-Type in the header
- use plural in the name for collection names, e.g. /books/
- use singular for document names, e.g. /books/sciencefiction/
- do not use create, delete methods in the name e.g. it is a mistake to make /deletebook/
- we can version and should add the main api version to the name e.g. /v1/books/
Returned response codes
The API should return response codes. The standard is responses containing error codes numbered from 2xx, 3xx, 4xx, 5xx. All but responses in the 200 group mean that there is an error in our API.
Our offer
Web development
Find out moreMobile development
Find out moreE-commerce
Find out moreUX/UI Design
Find out moreOutsourcing
Find out moreRelated articles
Mastering UX writing: A comprehensive guide to enhancing usability
29 Aug 2024
UX writing is the practice of crafting micro-copy that guides a user within digital products. A critical aspect of usability, it helps users understand how to interact with an interface. In this article, we'll unpack UX writing and strategies on mastering it, positioning you to elevate user experience through simple, precise, and engaging copy.
Understanding the concepts of Domain-Driven Design (DDD)
29 Aug 2024
Domain-Driven Design (DDD) is a powerful strategy for building effective, complex software systems. Conceptualizing abstract domain models often poses challenges. This comprehensive guide serves to decipher the intricacies of DDD, delivering a practical roadmap for software developers and architects.
How to design for accessibility: Tips and techniques
29 Aug 2024
In today's digital world, inclusivity and accessibility are critical to creating user-friendly applications. This article will guide you through key principles and practices of Accessibility Design, enabling you to craft more inclusive digital experiences. It aims to aid both seasoned developers and beginners in understanding the significance of these principles in shaping the digital ecosystem.
Understanding the microservices architecture: Pros and cons
26 Aug 2024
Unraveling the world of Microservices Architecture - a prevalent system design trend, this piece discusses its unique benefits and impediments. By dissecting this modern technology, we aim to provide you with insight that can guide choices about your tech stack, illuminating both the sunlit uplands of its advantages and the shadowed landscapes of its pitfalls.
How to use storyboarding in UX design
22 Aug 2024
Storyboarding is a powerful tool in UX design that helps visualize the user journey and identify potential pain points early in the process. By creating a visual narrative, designers can better understand and communicate how users will interact with a product or service.
Strengthening the defenses: The role of artificial intelligence in cybersecurity
13 Aug 2024
In a world where data breaches and cybercrimes continue to rise, cybersecurity has never been more crucial. The role of Artificial Intelligence in fortifying these defenses presents an intersection of profound potential. This union is increasingly becoming the backbone of robust security strategies, revolutionizing how we guard against, detect, and respond to emerging cyber threats.
How to choose the right front-end framework for your project?
13 Aug 2024
In the advent of digital transformation, the right front-end framework becomes a lighthouse guiding your project towards its ultimate destination. Allow us to elucidate the labyrinthine quest of selecting the perfect framework for your project. An insightful journey that uncaps the intricacies of this crucial decision-making process awaits.
Show all articles