RESTful - 前后端分离之Flask-restful-程序员宅基地

技术标签: 学习  前后端分离  Linux  知识点收藏  项目记录  flask-restful  数据库  自学  

什么是RESTFul?

1.简介

REST即表述性状态传递,是Roy Fielding提出的一种软件架构风格。它是一种针对网络应用的设计和开发方式,可以降低开发的复杂性,提高系统的可伸缩性。

是一种软件架构风格、设计风格,而不是标准,只是提供了一组设计原则和约束条件。它主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

REST 指的是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是 RESTful。遵循restful开发的应用程序接口(API)称为RESTFul API。RESTFul的接口都是围绕资源以及对资源的各种动作展开的。

2.资源

所谓的资源就是在网络中存在的任意实体,哪怕是一条简单信息。通俗讲就是我们访问的每个页面

数据之间传输格式:使用json,而不使用xml

3.动作

所谓动作就是数据的CURD。在开发者设计良好的前提下,对网络资源的动作都可抽象为对资源的CURD操作。RESTFul对网络的操作抽象为HTTP的GET、POST、PUT、DELETE等请求的方式以完成对资源的增删改查。具体对照如下:

方法  行为 示例
GET  获取资源信息  http://127.0.0.1:5000/source
GET 获取指定资源 http://127.0.0.1:5000/source/250
POST 创建新的资源 http://127.0.0.1:5000/source
PUT  更新指定资源   http://127.0.0.1:5000/source/250
DELETE 删除指定资源 http://127.0.0.1:5000/source/250

4.数据

通常传输的数据格式都采用JSON,有时也可以通过URL的参数进行传递

5.工具

说明:postman是一款非常好用的API开发测试工具,可以模拟各种请求
提醒:安装包,一路next完成安装,演示一个地址的访问

 

使用Flask-restful

Flask-RESTful是一个Flask的扩展,它增加了对快速构建REST APIs的支持。它是一种轻量级的抽象,可以与现有的ORM/库一起工作。Flask-RESTful励以最少的安装方式进行最佳实践

安装:pip install flask-restful

flask-restuflu中每种资源抽象成类,需要继承自Resource

下面是一个最小的API例子:

from flask import Flask
from flask_restful import Resource, Api

app = Flask(__name__)   #用flask创建app
api = Api(app)          #用Api来绑定app

class HelloWorld(Resource):
    def get(self):
        return {'hello': 'world'}

api.add_resource(HelloWorld, '/')   #通过把URLs传给Api对象的add_resource()方法,访问到你的资源

if __name__ == '__main__':
    app.run(debug=True) 

端点扩展:

1.资源通过多个URLs访问:  api.add_resource(HelloWorld,'/','/hello')

2.将路径的部分匹配为资源方法的变量:
api.add_resource(Todo,'/todo/<int:todo_id>',endpoint='todo_ep')
解析:
(1)endpoint是用来给url_for反转url的时候指定的。
如果不写endpoint,那么将会使用视图的名字的小写来作为endpoint。
(2):add_resource的第二个参数是访问这个视图函数的url,这个url可以跟之前的route一样,可以传递参数
。并且还有一点不同的是,这个方法可以传递多个url来指定这个视图函数。

3.如果一个请求与你的应用程序端点中的任何一个都不匹配,Flask-RESTful 将会返回404错误.
并附带一段有关其它最相似匹配的端点建议。你可以通过在配置中将ERROR_404_HELP设置为 False禁用此项。

参数解析

访问写完,那程序如何解析呢?

Flask-RESTful 内置了支持验证请求数据,它使用了一个类似argparse 的库。

from flask_restful import reqparse

parser = reqparse.RequestParser()
parser.add_argument('rate', type=int, help='Rate to charge for this resource')
args = parser.parse_args()


注:与 argparse 模块不同的是,reqparse.RequestParser.parse_args() 返回了 Python 字典
而不是一个自定义的数据结构。

使用 reqparse 模块同样可以自由地提供全面的错误信息。如果一个参数没有通过校验,Flask-RESTful 将会以一个400的错误请求以及高亮的错误信息回应,如下:

$ curl -d 'rate=foo' http://127.0.0.1:5000/todos

==》  {'status': 400, 'message': 'foo cannot be converted to int'}

