因为扫描器的准备使用Flask框架,所以开始恶补Flask和前后端的知识

Flask是一个使用Python编写的轻量级Web应用框架,作者是 Armin Ronacher(他也是 Werkzeug 及 Jinja2 的作者。)。本来只是作者的一个愚人节玩笑,不过后来大受欢迎,进而成为一个正式的项目。

我们使用pip来安装flask

pip install flask

  因为我python2和python3共存,所以这里我是pip3 install flask,都差不多

因为flask的版本更新迭代比较快,可能会有两个项目分别基于不同的flask版本开发的,如果想要两个项目都能正常运行,可以使用python的虚拟环境来解决这个问题。

暂时我还没有遇到这个问题,所以没有使用虚拟环境。

第一个Flask程序

from flask import Flask

app=Flask(__name__)

@app.route('/')
def hello_world():
return "hello world!" if __name__=='__main__':
app.run()  

这里的

from flask import Flask

  是从flask框架中导入Flask这个类

接着我们需要初始化一个Flask对象,即初始化为app。

传递__name__参数的好处有:

  1,方便flask框架去寻找资源

  2,方便flask插件比如Flask-Sqlalchemy出现错误的时候,好去寻找问题所在的位置

@app.route是一个装饰器,以@开头,并且在函数的上面,作用是做一个url与视图函数的映射

比如说在上面的第一个flask代码里面,hello_world就是这个视图函数,因为是@app.route('/'),所以url代表的就是127.0.0.1:5000/

app.run()即启动一个应用服务器,一直监听本地的5000端口,来接收用户的请求。

这时候因为默认是127.0.0.1:5000开启服务,我们访问一下,可以看到页面上已经输出了hello world!

但是如果我们修改return 的值时,比如:

@app.route('/')
def hello_world():
return "baidu.com"

  刷新127.0.0.1:5000页面,显示的还是之前的hello world!

也就是说我们修改的文件并没有即时地反馈在网页上,需要我们重启服务才可以生效

这里需要引入的就是debug模式,我们开启debug模式:

if __name__=='__main__':
app.run(debug=True)

  这时候在代码里面进行修改并保存了之后,在debug模式为True的情况下,不需要重启服务,在检测到代码被修改之后,应用服务器就会自动重启服务,方便我们进行调试,除此之外,在代码中出错,debug模式下也会将相应的错误信息显示在网页上,在我们开发的过程中很方便,但服务上线了之后就应当将debug服务关闭,避免详细的错误信息暴露服务器的配置情况。

更好的方式是我们将debug=True写在配置文件中,新建config.py,在里面写入

DEBUG=True

  同时在主app文件中导入这个文件,并且配置到Flask实例化对象app中

import config
app.config.from_object(config)

  另外后面我们用到很多参数,也都可以放在config.py文件中统一配置,比如SECRET_KEY和SQLALCHEMY等等。

在网页的浏览中,我们常常会传入参数对网页进行访问,比如/page/1,是网站文章的第一页,/page/2/,是网站文章的第二页,修改/page/后面的数字,访问到网站不同的页面,就需要用到url传参。

参数的作用已经很明显了,可以在相同的url,指定不同的参数来加载不同的数据

使用参数的方法:

@app.route('/page/<id>')
def page(id):
return "你访问的参数是"+id

  

很多时候我们会用到反转URL,反转URL即从视图函数到url的转换,其作用是:

  1,在页面重定向的时候,会使用url反转

  2,在模板中,也会使用url反转

比如说我们在登录了网站之后,网站会自动重定向我们到网站的主页,就会使用到url反转,使用方法:

首先需要导入url_for

from flask import url_for

  然后使用url_for函数,就能够获取到视图函数所对应的url

@app.route('/page/')
def page():
return url_for('page')

  这里可以看到页面上返回了/page/即访问的page函数的url

获取到了反转之后的url,我们就会想到重定向到该url。

我们需要导入redirect和url_for

from flask import url_for
from flask import redirect

  我们这里令其访问/的时候跳转到登录界面

@app.route('/')
def hello_world():
login_url=url_for('login')
return redirect(login_url)
return "google.com"

  先使用url_for函数将视图函数反转成url,然后使用redirect重定向到该url去

