DEV Community

Phanhie
Phanhie

Posted on

APIs - A BEGINNER’S GUIDE

You just started learning software development and so many terminologies are swimming in your lessons, which can be overwhelming. Then you hear about one, APIs, and you’re told it is a connection between the backend and front end of some websites. This was my initial understanding. While an API is a connection between software programs and applications, there’s way more to it than just that, and in this episode, we’ll talk briefly about what an API is.

Understanding the Basics
An API (Application Programming Interface) is a connection between computer programs. It helps two pieces of software communicate by providing functions with data. There are usually three components involved in this process:
Endpoints: This is a digital location represented by a URL where an API receives requests for data. When a client seeks information, resources, or data, it requests this endpoint.
Request: As the term suggests, this is a message sent to the API's database that asks for specific information or resources for the client.
Response: This is the message returned after the request has been processed. It indicates whether the request was successful or unsuccessful, depending on the situation and the type of request made.

Types of APIs
There are several types of APIs, including:
Public APIs: Also known as Open APIs, these are APIs made available to the general public and all software developers. You can integrate these APIs into your application without concerns about infringement. A well-known example is the OpenWeather API, which can be used for weather-related development.
Partner API: These APIs are not available to the public. They are created by a company to be shared with specific clients or partners. Examples include the Amazon Selling Partner API and the Airbnb Partner API.
Internal APIs: Also referred to as private APIs, internal APIs are designed specifically for use within an organization. They enable different services to work together seamlessly and are not made public.
RESTful API: Representational State Transfer (REST) APIs connect components in microservices architectures. They allow for secure communication between two software systems using HTTPS.
Composite APIs: These APIs enable you to bundle several API calls into a single request, helping to organize data into the required format. They are built on a product’s existing architecture.

How APIs work?
APIs connect software in three simple but complex steps:
There is a client application or software and the application sends a request to the API for a particular data.
The API receives the request and processes it by consulting the API database.
After the request has been processed, a response is sent back to the client application and is displayed on the website. This response can include data, an error message, or a status code.

Components of an API
API Endpoints
An API endpoint is a URL where requests are sent by the client application. Every request from the client application has its endpoint, which is important for organizing the API and making it easier to use.
Some examples of API endpoints are:
Twitter - https://api.twitter.com/2/tweets/{id}
Spotify - https://api.spotify.com/v1/albums/{id}
YouTube - https://www.googleapis.com/youtube/v3/videos
GitHub - https://api.github.com/repos/torvalds/linux

API Methods/HTTP Verbs
These methods are used in the coding process of API integration to specify the actions to be performed on a resource. They inform the server of your intended operations with the requested data. They are:
GET: Used to retrieve data from a resource. It should only be used for retrieving data and not for modifying it.
POST: Used to create a new resource. The data for the new resource is sent in the request body.
PUT: Used to update an existing resource. It typically replaces the entire resource with the data sent in the request body.
DELETE: Used to delete a resource.

Headers and Parameters
These are additional components of an API request sent for different purposes and in different parts of the request.
The header provides metadata about the request and response, sent in the HTTP headers. They enhance the request with additional information without being the request itself.
Parameters on the other hand are used to specify data that influences the action taken by the API, parameters act like search filters to refine the data returned. They can appear in the URL in two forms:
Query parameters: Added after a question mark (?) in the URL, these are used for filtering and sorting.
Example: GET /products?category=electronics&sort=price
Integrated into the URL path to identify specific resources.
Example: GET /products/123 (where 123 is the ID of the product)
Response Format
This typically refers to the structure of the response sent to an API and depends on factors such as the data type sent, the programming language used, API design style etc.
Some of these response formats are:
JSON
Plain Text
XML (Extensible Markup Language)
HTML (HyperText Markup Language)
CSV (Comma Separated Values)

Importance of API
APIs connect different software and allow them to work seamlessly together creating room for innovation, and efficiency. This is useful because it makes things faster, easier, and better for everyone. For developers, it means they don't have to build everything from scratch – they can plug into existing tools and services. For businesses, it means they can update their systems without completely rebuilding them, reach more customers on different devices, and automate boring tasks. And for users, it means smoother experiences, like getting directions on a map or paying online easily. APIs make everything work together more smoothly and help businesses grow.

Use Cases
Weather Updates: The weather forecast App on your phone uses APIs from weather data providers to fetch the latest weather information for your location.
Social Media Integration: External websites or apps allow you to share stuff directly to your social media platforms by using the social media(Facebook, Twitter, Instagram) API. This can be done without having to manually copy and paste anything
Online Payments: You're buying something online and you choose to pay with PayPal. The online store uses PayPal's API to securely connect to PayPal's systems, process your payment, and confirm the transaction. This ensures your financial information is handled safely.
In conclusion, APIs connect the digital world. It allows different software systems to communicate and share information, enabling countless functionalities we rely on every day, from online shopping and social media to maps and streaming services. APIs are essential for modern technology and continue to drive the development of new and exciting applications by enhancing user experience and efficiency.

Top comments (0)