tornado 02 输出、输入和URL传参
tornado 02 输出、输入和URL传参
一、输出
write输出到页面
#write可以接受的对象 #write() 可以接受3种对象:bytes Unicode字符(二进制字符) 字典
#如果接收的是字典,会把字典转化为json字符串,因此write也可以接收json字符串
#flush方法 缓冲区
#write会先把内容放到缓冲区,正常情况下,当请求处理完成(也就是整段函数结束后)的时候自动把缓冲区的内容输出到浏览器
#但是调用flush方法就可以直接把缓冲区的内容输出到浏览区,不用等待请求处理完成
class IndexHandler(tornado.web.RequestHandler):
def get(self):
self.write('dage') #字符串
self.write('<br>')
self.write(b'xuchengcheng') #二进制
self.write('<br>')
self.flush() #如果有flush,文件就会把内容立即冲刷到浏览器当中去
import time #导入time模块
time.sleep(3) #休息3秒钟后冲刷,后面的内容就会在3S后冲刷出来
di = {
'name':'xuchengcheng',
'age':''
}
self.write(di) #字典,当打印字典时候不会解析上面的br,同时排版改变了 import json
li=['xucc',18] #列表原来是不能被解析
li=json.dumps(li) #通过json把li转变为json字符串,然后就可以被解析了
self.write(li)
输出一个html页面
#template_path='templates'
#想要 Tornado 能够正确的找到 html 文件,需要在 Application 中指定文件的位置 class TemHandler(tornado.web.RequestHandler):
def get(self):
self.render('lesson2.html') #通过 render 可以返回一个 html 文件
class TemHandler(tornado.web.RequestHandler):
def get(self):
self.render('lesson2.html') #通过render可以返回一个同级目录文件夹下面的html文件 application = tornado.web.Application(
handlers=[
(r'/index',IndexHandler),
(r'/tem',TemHandler)
],
template_path = 'templates' #必须是在同级目录,前面是固定的,后面的是自己定义的文件夹
)
跳转路由
class RecHandler(tornado.web.RequestHandler):
def get(self):
self.redirect('/index') #打开rec路由会自动跳转到index路由下面 application = tornado.web.Application(
handlers=[
(r'/index',IndexHandler),
(r'/tem',TemHandler),
(r'/rec',RecHandler),
],
template_path = 'templates'
)
finish
class IndexHandler(tornado.web.RequestHandler):
def get(self):
self.write('dage')
self.write('<br>')
self.write(b'xuchengcheng')
self.write('<br>')
self.flush()
import time
time.sleep(3) #
di = {
'name':'xuchengcheng',
'age':''
}
self.write(di)
self.finish() #当调用 finish 之后,请求处理完成,类似于函数中的 return (注意:请求当中不能出现return) ,其后不能再执行 write ,否则会报错;但是后面的程序仍然是执行的,只是会报错 import json
li=['xucc',18]
li=json.dumps(li)
self.write(li)
二、 获取请求信息
class ReqHandler(tornado.web.RequestHandler):
def get(self):
self.write(self.request.remote_ip) #获取virtualbox(也就是访问人)的ip地址
print(self.request) #可以获取信息
print(self.request.remote_ip) #客户端的ip地址,返回值类型为字符串
print(self.request.request_time()) #返回此请求执行所花费的时间
print(self.request.full_url()) #重新构建此请求的完整URL
print(self.request.uri) #请求的完整uri
print(self.request.path) #路径部分的uri
print(self.request.query) #查询部分的uri
print(self.request.version) #请求中指定的HTTP版本,例如“HTTP/1.1”
自动重启服务
application = tornado.web.Application(
handlers=[
(r'/index',IndexHandler),
(r'/tem',TemHandler),
(r'/rec',RecHandler),
(r'/req', ReqHandler),
],
template_path = 'templates',
debug=True #自动重启服务(改完代码之后不用重新打开python文件),方便平时调试用的,在工作的时候禁用
)
三、输入
class GetHandler(tornado.web.RequestHandler):
def get(self): #获取url数据
name = self.get_argument('name','no')
self.write(name)
print(name)
name = self.get_arguments('name') #返回值是一个列表
print(name)
print(self.get_query_argument('name','no')) #获取地址栏的参数 def post(self, *args, **kwargs): #获取body数据
name = self.get_argument('name','no')
password = self.get_argument('password','no')
self.write(name)
self.write(password)
print(self.get_body_argument('name','no')) #获取form表单请求的内容,可以用get_arguments代替掉
#任何数据都可以用get_argument来获取到
四、URL传参
#REST风格传参 class SubjectHandler(tornado.web.RequestHandler):
def get(self,name,age): #下面的正则按照这里的位置来定义的
self.write('name:%s<br> age:%s'%(name,age)) class UserHandler(tornado.web.RequestHandler):
def get(self,age,name):
self.write('name:%s<br> age:%s'%(name,age)) application = tornado.web.Application(
handlers=[
(r'/index',IndexHandler),
(r'/tem',TemHandler),
(r'/rec',RecHandler),
(r'/req', ReqHandler),
(r'/get', GetHandler),
(r'/sub/(.+)/([0-9]+)', SubjectHandler), #用正则表达式(元字符+数字)
(r'/user/(?P<name>.+)/(?P<age>[0-9]+)', UserHandler), #这样就不是按照位置来传参了,而是按照变量名来传参了
],
template_path = 'templates',
debug=True
)
#查询字符串
#查询字符串通过在路由后面添加?再加上参数名和参数值来传入参数
#例子tem?name=xuchengcheng&name=lalala 的形式来传参 #REST
#通过/来分割每个参数,关键在于get方法定义
#还有就是tem?name=xuchengcheng&name=lalala 的形式来传参
tornado 02 输出、输入和URL传参的更多相关文章
- 02模板渲染和参数(补充:URL传参到视图)
先抛出代码: @app.route('/') def index(): return render_template('index.html',username ="郑勇") 问题 ...
- 点击div 跳转并通过URL传参
点击div前要先给div绑定要传的参数: //给panel绑定自定义属性,方便在跳转时传带参数,键/值对排列 panel.attr("user_age",user_age); pa ...
- 关于url传参中文乱码问题
之前都一直很不了解中文编码得问题,之前在做项目中没碰到那么头痛的问题.所以一直没有了解中文乱码的问题. 问题描述: 地址: http://localhost:8080/sun-government/c ...
- Silverlight项目笔记8:层次布局、客户端读取shp、ExecuteCountAsync、柱状图、url传参
1.层次布局 由于地图窗口和菜单栏都在一个父容器内,在浏览器缩小到一定程度点击地图弹出infoWindow时,会出现菜单栏遮挡infoWindow中间部分的现象,于是通过设置Canvas.ZIndex ...
- 浏览器URL传参最大长度问题
这几天为解决一个BUG头疼了一段时间,BUG现象如下: 一个选择人员的选择控件,当选择多个人时(50多个的时候),返回没有错误现象,而再一次打开的时候就报404错误.看到这个错误非常纳闷,无法下手,只 ...
- 关于微信浏览不能URL传参,URL中的问号被删除
关于微信浏览不能URL传参,URL中的问号被删除. 尼玛难道没有人遇到过这个问题?看了微信支付SDK3.0的代码,看到urlencode 看到了几次.实际上 在微信浏览器下 header('locat ...
- url传参后获取参数
当我们通过url传参跳转到其他页面,如: http://www.xxx.com/content.html?id=217&name=txf&phone=15829087165 在跳转后的 ...
- url传参中文乱码解决
url传参request.setCharacterEncoding("utf-8");无法解决中文乱码问题 解决方法: 修改tomcat---conf----server.xml文 ...
- URL传参时中文参数乱码的解决方法
URL传参时,中文参数乱码的解决: 今天在工作中遇到了这样的一个问题,在页面之间跳转时,我将中文的参数放入到url中,使用location进行跳转传参,但是发现接收到的参数值是乱码.我的代码是这样写的 ...
随机推荐
- XHProf安装使用笔记
编译安装 获取源代码包root@sourcjoy>wget http://pecl.php.net/get/xhprof-0.9.2.tgz解压root@sourcjoy>tar zxf ...
- 在TFS中获取项目,获取最新和上传(迁入)
一.在TFS中获取项目: (1)team (2)connect to team.... (3)选择服务地址,然后close (4)然后映射本地文件夹下载项目 (5)mapped添加映射,在map下就可 ...
- wampserver无法打开http://127.0.0.1/
如果你更换了端口号那么你就应该把相应的端口号也带上,比如localhost:8080(或127.0.0.1:8080)这样应该就可以了,因为只有80端口是默认才不用输入的.
- 线程dump
当应用程序运行变慢或者发生故障时,可能通过分析java的Thread Dumps得到分析他们得到阻塞和存在瓶颈的线程. 线程堆栈是虚拟机中线程(包括锁)状态的一个瞬间状态的快照,即系统在某一个时刻所有 ...
- 434. Number of Segments in a String 字符串中的单词个数
[抄题]: Count the number of segments in a string, where a segment is defined to be a contiguous sequen ...
- opennebula 安装指定参数
[root@opennebula opennebula-]# ./install.sh -u oneadmin -g oneadmin -k -d /home/oneadmin/ -u 指定用户-g ...
- dubbo 相关面试题 有用
调用关系说明: · 0. 服务容器负责启动,加载,运行服务提供者. · 1. 服务提供者在启动时,向注册中心注册自己提供的服务. · 2. 服务消费者在启动时,向注册中心订阅自己所需的服务. · 3. ...
- HighCharts SVN IReport进行PDF报表设计--模板
BOS物流项目笔记第十五天 HIghcharts是很强大的图表绘制插件,它是基于纯js绘制的.当然地,对于图表也会有很多操作了.下面就我工作时遇到的一些比较常见的highcharts的操作进行小结,不 ...
- [算法基础]Big O Notation时间复杂度计算方法
首先一点就是无视任何常量 从最简单的开始 statement; 这段时间复杂度为常数1,所以O(1). 然后 ; i < N; i++ ) statement; 这一段是线性的,则时间复杂度为N ...
- 数据库去重与join连表
join连表删除的效率与检测存在之后删除的效率比,后者的效率低了很多