01: flask基础
1.1 flask介绍
参考博客: https://www.cnblogs.com/sss4/p/8097653.html
1、django、tornado、flask比较
1. Django:1个重武器,包含了web开发中常用的功能、组件的框架;(ORM、Session、Form、Admin、分页、中间件、信号、缓存、ContenType....);
2. Tornado:2大特性就是异步非阻塞、原生支持WebSocket协议;
3. Flask:封装功能不及Django完善,性能不及Tornado,但是Flask的第三方开源组件比丰富;http://flask.pocoo.org/extensions/
2、使用参考
1. 小型web应用设计的功能点不多使用Flask;
2. 大型web应用设计的功能点比较多使用的组件也会比较多,使用Django(自带功能多不用去找插件);
3. 如果追求性能可以考虑Tornado;
3、flask介绍
1. Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架
2. 对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后触发Flask框架
3. 开发人员基于Flask框架提供的功能对请求进行相应的处理,并返回给用户
4. 如果要返回给用户复杂的内容时,需要借助jinja2模板来实现对模板的处理
5. 即:将模板和数据进行渲染,将渲染后的字符串返回给用户浏览器。
6. 如同是 Flask 本身实现的一样。众多的扩展提供了数据库集成、表单验证、上传处理、各种各样的开放认证技术等功能
4、安装
pip install flask
1.2 flask简单使用
1、定义路由
@app.route('/')是装饰器,定义如下:
app.route(rule, options)
rule参数:是绑定URL与函数。
options参数:是可选参数。
2、run() 函数来让应用运行在本地服务器上。定义如下 :
app.run(host, port, debug, options)
host:服务器主机名,默认是127.0.0.1 (localhost),如果设置0.0.0.0可以在本机之外访问。
port:主机端口,默认是5000。
debug:调试模式,默认是false;如果设置true,服务器会在代码修改后自动重新载入。
options:可选参数。
from flask import Flask app = Flask(__name__) @app.route('/')
def hello_world():
return 'Hello World' if __name__ == '__main__':
app.run(debug=True)
flask最简单使用
1.3 路由系统
1、动态路由获取参数
1. request.form # 获取post请求
2. request.values.get('name') 或 request.args.get('name') # 获取post请求数据
3. 访问:http://127.0.0.1:5000/user/zhangsan?name=aaa
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from flask import Flask
from flask import request app=Flask(__name__) @app.route('/user/<name>') #设置url传参数 http://127.0.0.1:5000/user/zhangsan?name=aaa
def first_flask(name): #视图必须有对应接收参数
print(name) # zhangsan
print(request.form) # 获取post请求
print(request.values.get('name')) # 获取get请求中参数
print(request.args.get('name')) # 获取get请求中参数
return 'Hello World' if __name__ == '__main__':
app.run()
flask获取请求参数
2、指定允许的请求方法( @app.route('/login', methods=['GET', 'POST']) )
1. @app.route('/login', methods=['GET', 'POST']) # 指定允许的请求
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from flask import Flask
from flask import request app=Flask(__name__) @app.route('/<path:url>/',methods=['get']) #只允许get请求
def first_flask(url):
print(url) # http://www.baidu.com
return 'Hello World' #response if __name__ == '__main__':
app.run()
指定允许的请求方法
3、反向生成url
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from flask import Flask,url_for
from flask import request #反向生成url
app=Flask(__name__) @app.route('/<path:url>',endpoint='name1')
def first_flask(url):
print(url_for('name1',url=url)) #如果设置了url参数,url_for(别名,加参数)
return 'Hello World' if __name__ == '__main__':
app.run()
反向生成url
4、通过app.add_url_rule()调用路由
http://127.0.0.1:5000/index/
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from flask import Flask,url_for
from flask import request #方式2通过app.add_url_rule()方法的方式调用路由
app=Flask(__name__) def first_flask():
return 'Hello World' app.add_url_rule(rule='/index/',endpoint='name1',view_func=first_flask,methods=['GET'])
#app.add_url_rule(rule=访问的url,endpoint=路由别名,view_func=视图名称,methods=[允许访问的方法])
if __name__ == '__main__':
app.run()
add_url_rule调用路由
5、扩展路由功能:正则匹配url
from flask import Flask, views, url_for
from werkzeug.routing import BaseConverter app = Flask(import_name=__name__) class RegexConverter(BaseConverter):
"""
自定义URL匹配正则表达式
"""
def __init__(self, map, regex):
super(RegexConverter, self).__init__(map)
self.regex = regex def to_python(self, value):
"""
路由匹配时,匹配成功后传递给视图函数中参数的值
:param value:
:return:
"""
return int(value) def to_url(self, value):
"""
使用url_for反向生成URL时,传递的参数经过该方法处理,返回的值用于生成URL中的参数
:param value:
:return:
"""
val = super(RegexConverter, self).to_url(value)
return val # 添加到flask中
app.url_map.converters['regex'] = RegexConverter # http://127.0.0.1:5000/index/9999
@app.route('/index/<regex("\d+"):nid>')
def index(nid):
print(url_for('index', nid='')) # /index/888
print(nid) #
return 'Index' if __name__ == '__main__':
app.run()
正则匹配url
1.4 视图
1、给Flask视图函数加装饰器
注意如果要给视图函数加装饰器,一点要加在路由装饰器下面,才会被路由装饰器装饰
from flask import Flask, views, url_for
from werkzeug.routing import BaseConverter #1、定义1个装饰器
def auth(func):
print('我在上面')
def inner(*args,**kwargs):
return func(*args,**kwargs)
return inner app=Flask(__name__) @app.route('/',methods=['GET'])
@auth #注意如果要给视图函数加装饰器,一点要加在路由装饰器下面,才会被路由装饰器装饰
def first_flask():
print('ffff')
return 'Hello World' if __name__ == '__main__':
app.run()
给Flask视图函数加装饰器
2、request获取请求信息
request.method: 获取请求方法
request.json
request.json.get("json_key"):获取json数据 **较常用
request.argsget('name') :获取get请求参数
request.form.get('name') :获取POST请求参数
request.form.getlist('name_list'):获取POST请求参数列表(多个)
request.values.get('age') :获取GET和POST请求携带的所有参数(GET/POST通用)
request.cookies.get('name'):获取cookies信息
request.headers.get('Host'):获取请求头相关信息
request.path:获取用户访问的url地址,例如(/,/login/,/ index/);
request.full_path:获取用户访问的完整url地址+参数 例如(/login/?age=18)
request.script_root: 抱歉,暂未理解其含义;
request.url:获取访问url地址,例如http://127.0.0.1:5000/?age=18;
request.base_url:获取访问url地址,例如 http://127.0.0.1:5000/;
request.url_root
request.host_url
request.host:获取主机地址
request.files:获取用户上传的文件
obj = request.files['the_file_name']
obj.save('/var/www/uploads/' + secure_filename(f.filename)) 直接保存
3、响应相关信息
return "字符串" :响应字符串
return render_template('html模板路径',**{}):响应模板
return redirect('/index.html'):跳转页面
方式一:响应json数据
return jsonify(user_list) app.config['JSON_AS_ASCII']=False #指定json编码格式 如果为False 就不使用ascii编码,
app.config['JSONIFY_MIMETYPE'] ="application/json;charset=utf-8" #指定浏览器渲染的文件类型,和解码格式;
方式二:响应json数据
return Response(data,mimetype="application/json;charset=utf-8",)
4、如果需要设置响应头就需要借助make_response()方法
from flask import Flask,request,make_response response = make_response(render_template('index.html'))
# response是flask.wrappers.Response类型
response.delete_cookie('key')
response.set_cookie('key', 'value')
response.headers['X-Something'] = 'A value'
return respons
设置响应头
1.4 FBV和CBV
1、CBV使用
http://127.0.0.1:5000/index/
#CBV视图
from flask import Flask,url_for,views
#-----------------------------------------------------
app=Flask(__name__) #装饰器 def auth(func):
print('我在上面')
def inner(*args,**kwargs):
return func(*args,**kwargs)
return inner #--------------------------------------------------------
class IndexView(views.MethodView): #CBV视图
methods=['GET'] #允许的http请求方法(改CBV只允许GET方法)
decorators = [auth,] #每次请求过来都加auth装饰器 def get(self):
return 'Index.GET'
def post(self):
return 'Index.POST' app.add_url_rule('/index/',view_func=IndexView.as_view(name='name1')) #(name='name1'反向生成url别名 if __name__ == '__main__':
app.run()
CBV使用
1.5 使用Jinja2模板
1、模板基本使用
from flask import Flask, render_template app = Flask(__name__) @app.route('/book/')
def show_book_info():
return render_template('book.html', book_name = 'Python从小白到大牛', author='关东升' '') if __name__ == '__main__':
app.run(debug=True)
hello.py
<html>
<body>
<h3>书名:《{{ book_name }}》</h3>
<h3>作者:{{ author }}</h3>
</body>
</html>
templates/book.html
2、Jinja2中使用表达式
from flask import Flask, render_template app = Flask(__name__) @app.route('/hello/<name>')
def hello(name):
s1 = "Long long ago, there's a girl named betty! She was 5 years old."
s2 = " " + s1 + " "
s3 = "<p>" + s1 + "</p>"
return render_template('hello.html', name=name, message=(s1, s2, s3)) if __name__ == '__main__':
app.run(debug=True)
hello.py
<html>
<body>
<h3>1+1 = {{ 1+1 }}</h3>
<h3>name变量:{{ name }}</h3>
<h3>name首字母大写:{{ name|capitalize }}</h3>
<h3>name小写:{{ name|lower }}</h3>
<h3>name大写:{{ name|upper }}</h3>
<h3>所有单词首字母大写:{{ message[0]|title }}</h3>
<h3>去除前后空格:{{ message[1]|trim }}</h3>
<h3>去除html标签:{{ message[2]|striptags }}</h3>
<h3>字符串不转义:{{ message[2]|safe }}</h3>
</body>
</html>
templates/hello.html
3、Jinjia2模板中语句
from flask import Flask, render_template app = Flask(__name__) @app.route('/book/<float:price>')
def show_book_price1(price):
info = '''
书名:《Python从小白到大牛》
作者:关东升
'''
return render_template('book_info.html', price=price, info=info) @app.route('/book/<int:price>')
def show_book_price2(price):
info = '''
书名:《Python从小白到大牛》
作者:关东升
'''
return render_template('book_info.html', price=price, info=info) @app.route('/book/')
def show_book_info():
book1 = {"bookname": "Python从小白到大牛", "author": "关东升"}
book2 = {"bookname": "Java从小白到大牛", "author": "关东升"}
book3 = {"bookname": "Kotlin从小白到大牛", "author": "关东升"}
list = []
list.append(book1)
list.append(book2)
list.append(book3)
return render_template('books.html', book_list=list) if __name__ == '__main__':
app.run(debug=True)
hello.py
<!DOCTYPE html>
<html>
<head>
<title>图书信息</title>
</head>
<body>
{% for book in book_list %}
<h3>书名:《{{ book.bookname }}》</h3>
<h3>作者:{{ book.author }}</h3>
<hr>
{% endfor %}
</body>
</html>
templates/books.html
<!DOCTYPE html>
<html>
<head>
<title>图书信息</title>
</head>
<body>
<h3>{{ info }}</h3>
{% if price <= 50.0 %}
<h3>很便宜哦!</h3>
{% else %}
<h3>好贵哦!</h3>
{% endif %}
</body>
</html>
templates/book_info.html
4、模板继承 & 访问静态文件
from flask import Flask, render_template app = Flask(__name__) @app.route('/book/login')
def login():
return render_template('login.html') @app.route('/book/reg')
def register():
return render_template('registration.html') if __name__ == '__main__':
app.run(debug=True)
hello.py
#footer,#header {
text-align: center;
} td.label {
text-align: right;
}
static/css/book.css
book_img1.jpg
book_img2.jpg
static/images/两张图片
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>图书管理系统-{% block title %}{% endblock %}</title>
<link rel="stylesheet" type="text/css" href="{{ url_for('static', filename = 'css/book.css') }}">
</head> <body>
<!-- 页面头部信息 -->
<div id="header">
<img src="{{ url_for('static', filename = 'images/book_img2.jpg') }}" width="20px" height="20px">
{% block header %}{% endblock %}
<hr/>
</div>
<!-- 页面内容信息 -->
<div id="content">
{% block body %}
{% endblock %}
</div>
<!-- 页面底部信息 -->
<div id="footer">
<hr/>
Copyright © 智捷课堂 2008-2018. All Rights Reserved
</div> </body>
</html>
templates/base.html
{% extends "base.html" %}
{% block title %}用户登录{% endblock %}
{% block header %}用户登录{% endblock %}
{% block body %}
<table width="40%" border="0">
<tbody>
<tr>
<td>用户ID:</td>
<td><input type="text"/></td>
</tr>
<tr>
<td>密码:</td>
<td><input type="password"/></td>
</tr>
<tr align="center">
<td colspan="2">
<input type="submit" value="确定">
<input type="reset" value="取消">
</td>
</tr>
</tbody>
</table>
{% endblock %}
templates/login.html
{% extends "base.html" %}
{% block title %}用户注册{% endblock %}
{% block header %}用户注册{% endblock %}
{% block body %}
<table width="40%" border="0">
<tbody>
<tr>
<td class="label">用户名:</td>
<td><input type="text"/></td>
</tr>
<tr>
<td class="label">密码:</td>
<td><input type="password"/></td>
</tr>
<tr>
<td class="label">再次输入密码:</td>
<td><input type="password"/></td>
</tr>
<tr>
<td class="label">邮箱:</td>
<td><input type="text"/></td>
</tr>
<tr align="center">
<td colspan="2">
<input type="submit">
<input type="reset">
</td>
</tr>
</tbody>
</table>
{% endblock %}
templates/registration.html
1.6 cookie和session操作
1、设置和获取cookie
set_cookie('userid', 'tony', expires=timeoutdate) # 设置cookie http://127.0.0.1:5000/setcookie
request.cookies.get('userid') # 获取cookie http://127.0.0.1:5000/getcookie
from flask import Flask, make_response, request
from datetime import datetime, timedelta app = Flask(__name__) @app.route('/setcookie')
def set_cookie():
response = make_response('<h1>设置Cookie')
timeoutdate = datetime.today() + timedelta(days=10)
# response.set_cookie('userid', 'tony')
response.set_cookie('userid', 'tony', expires=timeoutdate)
return response @app.route('/getcookie')
def get_cookie():
name = request.cookies.get('userid')
s = '<h1>Cookie中userid:{0}</h1>'.format(name)
return s if __name__ == '__main__':
app.run(debug=True)
hello.py 设置&获取cookie
2、使用session登录注销
from flask import Flask, render_template, request, session app = Flask(__name__)
app.secret_key = '任何不容易被猜到的字符串' @app.route('/')
def index():
return render_template('login.html') @app.route('/login', methods=['GET', 'POST'])
def login():
if request.method == 'POST':
session['userid'] = request.form['userid']
return render_template('result.html') @app.route('/logout')
def logout():
session.pop('userid', None)
return render_template('result.html') if __name__ == '__main__':
app.run(debug=True)
hello.py
#footer,#header {
text-align: center;
} td.label {
text-align: right;
}
static/css/book.css
book_img1.jpg
book_img2.jpg
static/images/两张图片
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>图书管理系统-{% block title %}{% endblock %}</title>
<link rel="stylesheet" type="text/css" href="{{ url_for('static', filename = 'css/book.css') }}">
</head> <body>
<!-- 页面头部信息 -->
<div id="header">
<img src="{{ url_for('static', filename = 'images/book_img2.jpg') }}" width="20px" height="20px">
{% block header %}{% endblock %}
<hr/>
</div>
<!-- 页面内容信息 -->
<div id="content">
{% block body %}
{% endblock %}
</div>
<!-- 页面底部信息 -->
<div id="footer">
<hr/>
Copyright © 智捷课堂 2008-2018. All Rights Reserved
</div> </body>
</html>
templates/base.html
{% extends "base.html" %}
{% block title %}用户登录{% endblock %}
{% block header %}用户登录{% endblock %}
{% block body %}
<form action = "/login" method = "POST">
<table width="40%" border="0">
<tbody>
<tr>
<td>用户ID:</td>
<td><input name="userid" type="text"/></td>
</tr>
<tr>
<td>密码:</td>
<td><input name="userpwd" type="password"/></td>
</tr>
<tr align="center">
<td colspan="2">
<input type="submit" value="确定">
<input type="reset" value="取消">
</td>
</tr>
</tbody>
</table>
</form>
{% endblock %}
templates/login.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>运行结果</title>
</head>
<body>
<h3>存储在Session中的userid数据:{{ session['userid'] }}</h3>
<h3><a href="/logout">Logout</a></h3>
</body>
</html>
templates/result.html
1.7 图片上传预览
from flask import Flask, render_template, request, redirect, url_for, send_from_directory
from werkzeug.utils import secure_filename
import os app = Flask(__name__)
app.config['UPLOAD_FOLDER'] = 'C:/desktop_Important_Document/flask/code/code'
# app.config['MAX_CONTENT_LENGTH'] = 1 * 1024 * 1024 # 小于1M @app.route('/')
def index():
return render_template('upload.html') @app.route('/upload', methods=['GET', 'POST'])
def upload():
if request.method == 'POST':
f = request.files['myfile']
filename = secure_filename(f.filename)
f.save(os.path.join(app.config['UPLOAD_FOLDER'], filename))
return redirect(url_for('uploaded_file',
filename=filename)) @app.route('/uploaded/<filename>')
def uploaded_file(filename):
return send_from_directory(app.config['UPLOAD_FOLDER'],
filename) if __name__ == '__main__':
app.run(debug=True)
hello.py
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>上传文件</title>
</head>
<body>
<form action="/upload" method="POST"
enctype="multipart/form-data">
<input type="file" name="myfile"><br><br>
<input type="submit" name="开始上传">
</form>
</body>
</html>
upload.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>上传结果</title>
</head>
<body>
<h1>{{ result }}</h1>
<img src="{{ path }}">
</body>
</html>
result.html
1.8 Flask-Migrate 数据库操作
1、安装相关包
pip install Flask==0.11.1
pip install Flask-Script==2.0.5
pip install Flask-Migrate==1.8.0
pip install Flask-SQLAlchemy==2.2
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_script import Manager
from flask_migrate import Migrate, MigrateCommand app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///app.db' db = SQLAlchemy(app)
migrate = Migrate(app, db) manager = Manager(app)
manager.add_command('db', MigrateCommand) class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(128)) if __name__ == '__main__':
manager.run()
manage.py 单文件测试数据库创建
2、相关文件
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from flask_script import Manager
from flask_migrate import Migrate, MigrateCommand
from platform import app
from exts import db
from models import User, Question, Answer manager = Manager(app) # 使用Migrate绑定app和db
migrate = Migrate(app, db) # 添加迁移脚本的命令到manager中
manager.add_command('db', MigrateCommand) if __name__ == '__main__':
manager.run()
manage.py
#! /usr/bin/env python
# -*- coding: utf-8 -*-
import os DEBUG = True SECRET_KEY = os.urandom(24) SQLALCHEMY_DATABASE_URI = 'mysql://root:1@localhost/testdb'
SQLALCHEMY_TRACK_MODIFICATIONS = True
config.py 配置数据库连接
#! /usr/bin/env python
# -*- coding: utf-8 -*-
from flask_sqlalchemy import SQLAlchemy db = SQLAlchemy()
exts.py 配置flask_sqlalchemy操作数据库
#! /usr/bin/env python
# -*- coding: utf-8 -*- from exts import db
from datetime import datetime class User(db.Model):
__tablename__ = 'user'
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
telephone1 = db.Column(db.String(11), nullable=False)
username = db.Column(db.String(50), nullable=False)
password = db.Column(db.String(100), nullable=False) class Question(db.Model):
__tablename__ = 'question'
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
title = db.Column(db.String(100), nullable=False)
content = db.Column(db.Text, nullable=False)
# now()获取的是服务器第一次运行的时间
# now就是每次创建一个模型的时候,都获取当前的时间
create_time = db.Column(db.DateTime, default=datetime.now)
author_id = db.Column(db.Integer, db.ForeignKey('user.id'))
author = db.relationship('User', backref=db.backref('questions')) class Answer(db.Model):
__tablename__ = 'answer'
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
content = db.Column(db.Text, nullable=False)
create_time = db.Column(db.DateTime, default=datetime.now)
question_id = db.Column(db.Integer, db.ForeignKey('question.id'))
author_id = db.Column(db.Integer, db.ForeignKey('user.id'))
question = db.relationship('Question', backref=db.backref('answers', order_by=id.desc()))
author = db.relationship('User', backref=db.backref('answers'))
models.py 表
#! /usr/bin/env python
# -*- coding: utf-8 -*- from flask import Flask, render_template, request, redirect, url_for, session
import config
from models import User, Question, Answer
from exts import db app = Flask(__name__)
app.config.from_object(config)
db.init_app(app) @app.route('/')
def index():
# context = {
# 'questions': Question.query.order_by('-create_time').all()
# }
return 'test '
platform.py 视图函数
3、创建数据库表命令
python manage.py db init # 创建迁移的仓库
Python manage.py db migrate # 创建迁移的脚本
python manage.py db upgrade # 更新数据库
python manage.py runserver # 运行项目
11111111111111111111
01: flask基础的更多相关文章
- 01: tornado基础篇
目录:Tornado其他篇 01: tornado基础篇 02: tornado进阶篇 03: 自定义异步非阻塞tornado框架 04: 打开tornado源码剖析处理过程 目录: 1.1 Torn ...
- flask基础之AppContext应用上下文和RequestContext请求上下文(六)
前言 应用上下文和请求上下文存在的目的,官方文档讲的很清楚,可参考: http://www.pythondoc.com/flask/appcontext.html 应用上下文对象在没有请求的时候是可以 ...
- flask基础之请求处理核心机制(五)
前言 总结一下flask框架的请求处理流程. 系列文章 flask基础之安装和使用入门(一) flask基础之jijia2模板使用基础(二) flask基础之jijia2模板语言进阶(三) flask ...
- flask基础之app初始化(四)
前言 flask的核心对象是Flask,它定义了flask框架对于http请求的整个处理逻辑.随着服务器被启动,app被创建并初始化,那么具体的过程是这样的呢? 系列文章 flask基础之安装和使用入 ...
- flask基础之jijia2模板语言进阶(三)
前言 前面学习了jijia2模板语言的一些基础知识,接下来继续深挖jijia2语言的用法. 系列文章 flask基础之安装和使用入门(一) flask基础之jijia2模板使用基础(二) 控制语句 和 ...
- flask基础之jijia2模板使用基础(二)
前言 在以前前后端不分离的时代,后台程序员往往又当爹又当妈,需要将前端程序员写的h5页面填充模板语言.而jijia2是一门十分强大的python的模板语言,是flask框架的核心模块之一.先简单介绍一 ...
- 笔记-flask基础操作
笔记-flask基础操作 1. 前言 本文为flask基础学习及操作笔记,主要内容为flask基础操作及相关代码. 2. 开发环境配置 2.1. 编译环境准备 安装相关Lib ...
- 后端 - Lession 01 PHP 基础
目录 Lession 01 php 基础 1. php 基础 2. php 变量 3. php 单引号 和 双引号区别 4. 数据类型 5. 数据类型转换 6. 常量 7. 运算符 8. 为 fals ...
- Flask基础(16)-->WTForms表单创建和简单验证
Flask基础(16)-->WTForms表单创建和简单验证 前言:使用Flask_WTF需要配置参数SECRET_KEYCSRF_ENABLED是为了CSRF(跨站请求伪造)保护.SECRET ...
随机推荐
- H5页面分享微信自定义分享title和img
前端开发H5 需分享到朋友圈和发给好友,想自定义分享的title和图表还有简短一句话,还需调用微信的api 首先需获取到微信的appId,timestamp,nonceStr,signature 微信 ...
- leetcode473 Matchsticks to Square
一开始想求所有结果为target的组合来着,但是所选元素不能重叠.用这个递归思想很简单,分成四个桶,每次把元素放在任意一个桶里面,最后如果四个桶相等就可以放进去,有一个地方可以剪枝,假如任意一个桶的元 ...
- OpenResty编译安装
从下载页 Download下载最新的 OpenResty® 源码包,并且像下面的示例一样将其解压: tar -xzvf openresty-VERSION.tar.gz VERSION 的地方替换成您 ...
- vue中兄弟组件间 的传值 bus(可以理解为公共交通)
点击大儿子(头部组件的年月日,下面的都要变化) 就相当于点击了年月日之后,下面的组件重新调接口,参数变化 1.首先随便哪儿写个bus.js 内容如下: import Vue from 'v ...
- C# sapnco支持.net 4.5了,真是个意外的发现
意外篇: 需要用C#写一个RFC直连的类库,需要引用sapnco.dll sapnco_utils.dll两个文件 之前都是从网上下载的sapnco3.0,引用开发,在win10机器上使用没有问题 ...
- AutoMapper.Mapper.CreateMap报“System.NullReferenceException: 未将对象引用设置到对象的实例。”异常复现
>>Agenda: >>Ⅰ.国庆假期问题出现 >>Ⅱ.双休日异常再次出现 >>Ⅲ.排障 >>Ⅳ.异常复盘 >>Ⅴ.修复后监测 & ...
- MySQL.配置MariaDB的字符集
配置MariaDB的字符集 环境: 操作系统:CentOS Linux release 7.x mariadb安装及配置 yum install mariadb-server mariadb #安装 ...
- React项目中使用Mobx状态管理(二)
并上一节使用的是普通的数据状态管理,不过官方推荐使用装饰器模式,而在默认的react项目中是不支持装饰器的,需要手动启用. 官方参考 一.添加配置 官方提供了四种方法, 方法一.使用TypeScrip ...
- C#7.0新特性(VS2017可用)
分享一下其实2016年12月就已经公布了的C#7.0的新特性吧,虽然很早就出来了,但咱这IDE不支持啊.. 不过在昨天的VS2017中已经完美可以支持使用了. E文好的,移步官方介绍地址:https: ...
- 凯撒密码、GDP格式化输出、99乘法表
1.恺撒密码的编码 s=input('明文:') print('密文:',end='') for i in s: print(chr(ord(i)+3),end='') 附加: print('字符串的 ...