Tornado框架使用http的GET方式传输中文汉字的简单实作

最近业余时间在看Tornado框架的使用,虽然维基百科「Comparison of web application frameworks」把Tornado黑的不行,但上手确实很简单

这个教程的第二个例子

import textwrap

import tornado.httpserver
import tornado.ioloop
import tornado.options
import tornado.web

from tornado.options import define, options
define("port", default=8000, help="run on the given port", type=int)

class ReverseHandler(tornado.web.RequestHandler):
    def get(self, input):
        self.write(input[::-1] + '\n')

class WrapHandler(tornado.web.RequestHandler):
    def post(self):
        text = self.get_argument('text')
        width = self.get_argument('width', 40)
        self.write(textwrap.fill(text, int(width)) + '\n')

class FindbrandHandler( tornado.web.RequestHandler ):
    def get(self, input):
        input_dcds = input.split('_')
        input_dcd = u''
        for elem in input_dcds:
            if len(elem)>0:
                input_dcd += unichr( int(elem) )
        print input_dcd.encode('utf-8')

        o_str = 'input: '+input_dcd.encode('utf-8') + '\noutput: getcha\n'
        self.write( o_str )

if __name__ == "__main__":
    tornado.options.parse_command_line()
    app = tornado.web.Application(
        handlers=[
            (r"/reverse/(\w+)", ReverseHandler),
            (r"/wrap", WrapHandler),
            (r"/brand/(\w+)", FindbrandHandler)
        ]
    )
    http_server = tornado.httpserver.HTTPServer(app)
    http_server.listen(options.port)
    tornado.ioloop.IOLoop.instance().start()

例程的逻辑如下:

添加FindbrandHandle类,继承RequestHandler,重写get方法

按照

/brand/(请求内容)

的方式载入web.Application,然后运行。

用curl请求:

curl localhost:9002/reverse/1234567

会得到如下返回

7654321

然而输入中文

curl localhost:9002/reverse/从星星的弹空里

会得到404页

<html><title>404: Not Found</title><body>404: Not Found</body></html>

这是因为http的GET方法,不支持汉语,仅支持字母数字符号。早些年某些浏览器访问百度,也往往看见百度将搜索词,使用urlencode方法,转化为GET方法支持的url字符串。

这里我们使用unichr()和ord()两个函数,实现unicode字符与整形数的转换,发送用下划线间隔的整形数。

这里是客户端例程:

import os
import sys

import nlp_tools as nt

urlstr = 'curl localhost:%d/brand/%s'

if __name__=='__main__':

    n_args = len(sys.argv)

    line = sys.argv[2]

    ecd_data = ''
    for word in line.decode('utf-8'):
        ecd_data += '%d_'%( ord(word) )

    url_request = ''
    if n_args==2:
        url_request = urlstr%( 8000, ecd_data )
    else:
        url_request = urlstr%( int(sys.argv[1]), ecd_data )

    print line
    print url_request

    os.system( url_request )

使用

python call_string_service1.py 9002 从星星的弹空里

调用该脚本,既可查看执行结果:

从星星的弹空里

curl localhost:9002/brand/20174_26143_26143_30340_24377_31354_37324_

input: 从星星的弹空里

output: getcha

本实作使用自写编码方式,简单演示其他url_encode模块的工作原理,实现了中文汉字的传输。

时间: 2024-10-10 16:23:49

Tornado框架使用http的GET方式传输中文汉字的简单实作的相关文章

《连载 | 物联网框架ServerSuperIO教程》- 10持续传输大块数据流的两种方式(如:文件)

1.C#跨平台物联网通讯框架ServerSuperIO(SSIO)介绍 <连载 | 物联网框架ServerSuperIO教程>1.4种通讯模式机制. <连载 | 物联网框架ServerSuperIO教程>2.服务实例的配置参数说明 <连载 | 物联网框架ServerSuperIO教程>- 3.设备驱动介绍 <连载 | 物联网框架ServerSuperIO教程>-4.如开发一套设备驱动,同时支持串口和网络通讯. <连载 | 物联网框架ServerSupe

