1、安装虚拟环境
mosson@mosson:~$ sudo apt-get install virtualenv
2、创建一个项目目录
mosson@mosson:~$ mkdir myproject
3、进入项目目录
mosson@mosson:~$ cd myproject/
4、利用虚拟环境创建目录
mosson@mosson:~/myproject$ virtualenv venv
5、开启环境
mosson@mosson:~/myproject$ source /spider/bin/activate
效果:
(venv) mosson@mosson:~/myproject$

这个带有(venv)的是一个虚拟的环境 可以在环境里安装你需要的flask的版本,其他各种的软件包,不会与根下的python包有冲突

6、退出虚拟环境:

(venv) mosson@mosson:deactivate

二、简单的demo

1、'hello world'

.py文件

from flask import Flask
from flask import request app = Flask(__name__) @app.route('/')
def hello_world():
return 'Hello World!'
if __name__ == '__main__':
app.run()

访问方式:

demo2

.py

from flask import Flask
from flask import request app = Flask(__name__) @app.route('/user/<name>')
def user(name):
return '<h1>Hello %s </h1>' % name if __name__ == '__main__':
app.run()

访问方式

demo3:查看浏览器请求头中的 "User_Agent"信息

from flask import Flask
from flask import request app = Flask(__name__) @app.route('/')
def index():
user_agent = request.headers.get('User-Agent')
return '<p>Your browser is %s</p>'%user_agent if __name__ == '__main__':
app.run()

任何时候一个请求来到Flask就会激活(或者称作pushes)application context和request contexts,当请求结束再销毁它们。这意味着请求到来的时候,你可以在当前线程中获取到current_app和g,类似地reqeust和session也能被获取到。当没有激活的application context或者request context的时候,获取这些变量会报错。

如下示例证明了application context是如何工作的:

>>> from hello import app
>>> from flask import current_app
>>> current_app.name
Traceback (most recent call last):
...
RuntimeError: working outside of application context
>>> app_ctx = app.app_context()
>>> app_ctx.push()
>>> current_app.name
'hello'
>>> app_ctx.pop()

默认直接使用current_app.name是会报错的,

直到我们调用了app的app_ctx的push或pop方法改变了current_app的值。

注:这里把push和pop当做一个往current_app写入、推出application context的方法,而不要跟常见的数组的操作方法混淆了。

 

3、在前端页面中访问函数

url_for('.函数名')     提示:别忘了括号里面的点

函数实例:

from flask import Flask,render_template
from flask import request app = Flask(__name__) @app.route('/services')
def services():
return 'Services'
@app.route('/about')
def about():
return 'About' if __name__ == '__main__':
app.run(debug=True)

效果展示:

点击 Services 或者 About 都会跳转到相应的函数里

4 、正则匹配路由

先定义一个正则转换器:

from werkzeug.routing import BaseConverter
class RegexConverter(BaseConverter):
def __init__(self, url_map, *items):
super(RegexConverter, self).__init__(url_map)
self.regex = items[0]

设置 正则转换器的名字  : regex

app.url_map.converters['regex'] = RegexConverter

在路由里写上正则:

@app.route('/user/<regex("[a-z]{3}"):user_id>')
def user(name):
return '<h1>Hello %s </h1>' % name

常见的 HTTP 方法:

get:

浏览器告知服务器:只获取页面上的信息并发给我

这是最常用的方法

post:

浏览器告诉服务器:想在url上发布新信息,并且

服务器必须确保 数据已存储且存储一次

这是 HTML 表单通常发送数据到服务器

put:

类似 post 但是服务器可能触发了存储过程多次,多次覆盖旧的值

原因:

  传输过程中连接可能会丢失

  这种情况下,浏览器的服务器之间的系统可能安全地第二次接收请求,而不破坏其他的东西

  post 只触发一次,所以 用 post 是不可能

delete:

删除给定位置的信息

head

浏览器告诉服务器:欲获取信息,但是只关心,消息头

应用应像 GET  请求一样来处理,但是不分发实际内容

在 flask中 你完全无需人工干预

底层的 Werkzeug 库已经替我们处理好了

options

给客户端提供一个敏捷的途径来弄清楚这个 url 支持 哪些 HTTP 方法

从 flask 0.6 开始 实现里自动处理