python3封装Api接口
注:本篇的代码和语法基于Python3.5环境,下面将用到Python 的Flask框架
封装接口主要讲静态接口(无参数传入)、动态接口(有参数传入,不同参数返回的信息不同)。针对动态接口有三种传参方式:key_value、json串和拼接方式入参
- 一、封装成无参数传入的接口
from flask import Flask,jsonify,request
data = {'huhy':{'age':24,'sex':'女'},
'liuer':{'age':12,'sex':'男'}
}
app = Flask(__name__)#创建一个服务,赋值给APP
@app.route('/get_user',methods=['post'])#指定接口访问的路径,支持什么请求方式get,post
#讲的是封装成一种静态的接口,无任何参数传入
def get_user():#-----这里的函数名称可以任意取
return jsonify(data)#把字典转成json串返回 app.run(host='0.0.0.0',port=8802,debug=True)
#这个host:windows就一个网卡,可以不写,而liux有多个网卡,写成0:0:0可以接受任意网卡信息,
通过访问127.0.0.1:8802/get_user,可返回data信息
#debug:调试的时候,可以指定debug=true;如果是提供接口给他人使用的时候,debug要去掉接口返回的截图如下:
- 二、有参数传入的接口
1.通过key_value方式传参from flask import Flask,jsonify,request
data = {'huhy':{'age':24,'sex':'女'},
'liuer':{'age':12,'sex':'男'}
}
err = {'zz':404,
'yy':502
}
app = Flask(__name__)#创建一个服务,赋值给APP
@app.route('/get_user',methods=['post'])#指定接口访问的路径,支持什么请求方式get,post # key_values方式传参
def get_user():
username = request.form.get('username')#获取接口请求中form-data的username参数传入的值
if username in data:#判断请求传入的参数是否在字典里
return jsonify(data[username])
#如果在的话,则返回data对应key的值转成的json串信息
else:
return jsonify(err[username])
#如果不在的话,返回err对应key的value转成的json串信息 app.run(host='0.0.0.0',port=8802,debug=True)
#这个host:windows就一个网卡,可以不写,而liux有多个网卡,写成0:0:0可以接受任意网卡信息
#通过访问127.0.0.1:8802/get_user,form—data里输入username参数,则可看到返回信息接口返回的截图如下:
2.通过json串方式传参
from flask import Flask,jsonify,request
data = {'huhy':{'age':24,'sex':'女'},
'liuer':{'age':12,'sex':'男'}
}
err = {'zz':404,
'yy':502
}
app = Flask(__name__)#创建一个服务,赋值给APP
@app.route('/get_user',methods=['post'])#指定接口访问的路径,支持什么请求方式get,post #json方式传参
def get_ss():
username = request.json.get('username1')#获取带json串请求的username参数传入的值
if username in data: # 判断请求传入的参数是否在字典里
return jsonify(data[username])
#如果在的话,则返回data对应key的值转成的json串信息
else:
return jsonify(err[username])
#如果不在的话,返回err对应key的value转成的json串信息
app.run(host='0.0.0.0',port=8802,debug=True)
#这个host:windows就一个网卡,可以不写,而liux有多个网卡,写成0:0:0可以接受任意网卡信息
#通过访问127.0.0.1:8802/get_user,form—data里输入username参数,则可看到返回信息接口返回的截图如下:
3.请求链接直接拼接入参方式
from flask import Flask,jsonify,request
data = {'huhy':{'age':24,'sex':'女'},
'liuer':{'age':12,'sex':'男'}
}
err = {'zz':404,
'yy':502
}
app = Flask(__name__)#创建一个服务,赋值给APP
@app.route('/get_user',methods=['post'])#指定接口访问的路径,支持什么请求方式get,post #请求后直接拼接入参方式
def get_ss():
username = request.args.get('username')#使用request.args.get方式获取拼接的入参数据
if username in data: # 判断请求传入的参数是否在字典里
return jsonify(data[username])
#如果在的话,则返回data对应key的值转成的json串信息
else:
return jsonify(err[username])
#如果不在的话,返回err对应key的value转成的json串信息
app.run(host='0.0.0.0',port=8802,debug=True)
#这个host:windows就一个网卡,可以不写,而liux有多个网卡,写成0:0:0可以接受任意网卡信息
#通过访问127.0.0.1:8802/get_user,form—data里输入username参数,则可看到返回信息接口返回的截图,如下:
4.request.values.get()获取请求参数的方法,不仅支持获取连接拼接的参数,而且还能获取body form填入的参数
- 未完待续
python3封装Api接口的更多相关文章
- Vue实例中封装api接口的思路 在页面中用async,await调用方法请求
一般我们写小型的项目是用不到封装axios实例 但是当我们写大型项目时 接口有时候多到有上百个接口,那我们在请求一次调用一次接口,接口上好多都是重复的,这个时候我们就可以封装axios实例,既节省了 ...
- vue封装API接口
第一步: 首先引入axios 然后创建两个文件夹api和http http.js 里面的 1 import axios from 'axios';//引入axios 2 3 //环境的切换 开发环境( ...
- 回调函数 和 promise对象,及封装API接口
1.回调函数:https://blog.csdn.net/baidu_32262373/article/details/54969696 注意:回调函数不一定需要用到 return.如果浏览器支持Pr ...
- Vue中axios的封装和api接口的统一管理
更新的是我csdn上的文章,需要的话可以看下,互相学习点击去我的csdn vue中axios的封装 在vue项目和后端交互获取数据时,通常使用axios库,官方文档:https://www.npmjs ...
- vue中Axios的封装和API接口的管理
前端小白的声明: 这篇文章为转载:主要是为了方便自己查阅学习.如果对原博主造成侵犯,我会立即删除. 转载地址:点击查看 如图,面对一团糟代码的你~~~真的想说,What F~U~C~K!!! 回归正题 ...
- vue2.0 + vux (五)api接口封装 及 首页 轮播图制作
1.安装 jquery 和 whatwg-fetch (优雅的异步请求API) npm install jquery --save npm install whatwg-fetch --save 2. ...
- 【uni-app】uni.request二次封装,更好的管理api接口和使用
前言 之前写了一个Vue.js的axios二次封装(点击跳转),这次是uni-app,uni-app是基于vue.js框架的,我觉得是很好用的一个框架,而且一套代码编译那么多平台,非常节省成本,当然, ...
- 【vue】axios二次封装,更好的管理api接口和使用
在现在的前端开发中,前后端分离开发比较主流,所以在封装方法和模块化上也是非常需要掌握的一门技巧.而axios的封装也是非常的多,下面的封装其实跟百度上搜出来的axios封装或者axios二次封装区别不 ...
- 循序渐进VUE+Element 前端应用开发(13)--- 前端API接口的封装处理
在前面随笔<循序渐进VUE+Element 前端应用开发(12)--- 整合ABP框架的前端登录处理>介绍了一个系统最初接触到的前端登录处理的实现,但往往对整个系统来说,一般会有很多业务对 ...
随机推荐
- 协程实现多并发socket,跟NGINX一样
server: #!/usr/bin/env python # -*- coding: utf-8 -*- # author aliex-hrg import gevent from gevent i ...
- excel技巧--文本拆分合并
如果像上图那样将一单元格内拆分成同等大小的字词,可用如下步骤: 1.将该单元格的宽度缩至拆分词的大小: 2.选择同列的适当的单元格,用于填充拆分的字符: 3.点击“开始”-->填充-->两 ...
- 注册表项关于start参数的说明
start = {0,1,2,3,4}0 == 由核心装载器装载1 == 由I/O子系统装载2 == 自动启动3 == 手工启动4 == 禁止启动
- java中关于File类的细说
File类是我们接触的比较多的类,当初学习是真是傻傻分不清啊.今天就总结一下file的一些比较不好区分的地方. 首先:当然就是构造方法 File f = new File("文件路径&quo ...
- RTB业务知识之1-原生广告
一.背景 Native Advertising (Native Ads), 又称为原生广告, 是2013全球媒体界爆红的关键词,从2012年年底,就有人开始提了这个名词,接着到处都可以看到这个名词,再 ...
- IIS7.0 下使用Intelligencia.UrlRewriter时Session为空问题
背景 新年伊始,本人的开发环境由Windows Server 2003 +IIS 6 升级成了 Windows Server 2008 +IIS 7,之后便着手参加新项目的开发.项目开发后期测试过程中 ...
- 关于java多线程理解到集群分布式和网络设计的浅析
对于JAVA多线程的应用非常广泛,现在的系统没有多线程几乎什么也做不了,很多时候我们在何种场合如何应用多线程成为一种首先需要选择的问题, 另外关于java多线程的知识也是非常的多,本文中先介绍和说明一 ...
- vagrant box保存路径修改
add box的时候默认保存在C盘用户文件夹 C:\Users\xxx.vagrant.d,通过设置VAGRANT_HOME环境变量改变默认位置 WIN setx VAGRANT_HOME “X:/y ...
- python-selenium并发执行测试用例(方法一 各模块每一条并发执行)
总执行代码: # coding=utf-8import unittest,os,timeimport HTMLTestRunnerimport threadingimport syssys.path. ...
- checked和stop()的讲解
input:cheacked (属性选择器): checked 选中复选框 $("p").stop(ture); 代码的翻译:(参数)布尔值 p身上所有的动画都停止了 加不加tr ...