inputs模块提供许多常用的转换函数,像 inputs.date() 和 inputs.url()。

调用 parse_args 传入 strict=True 能够确保当请求包含了你的解析器中未定义的参数时抛出一个异常。

args = parser.parse_args(strict=True)

 

完整例子

# -*- coding: utf-8 -*-
from flask import Flask
from flask_restful import reqparse, abort, Api, Resource

#做简单的Application初始化
app = Flask(__name__)
api = Api(app)         #用Api来绑定app

#定义我们需要操作的资源类型(都是json格式的)
TODOS = {
    'todo1': {'task': 'build an API'},
    'todo2': {'task': '哈哈哈'},
    'todo3': {'task': 'profit!'},
}

#验证todo_id是否在TODOS当中
def abort_if_todo_doesnt_exist(todo_id):
    if todo_id not in TODOS:
        abort(404, message="Todo {} doesn't exist".format(todo_id))

#参数解析的RequestParser类,可以很方便的解析请求中的-d参数,并进行类型转换
parser = reqparse.RequestParser()
parser.add_argument('task')

#操作(put / get / delete)单一资源Todo
class Todo(Resource):
    def get(self, todo_id):
        abort_if_todo_doesnt_exist(todo_id)      #进行请求前,先做id确认
        return TODOS[todo_id]                    #从TODOS字典中读取数据

    def delete(self, todo_id):
        abort_if_todo_doesnt_exist(todo_id)
        del TODOS[todo_id]
        return '', 204

    def put(self, todo_id):
        args = parser.parse_args()
        task = {'task': args['task']}
        TODOS[todo_id] = task
        return task, 201

# # 操作(post / get)资源列表TodoList
class TodoList(Resource):
    def get(self):
        return TODOS

    def post(self):
        args = parser.parse_args()
        todo_id = int(max(TODOS.keys()).lstrip('todo')) + 1
        todo_id = 'todo%i' % todo_id
        TODOS[todo_id] = {'task': args['task']}
        return TODOS[todo_id], 201


# 设置路由,即告诉Python程序URL的对应关系
api.add_resource(TodoList, '/todos')
api.add_resource(Todo, '/todos/<todo_id>')

if __name__ == '__main__':
    app.run(debug=True)

以下用postman工具验证结果

查询列表:

查询单任务:

删除任务:

添加任务(这是用post表单形式,还可以改成json形式啦):

更新任务:

 

ok,后台flask已经返回数据了,那前端怎么接收呢,后面再举一例解释

前后端分离简单理解

flask中返回json格式数据

简单前后端分离:

前端页面变成一个静态文件。存放在项目的static/html目录下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Score List</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <script>
        $(function (){
            $.getJSON("/getscores/", function (data){    #引入data
                console.log(data);
                var scores = data["scores"];             #data中获取对应数据
                var $ul = $("#score_container");
                for(var i=0; i < scores.length; i++){
                    var $li = $("<li></li>").html(scores[i]);  
                    $ul.append($li);
                }
            })
        })
    </script>
</head>
<body>
<h2>机试成绩表</h2>
<ul id="score_container"></ul>
</body>
</html>

后端只需要返回json数据即可:

@app.route('/getscores/')
def get_scores():
    data = {
        'msg': 'ok',
        'status': '200',
        'scores': [1,2,3,4,5,6,30,40]
    }
    return jsonify(data)

 

ok,记录到此~

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_42277380/article/details/97629932

智能推荐

前端开发之vue-grid-layout的使用和实例-程序员宅基地

文章浏览阅读1.1w次,点赞7次,收藏34次。vue-grid-layout的使用、实例、遇到的问题和解决方案_vue-grid-layout

Power Apps-上传附件控件_powerapps点击按钮上传附件-程序员宅基地

文章浏览阅读218次。然后连接一个数据源,就会在下面自动产生一个添加附件的组件。把这个控件复制粘贴到页面里,就可以单独使用来上传了。插入一个“编辑”窗体。_powerapps点击按钮上传附件

C++ 面向对象(Object-Oriented)的特征 & 构造函数& 析构函数_"object(cnofd[\"ofdrender\"])十条"-程序员宅基地