第二百六十七节,Tornado框架-分页封装模块

Tornado框架-分页封装模块 框架引擎 #!/usr/bin/env python #coding:utf-8 import tornado.ioloop import tornado.web #导入tornado模块下的web文件 from controllers import index settings = { #html文件归类配置,设置一个字典 "template_path":"views", #键为template_path固定的,值为要存放HTML

第二百六十二节,Tornado框架-cookie

Tornado框架-cookie Cookie 是网站用来在客户端保存识别用户的一种小文件.一般来用库可以保存用户登 录信息.购物数据信息等一系列微小信息. self.set_cookie()方法,创建cookie必写参数,cookie名称和cookie值,后面有可选参数self.get_cookie()方法,获取指定cookie值,必写参数要获取的cookie名称 模板引擎 #!/usr/bin/env python #coding:utf-8 import tornado.ioloop im

第二百六十九节,Tornado框架-Session登录判断

Tornado框架-Session登录判断 Session需要结合cookie来实现 Session的理解 1.用户登录系统时,服务器端获取系统当前时间,进行nd5加密,得到加密后的密串 2.将密串作为一个字典的键,值为一个字典,也就是嵌套字典,键为密串的字典里保存用户信息 3.将这个密串当做cookie值写入浏览器 4.当用户访问时,判断值为密串的cookie是否存在,如果存在,获取cookie的值也就是密串,将这个密串在服务端的字典里查找是否存在,如果存在就可以拿到用户保存的各种信息,判断用

第二百六十三也,Tornado框架-基于正则的动态路由映射分页

Tornado框架-基于正则的动态路由映射分页 分页基本显示数据 第一步.设置正则路由映射配置,(r"/index/(?P<page>\d*)", index.indexHandler),正则匹配访问路径,访问录index/后面可以是可以是0个或多个数字第二步.配置逻辑处理方法,get()方法里显示对应的页面,并传值一个SHUJU全局变量列表到html模板,这个全局变量列表里是字典显示的数据第三步.在html模板里用模板语言,循环这个列表里的字典,显示到表格里第四步.设置用

tornado框架——进阶

tornado框架--进阶 自定义Session组件 Session 面向对象基础 面向对象中通过索引的方式访问对象,需要内部实现 __getitem__ .__delitem__.__setitem__方法 class Foo(object): def __getitem__(self, key): print '__getitem__',key def __setitem__(self, key, value): print '__setitem__',key,value def __del

tornado框架的get方法传递参数

tornado框架的get方法传递参数,代码: # encoding: utf-8 """ @version: ?? @author: andu99 @contact: [email protected] @site: http://www.cnblogs.com/andu99/ @software: PyCharm @file: main.py @time: 2018/5/9 0009 上午 11:05 """ from tornado.iol

tornado框架初探

1.tornado概述 Tornado就是我们在 FriendFeed 的 Web 服务器及其常用工具的开源版本.Tornado 和现在的主流 Web 服务器框架(包括大多数 Python 的框架)有着明显的区别:它是非阻塞式服务器,而且速度相当快.得利于其 非阻塞的方式和对epoll的运用,Tornado 每秒可以处理数以千计的连接,因此 Tornado 是实时 Web 服务的一个 理想框架.我们开发这个 Web 服务器的主要目的就是为了处理 FriendFeed 的实时功能 --在 Frie

Tornado框架简介

1.概念:? ? Tornado全称Tornado Web Server,是一个用Python语言写成的Web服务器兼Web应用框架,由FriendFeed公司在自己的网站FriendFeed中使用,被Facebook收购以后框架在2009年9月以开源软件形式开放给大众. 2.特点:? ? 1.作为Web框架,是一个轻量级的Web框架,类似于另一个Python web框架Web.py,其拥有异步非阻塞IO的处理方式. ? ? 2.作为Web服务器,Tornado有较为出色的抗负载能力,官方用ng