python模块restful使用方法实例


Posted in Python onDecember 10, 2013

RESTful架构,目前是比较流行的一种互联网软件架构。REST,即Representational State Transfer的缩写。

说白点就是网站即软件,再白点就是一个服务软件支持http的四种方法:

GET用来获取资源,POST用来新建资源、更新资源,PUT用来更新资源,DELETE用来删除资源。

并对外提供一个或多个URI,每个URI对应一个资源;客户端通过URI配合上面的方法就可以和服务

段的软件交互。客户端主要是浏览器,使用restful框架的软件对http的支持也为了web应用带来方便。

REST这个词,是Roy Thomas Fielding在他2000年的博士论文中提出的。他的贡献很多,

可以了解一下。本人工作的方向是SDN,也算是比较潮的东东,其中floodlight就用到了restful框架。

开发者为软件开发出一些功能,并提供URI api,用户就可以利用浏览器、curl等工具通过提供的URI

从软件中获得想要的信息或者设置软件的功能。

对于发开者来说,就是提供URI和URI对应的资源,并将他们对应上,类似dicts={'/path?':resource}。

比如重写http GET方法:首先获得客户端请求的url,解析url然后判断其对应的URI,由于URI与应一个资源,

那么url就可以访问这个资源了。具体实现上资源也就是方法或者一个类,要看具体实现了。

下面来个很简单的例子,因为对于真正功能强大的restful来说,这个例子有几点不足,但是作为简单的演示,

应该够了。

#-*-coding:UTF-8-*-
import socket,sys,urllib
from BaseHTTPServer import *
class Restful(BaseHTTPRequestHandler):  #所有rest的父类
    def __init__(self,request, client_address, server):
        BaseHTTPRequestHandler.__init__(self,request, client_address, server)
        self.dp=None
        self.router=None
    def basepath(self):
        pass
    def getresetlet(self):
        pass
    def send(self,src):
        self.send_response(200)
        self.send_header("Content-type", "text/html")
        self.end_headers()
        self.wfile.write(src)
        self.wfile.close()
    def done(self):
        self.dp=self.basepath()
        self.router=self.getrestlet()
class Test(Restful):            #测试1
    def test(self):  #这就是一个资源
        return "{\"date\":\"2013-11-19\"}"
    def do_GET(self):  #重写get方法给了通过客户端请求的url找到对应的资源
        self.done()
        for key in self.router.keys():
            tmp=self.dp+key
            if tmp in self.path:
                  self.send(self.router[key]()) #执行资源
    def basepath(self): #这个简单的说就是和下面函数中的路径配合,即/wm/time
        return "/wm"
    def getrestlet(self):  #这儿就是URI与资源对应,这里只有test资源,可以注册多个
        rr={}
        rr['/time']=self.test 
          return rr
class testjson(Restful):      #测试2
    def testjson(self,vpc,vr):  #这里比测试1复杂些,因为参数的值需要从url中获得
        src1="{\"vpc\":1,\"vrouter\":3,\"day\":[1,2,3]}"
        src2="{\"vpc\":1,\"vrouter\":4,\"day\":[23,21,3]}"
        src3="{\"vpc\":5,\"vrouter\":3,\"day\":[13,2,23]}"
        tlist=[src1,src2,src3]
        cmpvpc="\"vpc\":"+vpc
        cmpvr="\"vrouter\":"+vr
        for k in tlist:
            if cmpvpc in k and cmpvr in k:
                return k
    def firewall(self):
        return "{\"filter\":[\"baid.com/\",\"c.cn/\"],\"acl\":{\"accept\":123,\"reject\":321}}"
    def do_GET(self):  #重写GET,解析url,这里的self.path类似:/ins/json?vpc=1&vrouter=3
        self.done()
        print self.path
        if 'vpc' in self.path and 'vrouter' in self.path:
            query=None
            if '?' in self.path:
                query =    urllib.splitquery(self.path)
            key=query[0]+'?'
            param=query[1].split('&') #解析获得属性信息,传递给资源函数
            pdict={}
            for p in param:
                tmp=p.split('=')
                pdict[tmp[0]]=tmp[1]  
            for k in self.router.keys():
                if k in key:
                    self.send(self.router[k](pdict['vpc'],pdict['vrouter'])) #执行资源
        elif 'firewall' in self.path:
            self.send(self.router['/firewall']())
        else:
            self.send("{}")
    def basepath(self):
        return "/ins"
    def getrestlet(self):
        rr={}
        rr['/json?']=self.testjson #注册资源
        rr['/firewall']=self.firewall
        return rr
            
try:
    server=HTTPServer(('',8084),testjson) #测试2
    server.serve_forever()
except KeyboardInterrupt:
    sys.exit(0)

