preface

What is an API?

What is the SDK?

What is the relationship between the two?

Welcome to our weekly q&a series.

Now that I clicked on it, I’m sure you’ve heard of these two nouns before, so let’s start with an example. If you want to develop an OCR application (commonly known as a text recognition application), its function is to recognize a user uploaded a picture, and then the image of the text recognition back to the user. As shown below:

Often, the back-end services of OCR applications are deployed in the cloud, so how do we communicate between mobile applications and cloud-based services?

This is where the API and SDK come in.

API

The characteristics of the API

communication

The first thing we need to understand is that apis are about communication, protocols defined for applications (services) to talk to other applications (services). In the example above, you can simply think of the API as the bridge between the OCR application and the cloud service.

So what exactly is an API?

Application Programming Interface (API)

Typically, these are predefined functions designed to provide users and developers with the ability to access a set of programs based on a piece of software or hardware without having to access the source code or understand the details of the inner workings.

In Java, for example, when you want to sort an array, do you write a sorting algorithm first, or do you just use arrays.sort ()? I think you have some answers in your mind.

abstract

Second, we need to understand another important feature of apis: abstraction.

What does abstraction mean?

Take this OCR application as an example. When we use the character recognition capability provided by the cloud (such as Baidu character recognition), there may be thousands of codes behind it, such as the machine learning code that provides recognition capability, the back-end code that provides Web capability and so on.

But as an APP developer, do you need to see how the code is written? Don’t know the source code behind cannot call baidu to provide the ability to identify the text? Of course not.

Often the service provider has already provided you with documentation on how to invoke the service, as long as you follow its instructions.

Therefore, the API abstracts out all the complex logic between your APP and the OCR service, simplifying the call process so that you only need to worry about getting the data you need.

standardized

Apis are standardized, which means there are industry standards on how to define apis, such as SOAP, REST, GraphQL, and so on.

I wrote about RESTful apis in your first SpringBoot book, which you can click to read. This is a SpringBoot introductory tutorial I am writing. It is not finished yet, and you are welcome to give your suggestions 🙏.

The components of an API

So, what does an API usually consist of?

First, we send some data to the cloud, called a “request.”

Sending a request from a local application to the cloud takes several steps. Take REST for example.

For REST API invocation requests, the first step is to specify the method to be transferred, usually corresponding to HTTP methods, as shown in the following figure:

When you want to upload an image, you usually use the POST method, followed by passing some parameters, including the requested content (the image itself). Then add the address you want to request to form a complete request. As shown below:

The server then returns the data to you in JSON and other forms, annotated in the documentation of the cloud service you use.

SDK

Having said that, you should know something about apis, which begs the question: how do you, as a developer, invoke an API in a real project?

Do you have to construct the HTTP request yourself, concatenate the URL, add the required parameters, and process the returned JSON object?

Trouble.

Is there a good way to simplify things so that I can just give me an image and then give me the result?

Of course there is, and that’s where the SDK comes in.

SDK stands for Software Development Kit.

It is generally a collection of development tools used by some software engineers to build application software for specific software packages, software frameworks, hardware platforms, operating systems, etc.

Generally speaking, it is a tool package provided by a third-party service provider to implement a function of product software. The JDK, for example, is an SDK.

Using the OCR application above as an example, if we use a vendor’s SDK service, we don’t even need to build the HTTP request, just call a method, and the possible code is shown in the figure below.

OCRResult res = ocrClient.ocr("pic.jpg").getResult();
Copy the code

By calling this line of code, the SDK will automatically wrap the API request, and as a response, you will get a result that is not necessarily a JSON object, but could be code, such as the OCRResult in the above code section, because the SDK has also deserialized the JSON object into the object you want. For example, a Java Model.

The SDK is equivalent to the development integration tool environment, and the API is the data interface. Apis can be requested in the “environment” provided by the SDK. Similarly, the “environment” here is an abstract concept. If you don’t use the SDK, you can call the API directly, but the environment is up to the developer to implement.

The difference between

In fact, we have learned from the above that the API is more like a subset of the SDK in most cases, and their differences are as follows:

  • An API is usually a function that has a specific function; The SDK is a collection of many functions, more like a toolkit.
  • An API usually acts as a data interface, and an SDK acts as a tool environment, usually calling APl in the SDK environment.
  • The SDK has a higher level of encapsulation than the API.

The above is all the content of this article, if you think the article is helpful to you, click on the attention to forward to your friends, this is really important to me, your support is my motivation to continue to write more, thank you!