flask笔记---url、变量规则
1、路由:
route() 装饰器用于把一个函数绑定到一个 URL,可以动态变化 URL 的某些部分,还可以为一个函数指定多个规则,从而方便用户访问与记忆。
例子:
@app.route('/') #调用一个app的route方法
def hello_work(): #定义一个处理方法
return '<h1>hello world</h1>'
@app.route('/test') #创建第二个应用,并指定访问路径
def index():
return 'index page'
全部代码为:
#coding=utf-
from flask import Flask #导入flask类
app = Flask(__name__) #生成该类的一个实例 @app.route('/') #调用一个app的route方法
def hello_work(): #定义一个处理方法
return '<h1>hello world</h1>' @app.route('/test') #创建第二个应用,并指定访问路径
def index():
return 'index page' if __name__ == '__main__': #确保服务器只会在使用python解释器运行代码的情况下运行
#app.debug = True #第一种方式:在应用对象上设置标志
#app.run(host='0.0.0.0') #用host参数,设定全网段可以访问
app.run(debug=True,host='0.0.0.0') #第二种方式:作为参数传递给run方法
执行程序,状态为:
# python hello.py
* Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
* Restarting with stat
192.168.168.80 - - [/Apr/ ::] "GET / HTTP/1.1" -
192.168.168.80 - - [/Apr/ ::] "GET /test HTTP/1.1" -
两次访问在浏览器中的表现为:

2、变量规则:
第一个例子:
"第三个应用:标记url的一部分<username>,它可以添加变量,作为关键字参数传递给函数。"
@app.route('/user/<username>')
def show_user_message(username):
return 'user %s' % username
效果截图:

第二个例子:
"第四个应用"
@app.route('/post/<int:post_id>') #转换器有:int、float、path(和缺省状况相同,也接受/
def show_post(post_id):
return 'post %d' % post_id
效果截图:

第三个例子:
"第五个应用"
@app.route('/get/<float:get_nu>')
def test(get_nu):
return 'the test outcome: %f' % get_nu
效果截图:

