Home >Backend Development >Python Tutorial >RESTful API design based on Python

RESTful API design based on Python

PHPz
PHPzOriginal
2023-06-17 10:06:102900browse

With the popularity of the Internet, more and more applications are beginning to use RESTful API interfaces for data interaction. RESTful API, "Representational State Transfer", is a network application interface design pattern based on the HTTP protocol. It is a way of communicating through HTTP protocol using data formats such as XML and JSON on the Internet, so that applications can interact with each other and exchange data.

Compared with other interface design patterns, RESTful API is simple, flexible, easy to use, and versatile, and is favored by many developers. This article will introduce how to design RESTful API using Python language.

1. RESTful API design principles
When designing a RESTful API, you need to follow the following principles:

  1. Uniquely identify resources: Each resource needs to have a unique URI (Uniform Resource Identifier) ​​for identification.
  2. Use HTTP protocol for communication: RESTful API is mainly based on HTTP protocol for data interaction, so it needs to comply with the regulations of HTTP protocol.
  3. Use standard HTTP methods: In RESTful API, the main HTTP methods used are GET, POST, PUT, DELETE, etc.
  4. Use HTTP status code for identification: RESTful API uses HTTP status code to return request results, such as 200 for success, 404 for resource not found, etc.

2. Use Python to implement RESTful API design
Python is a very popular programming language. It is easy to read, write, concise and clear. It is one of the ideal languages ​​​​for building RESTful APIs. one. Below, we will use Python Flask and Flask-RESTful library to implement a simple RESTful API.

  1. Install Flask and Flask-RESTful library
    Flask is a web framework based on the Python language, which can be used to build web applications. Flask-RESTful is a RESTful API framework developed on the basis of Flask, which can be used to build RESTful API applications. Before you start building a RESTful API, you need to install Flask and the Flask-RESTful library.

    $ pip install flask
    $ pip install flask-restful
  2. Writing RESTful API code
    After installing Flask and Flask-RESTful libraries, we can start writing RESTful API code. Below, we take a simple student management system as an example to introduce how to use Python to write a RESTful API.

First, we need to create a Flask application and introduce the Flask-RESTful library into the application:

from flask import Flask
from flask_restful import Resource, Api

app = Flask(__name__)
api = Api(app)

Then, we need to define a student class and define the relevant Resource:

class Student(Resource):
    def get(self, id):
        # 获取指定id的学生信息
        pass

    def post(self):
        # 新增一个学生
        pass

    def put(self, id):
        # 更新指定id的学生信息
        pass

    def delete(self, id):
        # 删除指定id的学生信息
        pass

api.add_resource(Student, '/students', '/students/<int:id>')

In the above code, we define a Student class, which inherits the Resource class in the Flask-RESTful library. Among them, the get, post, put, and delete methods correspond to the GET, POST, PUT, and DELETE methods in the RESTful API respectively. Then, we use the add_resource method to bind the Student class and the URI of the corresponding resource.

Finally, we need to run the Flask application:

if __name__ == '__main__':
    app.run(debug=True)
  1. Testing the RESTful API
    After writing the RESTful API code, we need to test it. You can use tools such as Postman for testing, or you can write your own Python scripts for testing. Below, we take Python script as an example to test the RESTful API:

    import requests
    import json
    
    # 获取指定id的学生信息
    response = requests.get("http://localhost:5000/students/1")
    print(response.content)
    
    # 新增一个学生
    data = {
        "name": "Tom",
        "age": 20,
        "gender": "Male"
    }
    headers = {
        "content-type": "application/json"
    }
    response = requests.post("http://localhost:5000/students", data=json.dumps(data), headers=headers)
    print(response.content)
    
    # 更新指定id的学生信息
    data = {
        "name": "Tom",
        "age": 21,
        "gender": "Male"
    }
    headers = {
        "content-type": "application/json"
    }
    response = requests.put("http://localhost:5000/students/1", data=json.dumps(data), headers=headers)
    print(response.content)
    
    # 删除指定id的学生信息
    response = requests.delete("http://localhost:5000/students/1")
    print(response.content)

In the above code, we use the requests library to send GET, POST, PUT, and DELETE requests, and then print out The result returned. Among them, the data parameter needs to convert the Python dictionary into a JSON string, and the headers parameter needs to specify the content-type as application/json.

3. Summary
This article introduces how to use Python language to design RESTful API, which uses Python Flask and Flask-RESTful library. Through studying this article, readers should master how to build a RESTful API in the Python language, and also understand the design principles and common HTTP methods of RESTful APIs. In future web application development, I hope readers can flexibly use RESTful API technology to achieve more efficient, flexible and easy-to-use applications.

The above is the detailed content of RESTful API design based on Python. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn