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作用域用法实例详解
Mar 15 Python
python对象及面向对象技术详解
Jul 19 Python
python构建深度神经网络(DNN)
Mar 10 Python
Django如何配置mysql数据库
May 04 Python
小白入门篇使用Python搭建点击率预估模型
Oct 12 Python
python之当你发现QTimer不能用时的解决方法
Jun 21 Python
基于Python实现大文件分割和命名脚本过程解析
Sep 29 Python
python numpy中cumsum的用法详解
Oct 17 Python
python中的逆序遍历实例
Dec 25 Python
PyCharm刷新项目(文件)目录的实现
Feb 14 Python
python中如何写类
Jun 29 Python
详解Python IO编程
Jul 24 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共享内存段示例分享
2014/01/20 PHP
PHP实现的sqlite数据库连接类
2014/12/12 PHP
php目录拷贝实现方法
2015/07/10 PHP
php flush无效,IIS7下php实时输出的方法
2016/08/25 PHP
ThinkPHP 3.2.3实现加减乘除图片验证码
2018/12/05 PHP
学习YUI.Ext 第六天--关于树TreePanel(Part 1)
2007/03/10 Javascript
使用dynatrace-ajax跟踪JavaScript的性能
2010/04/12 Javascript
jQuery 选择器、DOM操作、事件、动画
2010/11/25 Javascript
JS防止网页被嵌入iframe框架的方法分析
2016/09/13 Javascript
JS动态计算移动端rem的解决方案
2016/10/14 Javascript
jQuery 常见小例汇总
2016/12/14 Javascript
axios的拦截请求与响应方法
2018/08/11 Javascript
angularjs $http调用接口的方式详解
2018/08/13 Javascript
vue发送ajax请求详解
2018/10/09 Javascript
新手简单了解vue
2019/05/29 Javascript
简单了解JavaScript sort方法
2019/11/25 Javascript
[02:42]决战东方!DOTA2亚洲邀请赛重启荣耀之争
2017/03/17 DOTA
[52:40]完美世界DOTA2联赛PWL S2 Magma vs GXR 第一场 11.29
2020/12/02 DOTA
python通过cookie模拟已登录状态的初步研究
2016/11/09 Python
python使用KNN算法手写体识别
2018/02/01 Python
python opencv实现运动检测
2018/07/10 Python
python web框架Flask实现图形验证码及验证码的动态刷新实例
2019/10/14 Python
Python-Flask:动态创建表的示例详解
2019/11/22 Python
Python使用pyyaml模块处理yaml数据
2020/04/14 Python
详解Selenium 元素定位和WebDriver常用方法
2020/12/04 Python
英国川宁茶官方网站:Twinings茶
2019/05/21 全球购物
C语言怎样定义和声明全局变量和函数最好
2013/11/26 面试题
护理自荐信
2013/10/22 职场文书
坚定理想信念心得体会
2014/03/11 职场文书
公司新年寄语
2014/04/04 职场文书
《欢乐的泼水节》教学反思
2014/04/22 职场文书
大学生标准自荐书
2014/06/15 职场文书
2015教师节师德演讲稿
2015/03/19 职场文书
太行山上观后感
2015/06/05 职场文书
幼儿园大班教育随笔
2015/08/14 职场文书
2019年七夕情人节浪漫祝福语大全!
2019/08/08 职场文书