至此,全部代码为:
return '<h1>hello world</h1>'
@app.route('/test') #创建第二个应用,并指定访问路径
def index():
return 'index page'
"-------------------------------------二、变量规则例子----------------------------------------"
"第三个应用:标记url的一部分<username>,它可以添加变量,作为关键字参数传递给函数。"
@app.route('/user/<username>')
def show_user_message(username):
return 'user %s' % username
" 第四个应用"
@app.route('/post/<int:post_id>') #转换器有:int、float、path(和缺省状况相同,也接受/
def show_post(post_id):
return 'post %d' % post_id
"第五个应用"
@app.route('/get/<float:get_nu>')
def test(get_nu):
return 'the test outcome: %f' % get_nu
if __name__ == '__main__': #确保服务器只会在使用python解释器运行代码的情况下运行
#app.debug = True #第一种方式:在应用对象上设置标志
#app.run(host='0.0.0.0') #用host参数,设定全网段可以访问
app.run(debug=True,host='0.0.0.0') #第二种方式:作为参数传递给run方法
3、url重定向
第一个例子:
"第六个应用"
@app.route('/redirect/') #行为像文件夹,(若末尾没有斜杠,Flask会自动重定向加上)
def redirect():
return 'The redirect page'
效果:
访问后的效果: 
第二个例子:
"第七个应用"
@app.route('/redirec') #行为像文件,若访问时在末尾加上斜杠,会得到404错误
def redirect():
return 'The second redirect page'
效果:
末尾加上斜杠后的效果:
至此,全部代码为:
#coding=utf-
from flask import Flask #导入flask类
app = Flask(__name__) #生成该类的一个实例 "------------------------------------一、URL例子--------------------------------------------"
@app.route('/') #调用一个app的route方法
def hello_work(): #定义一个处理方法
return '<h1>hello world</h1>' @app.route('/test') #创建第二个应用,并指定访问路径
def index():
return 'index page' "-------------------------------------二、变量规则例子----------------------------------------"
"第三个应用:标记url的一部分<username>,它可以添加变量,作为关键字参数传递给函数。"
@app.route('/user/<username>')
def show_user_message(username):
return 'user %s' % username " 第四个应用"
@app.route('/post/<int:post_id>') #转换器有:int、float、path(和缺省状况相同,也接受/
def show_post(post_id):
return 'post %d' % post_id "第五个应用"
@app.route('/get/<float:get_nu>')
def test(get_nu):
return 'the test outcome: %f' % get_nu "--------------------------------------三、唯一的URL/重定向行为-----------------------------"
#"第六个应用
#@app.route('/redirect/') #行为像文件夹,(若末尾没有斜杠,Flask会自动重定向加上)
#def redirect():
# return 'The redirect page'
#"
"第七个应用"
@app.route('/redirec') #行为像文件,若访问时在末尾加上斜杠,会得到404错误
def redirect():
return 'The second redirect page' if __name__ == '__main__': #确保服务器只会在使用python解释器运行代码的情况下运行
#app.debug = True #第一种方式:在应用对象上设置标志
#app.run(host='0.0.0.0') #用host参数,设定全网段可以访问
app.run(debug=True,host='0.0.0.0') #第二种方式:作为参数传递给run方法
flask笔记---url、变量规则的更多相关文章
- Flask变量规则(构建动态url)
原文出处: http://codingdict.com/article/4867 可以通过将可变部分添加到规则参数来动态构建URL.这个变量部分被标记为 < variable-name>. ...
- Flask内置URL变量转换器
Flask内置URL变量转换器: 转换器通过特定的规则执行,”<转换器: 变量名>”.<int: year>把year的值转换为证书,因此我们可以在视图函数中直接对year变量 ...
- <玩转Django2.0>读书笔记:URL规则和视图
1. 带变量的URL #urls.py from django.urls import path from .view import * urlpatterns = [ path('',index_v ...
- flask笔记(三)Flask 添加登陆验证装饰器报错,及解析
Flask 添加登陆验证装饰器报错,及解析 写这个之前,是想到一个需求,这个是关于之前写Flask笔记(二)中的一个知识点,路由相关 需求为 : 有一些页面必须是登陆之后才能访问的,比如Shoppin ...
- Flask笔记1
Flask笔记 首先明确一下,要运行一个动态网页,我们需要 一个 Web 服务器来监听并响应请求,如果请求的是静态文件它就直接将其返回,如果是动态 url 它就将请求转交给 Web 应用. 一个 We ...
- Nginx应用-Location路由反向代理及重写策略 请求转发-URL匹配规则 NGINX Reverse Proxy
NGINX Docs | NGINX Reverse Proxy https://docs.nginx.com/nginx/admin-guide/web-server/reverse-proxy/ ...
- 使Flask的url支持正则表达式以及一个api小demo
from flask import Flask from flask import jsonify from flask import request from werkzeug.routing im ...
- ES6学习笔记之变量的解构赋值
变量的解构赋值 ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构. 数组的解构赋值 以前,为变量赋值,只能直接指定值: 1 2 3 var a = 1; var b = 2; ...
- Django和Flask对于URL尾斜杠(back slash)的处理
最近在看Flask,其中提到了对于URL尾斜杠的处理.感觉算是一个需要注意的地方吧,就和Django的处理方式来进行一个简单的对比. 首先说下什么是尾斜杠. http://www.baidu.com/ ...
随机推荐
- 【POJ 1556】The Doors 判断线段相交+SPFA
黑书上的一道例题:如果走最短路则会碰到点,除非中间没有障碍. 这样把能一步走到的点两两连边,然后跑SPFA即可. #include<cmath> #include<cstdio> ...
- 使用maven镜像
maven 的安装目录下的 conf 文件夹下有个 settings.xml 文件,编辑该文件 在<mirrors>中插入: <mirror> <id>repo2& ...
- httpclient提示Cookie rejected: violates RFC 2109: domain must start with a dot
使用httpclient时发生如下告警信息: WARN - HttpMethodBase.processResponseHeaders(1505) | Cookie rejected: "$ ...
- Spring Assert 断言
Assert(断言)的初步理解构思 Web 应用在接受表单提交的数据后都需要对其进行合法性检查,如果表单数据不合法,请求将被驳回.类似的,当我们在编写类的方法时,也常常需要对方法入参进行合 法性检查, ...
- 进程间通信方式与Binder机制原理
1, Intent隐式意图携带数据 2, AIDL(Binder) 3, 广播BroadCast 4, 内容提供者ContentProvider --------------------------- ...
- 【POJ 3177】Redundant Paths(边双连通分量)
求出每个边双连通分量缩点后的度,度为1的点即叶子节点.原图加上(leaf+1)/2条边即可变成双连通图. #include <cstdio> #include <cstring> ...
- Trinity min_kmer_cov
A high min_kmer value was used to reduce noise in the assembly and to identify only transcripts that ...
- ActiveMQ;RabbitMQ;ZeroMQ
中间件类型: Embedded middleware: As the name suggests, this typeof middleware handles embedded applicatio ...
- 控制div位于最上层
前提: 设置了position属性,且为relative,absolute或是fixed: 设置z-index,数值越大,越上,-1为最底层,99999为最顶层
- PHP Multipart/form-data remote dos Vulnerability
catalog . Description . Analysis 1. Description PHP is vulnerable to a remote denial of service, cau ...