Flask学习 url和视图的更多相关文章

  1. flask之URL和视图(一)

    1.Flask URL和视图 1.1.第一个flask程序 from flask import Flask #创建一个Flask对象,传递__name__参数进去 app = Flask(__name ...

  2. 【Python】Flask系列-URL和视图笔记

    1.学习目标 熟悉Flask相关知识. 熟悉web开发流程. 能独立开发Flask项目. 2.环境配置 Python虚拟环境安装 因为python的框架更新迭代太快了,有时候需要在电脑上存在一个框架的 ...

  3. 1.Flask URL和视图

    1.1.第一个flask程序 from flask import Flask #创建一个Flask对象,传递__name__参数进去 app = Flask(__name__) #url与视图映射 @ ...

  4. flask第七篇——URL与视图函数的映射

    有兴趣的朋友可以添加微信公众号:自动化测试实战 今天开始就要进入正题了.大家都准备好了吧~ 代码提示 先和大家说个小知识点:有同学后台说输入flask代码pycharm不提示,现在告诉你一个解决方法: ...

  5. Python学习笔记整理总结【Django】【MVC/MTV/路由分配系统(URL)/视图函数 (views)/表单交互】

     一.Web框架概述  Web框架本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. #!/usr/bin/env python # -*- coding:utf-8 ...

  6. Django学习笔记之URL与视图

    视图 视图一般都写在app的views.py中.并且视图的第一个参数永远都是request(一个HttpRequest)对象.这个对象存储了这个http请求的所有信息,其中包括携带的参数以及一些头部信 ...

  7. Python Flask学习笔记之Hello World

    Python Flask学习笔记之Hello World 安装virtualenv,配置Flask开发环境 virtualenv 虚拟环境是Python解释器的一个私有副本,在这个环境中可以安装私有包 ...

  8. Flask 学习篇二:学习Flask过程中的记录

    Flask学习笔记: GitHub上面的Flask实践项目 https://github.com/SilentCC/FlaskWeb 1.Application and Request Context ...

  9. python flask学习(3)

    这次主要学习web表单.学了下,很像是Django的form表单验证.不过有许多的不同.可以说是功能更加碎块化.Django的验证方式是很固定和严谨的,风格完全不同. 尽管Flask的请求对象提供的对 ...

随机推荐

  1. Linux系统下用户如何膝盖FTP用户密码

    其实修改ftp用户密码与修改普通用户的密码的过程是一眼高的其具体步骤如下 1.用root账户登录系统 2.使用passwd命令修改密码: 第一次输入密码后提示:The password fails t ...

  2. MSSQL 高并发下生成连续不重复的订单号

    参考: https://www.cnblogs.com/h-change/p/6699683.html 这里在数据库层面生成的,经测试确实不会重复. 附上自己修改后的版本,这里也可以预先生成一年的记录 ...

  3. netfilter 的扩展功能 helper tftp-nat

    /* 需要对conntrack进行功能扩展的协议,会初始化一个struct nf_conntrack_helper 实例,把该实例注册到Netfilter中管理的全局哈希表中. 查找helper使用的 ...

  4. tcp 输入 简析 转载

    正常来说 TCP 收消息过程会涉及三个队列: Backlog Queue sk->sk_backlog Prequeue tp->ucopy.prequeue Receive Queue  ...

  5. lseek系统调用

    文件的随机读写.目前为止,文件都是顺序访问.读写都是从当前文件的偏移位置开始,然后文件偏移值自动的增加到刚好超出读或者写结束的位置是它为下一次作好准备.在linux中有文件偏移.使得随机访问变得简单, ...

  6. POJ2689 [质数距离] 题解

    质数距离 题目TP门 题目描述 给定两个整数L和R,你需要在闭区间[L,R]内找到距离最接近的两个相邻质数C1和C2(即C2-C1是最小的),如果存在相同距离的其他相邻质数对,则输出第一对. 同时,你 ...

  7. [web安全原理分析]-文件上传漏洞基础

    简介 前端JS过滤绕过 待更新... 文件名过滤绕过 待更新 Content-type过滤绕过 Content-Type用于定义网络文件的类型和网页编码,用来告诉文件接收方以什么形式.什么编码读取这个 ...

  8. .Net orm 开源项目 FreeSql 2.0.0(满意的答卷)

    写在开头 2018年11月头脑发热到今天,一晃已经两年,当初从舒服区走向一个巨大的坑,回头一看后背一凉. 两年时间从无到有,经历数不清的日夜奋斗(有人问花了多长时间投入,答案:全职x2 + 两年无休息 ...

  9. python自动化测试pytest框架

    pytest和unittest都是python中的测试框架,pytest相比unittest 更加的灵活,具体体现在 以下几点 1.写测试方法时不用继承类 2.前置后置放在一起 2.1如果是全局共享的 ...

  10. selenium WebDriver提示Unable to find a matching set of capabilities解决方法

    问题出在:应该将火狐浏览器驱动添加到火狐浏览器安装目录下,并且将火狐浏览器安装目录放在path下面.(出现大意,忘了在火狐浏览器下放其对应的驱动) 亲测以下组合方式可用:   pycharm-comm ...