如果运行上面的程序,运行的是测试2,运行后此程序监听8084。

此时在浏览器地址栏输入http://127.0.0.1:8084/ins/json?vpc=1&vrouter=3

得到如下图,本人使用的chrome,安装插件后的效果。

python模块restful使用方法实例

这里仅仅作为演示,程序有有许多不足。对于好的框架,注册资源不应该和资源在同一个类中,

basepath()与getrestlet()不应该在实现的资源类里(也就是上面的测试里),也使router没起作用。

应该在另一个类里注册,这样可以通过不同的URI,两个测试都应该能够运行;还有就是使用的python自带的BaseHTTPServer模块,并不适合做restful。

但是工作过程大体就是这样,后续有时间会写个python版的restful简易框架。

Python 相关文章推荐
python遍历数组的方法小结
Apr 30 Python
用Python实现命令行闹钟脚本实例
Sep 05 Python
Django实战之用户认证(初始配置)
Jul 16 Python
对python 多个分隔符split 的实例详解
Dec 20 Python
Python自动化运维之Ansible定义主机与组规则操作详解
Jun 13 Python
Python实现K折交叉验证法的方法步骤
Jul 11 Python
elasticsearch python 查询的两种方法
Aug 04 Python
Python目录和文件处理总结详解
Sep 02 Python
pytorch之添加BN的实现
Jan 06 Python
使用keras框架cnn+ctc_loss识别不定长字符图片操作
Jun 29 Python
Python爬取微信小程序通用方法代码实例详解
Sep 29 Python
python调用百度AI接口实现人流量统计
Feb 03 Python
python解析模块(ConfigParser)使用方法
Dec 10 #Python
python基础入门详解(文件输入/输出 内建类型 字典操作使用方法)
Dec 08 #Python
python socket网络编程步骤详解(socket套接字使用)
Dec 06 #Python
python3图片转换二进制存入mysql
Dec 06 #Python
python数据库操作常用功能使用详解(创建表/插入数据/获取数据)
Dec 06 #Python
python多线程编程方式分析示例详解
Dec 06 #Python
树莓派中python获取GY-85九轴模块信息示例
Dec 05 #Python
You might like
PHP采集利器 Snoopy 试用心得
2011/07/03 PHP
PHP持久连接mysql_pconnect()函数使用介绍
2012/02/05 PHP
PHP乱码问题,UTF-8乱码常见问题小结
2012/04/09 PHP
详解WordPress中用于合成数组的wp_parse_args()函数
2015/12/18 PHP
TP5框架实现自定义分页样式的方法示例
2020/04/05 PHP
在多个页面使用同一个HTML片段《续》
2011/03/04 Javascript
广泛收集的jQuery拖放插件集合
2012/04/09 Javascript
js中的caller和callee属性介绍和例子
2014/06/07 Javascript
JavaScript实现简单的tab选项卡切换
2016/01/05 Javascript
ES6所改良的javascript“缺陷”问题
2016/08/23 Javascript
jQuery实现移动端Tab选项卡效果
2017/03/15 Javascript
浅谈如何使用 webpack 优化资源
2017/10/20 Javascript
vue 实现剪裁图片并上传服务器功能
2018/03/01 Javascript
vue打包相关细节整理(小结)
2018/09/28 Javascript
详解ESLint在Vue中的使用小结
2018/10/15 Javascript
如何解决.vue文件url引用文件的问题
2019/01/18 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
2019/02/18 Javascript
[03:12]完美世界DOTA2联赛PWL DAY9集锦
2020/11/10 DOTA
Python fileinput模块使用介绍
2014/11/30 Python
深入理解python中的select模块
2017/04/23 Python
Python逐行读取文件中内容的简单方法
2019/02/26 Python
python批量处理文件或文件夹
2020/07/28 Python
python中自带的三个装饰器的实现
2019/11/08 Python
Python  Asyncio模块实现的生产消费者模型的方法
2021/03/01 Python
CSS3 实现弹跳的小球动画
2020/10/26 HTML / CSS
详解HTML5中的拖放事件(Drag 和 drop)
2016/11/14 HTML / CSS
C#实现启动一个进程
2016/10/01 面试题
软件项目开发计划书
2014/05/01 职场文书
高等教育学专业自荐书
2014/06/17 职场文书
居委会四风问题个人对照检查材料
2014/09/25 职场文书
2014年小学图书室工作总结
2014/12/09 职场文书
村级干部党员公开承诺事项
2015/05/04 职场文书
党小组考察意见
2015/06/02 职场文书
Nginx反向代理及负载均衡如何实现(基于linux)
2021/03/31 Servers
python删除csv文件的行列
2021/04/06 Python
MySQL定时备份数据库(全库备份)的实现
2021/09/25 MySQL