文章浏览阅读264次。(1) Abstraction (抽象)(2) Polymorphism (多态)(3) Inheritance (继承)(4) Encapsulation (封装)_"object(cnofd[\"ofdrender\"])十条"

修改node_modules源码,并保存,使用patch-package打补丁,git提交代码后,所有人可以用到修改后的_修改 node_modules-程序员宅基地

文章浏览阅读133次。删除node_modules,重新npm install看是否成功。在 package.json 文件中的 scripts 中加入。修改你的第三方库的bug等。然后目录会多出一个目录文件。_修改 node_modules

【】kali--password:su的 Authentication failure问题,&sudo passwd root输入密码时Sorry, try again._password: su: authentication failure-程序员宅基地

文章浏览阅读883次。【代码】【】kali--password:su的 Authentication failure问题,&sudo passwd root输入密码时Sorry, try again._password: su: authentication failure

整理5个优秀的微信小程序开源项目_微信小程序开源模板-程序员宅基地

文章浏览阅读1w次,点赞13次,收藏97次。整理5个优秀的微信小程序开源项目。收集了微信小程序开发过程中会使用到的资料、问题以及第三方组件库。_微信小程序开源模板

随便推点

Centos7最简搭建NFS服务器_centos7 搭建nfs server-程序员宅基地

文章浏览阅读128次。Centos7最简搭建NFS服务器_centos7 搭建nfs server

Springboot整合Mybatis-Plus使用总结(mybatis 坑补充)_mybaitis-plus ruledataobjectattributemapper' and '-程序员宅基地

文章浏览阅读1.2k次,点赞2次,收藏3次。前言mybatis在持久层框架中还是比较火的,一般项目都是基于ssm。虽然mybatis可以直接在xml中通过SQL语句操作数据库,很是灵活。但正其操作都要通过SQL语句进行,就必须写大量的xml文件,很是麻烦。mybatis-plus就很好的解决了这个问题。..._mybaitis-plus ruledataobjectattributemapper' and 'com.picc.rule.management.d

EECE 1080C / Programming for ECESummer 2022 Laboratory 4: Global Functions Practice_eece1080c-程序员宅基地

文章浏览阅读325次。EECE 1080C / Programming for ECESummer 2022Laboratory 4: Global Functions PracticePlagiarism will not be tolerated:Topics covered:function creation and call statements (emphasis on global functions)Objective:To practice program development b_eece1080c

洛谷p4777 【模板】扩展中国剩余定理-程序员宅基地

文章浏览阅读53次。被同机房早就1年前就学过的东西我现在才学,wtcl。设要求的数为\(x\)。设当前处理到第\(k\)个同余式,设\(M = LCM ^ {k - 1} _ {i - 1}\) ,前\(k - 1\)个的通解就是\(x + i * M\)。那么其实第\(k\)个来说,其实就是求一个\(y\)使得\(x + y * M ≡ a_k(mod b_k)\)转化一下就是\(y * M ...

android 退出应用没有走ondestory方法,[Android基础论]为何Activity退出之后,系统没有调用onDestroy方法?...-程序员宅基地

文章浏览阅读1.3k次。首先,问题是如何出现的?晚上复查代码,发现一个activity没有调用自己的ondestroy方法我表示非常的费解,于是我检查了下代码。发现再finish代码之后接了如下代码finish();System.exit(0);//这就是罪魁祸首为什么这样写会出现问题System.exit(0);////看一下函数的原型public static void exit (int code)//Added ..._android 手动杀死app,activity不执行ondestroy

SylixOS快问快答_select函数 导致堆栈溢出 sylixos-程序员宅基地

文章浏览阅读894次。Q: SylixOS 版权是什么形式, 是否分为<开发版税>和<运行时版税>.A: SylixOS 是开源并免费的操作系统, 支持 BSD/GPL 协议(GPL 版本暂未确定). 没有任何的运行时版税. 您可以用她来做任何 您喜欢做的项目. 也可以修改 SylixOS 的源代码, 不需要支付任何费用. 当然笔者希望您可以将使用 SylixOS 开发的项目 (不需要开源)或对 SylixOS 源码的修改及时告知笔者.需要指出: SylixOS 本身仅是笔者用来提升自己水平而开发的_select函数 导致堆栈溢出 sylixos

推荐文章

热门文章

相关标签