# -*- coding:utf-8 -*- from flask import Flask, url_for app1 = Flask(__name__, static_folder='mystatic', static_url_path='/myurl', template_folder='mytemplate')
app2 = Flask(__name__)
app3 = Flask(__name__, static_url_path='') @app1.route('/')
def hello_world():
return 'Hello World!' @app1.route("/css")
def static_css():
return url_for('static', filename='style.css') @app1.route("/js")
def static_js():
return url_for('static', filename='login.js') # @app.route("/ss")
# def static():
# return "hello ss!"
# AssertionError: View function mapping is overwriting an existing endpoint function: static
# 不允许重复定义内部约束方法static if __name__ == '__main__':
print("1--------------------")
print(app1.__dict__)
print app1.view_functions['static'].__dict__
print("2--------------------")
print app2.__dict__
print("3--------------------")
print app3.__dict__
# app1.run()
# app2.run(port=5001)
# app3.run(port=5002)

目录结构


flask_simply_dome
-mystatic
--login.js -->"this is a test login.js"
-static
--login.js -->"this is app3 or app2 login.js"
asimply_app.py
# curl "http://127.0.0.1:5000/css"
/myurl/style.css
# curl "http://127.0.0.1:5000/js"
/myurl/login.js
# curl "http://127.0.0.1:5000/myurl/login.js"
"this is a test login.js" # curl "http://127.0.0.1:5001/static/login.js"
"this is app3 or app2 login.js" # curl "http://127.0.0.1:5002/login.js"
"this is app3 or app2 login.js"

对比各app的属性

1--------------------
{
'subdomain_matching': False,
'error_handler_spec': {},
'_before_request_lock': < thread.lock object at 0x0000000002619D50 > ,
'before_request_funcs': {},
'teardown_appcontext_funcs': [],
'shell_context_processors': [],
'after_request_funcs': {},
'cli': < flask.cli.AppGroup object at 0x0000000002EF0278 > ,
'_blueprint_order': [],
'before_first_request_funcs': [],
'view_functions': {
'static_css': < function static_css at 0x0000000002EF87B8 > ,
'static_js': < function static_js at 0x0000000002EF8828 > ,
'hello_world': < function hello_world at 0x0000000002EF8748 > ,
'static': < bound method Flask.send_static_file of < Flask 'asimply_app' >>
},
'instance_path': 'D:\\myself\\flask_simply_dome\\instance',
'teardown_request_funcs': {},
'url_value_preprocessors': {},
'config': < Config {
'JSON_AS_ASCII': True,
'USE_X_SENDFILE': False,
'SESSION_COOKIE_SECURE': False,
'SESSION_COOKIE_PATH': None,
'SESSION_COOKIE_DOMAIN': None,
'SESSION_COOKIE_NAME': 'session',
'MAX_COOKIE_SIZE': 4093,
'SESSION_COOKIE_SAMESITE': None,
'PROPAGATE_EXCEPTIONS': None,
'ENV': 'production',
'DEBUG': False,
'SECRET_KEY': None,
'EXPLAIN_TEMPLATE_LOADING': False,
'MAX_CONTENT_LENGTH': None,
'APPLICATION_ROOT': '/',
'SERVER_NAME': None,
'PREFERRED_URL_SCHEME': 'http',
'JSONIFY_PRETTYPRINT_REGULAR': False,
'TESTING': False,
'PERMANENT_SESSION_LIFETIME': datetime.timedelta(31),
'TEMPLATES_AUTO_RELOAD': None,
'TRAP_BAD_REQUEST_ERRORS': None,
'JSON_SORT_KEYS': True,
'JSONIFY_MIMETYPE': 'application/json',
'SESSION_COOKIE_HTTPONLY': True,
'SEND_FILE_MAX_AGE_DEFAULT': datetime.timedelta(0, 43200),
'PRESERVE_CONTEXT_ON_EXCEPTION': None,
'SESSION_REFRESH_EACH_REQUEST': True,
'TRAP_HTTP_EXCEPTIONS': False
} > ,
'_static_url_path': '/myurl',
'template_context_processors': {
None: [ < function _default_template_ctx_processor at 0x0000000002ED9BA8 > ]
},
'template_folder': 'mytemplate',
'blueprints': {},
'url_map': Map([ < Rule '/css' (HEAD, OPTIONS, GET) - > static_css > , <
Rule '/js' (HEAD, OPTIONS, GET) - > static_js > , <
Rule '/' (HEAD, OPTIONS, GET) - > hello_world > , <
Rule '/myurl/<filename>' (HEAD, OPTIONS, GET) - > static >
]),
'name': 'asimply_app',
'_got_first_request': False,
'import_name': '__main__',
'root_path': 'D:\\myself\\flask_simply_dome',
'_static_folder': 'mystatic',
'extensions': {},
'url_default_functions': {},
'url_build_error_handlers': []
}
{}
1--------------------
{
'subdomain_matching': False,
'error_handler_spec': {},
'_before_request_lock': < thread.lock object at 0x0000000002619D70 > ,
'before_request_funcs': {},
'teardown_appcontext_funcs': [],
'shell_context_processors': [],
'after_request_funcs': {},
'cli': < flask.cli.AppGroup object at 0x0000000002EF03C8 > ,
'_blueprint_order': [],
'before_first_request_funcs': [],
'view_functions': {
'static': < bound method Flask.send_static_file of < Flask 'asimply_app' >>
},
'instance_path': 'D:\\myself\\flask_simply_dome\\instance',
'teardown_request_funcs': {},
'url_value_preprocessors': {},
'config':同上,
'_static_url_path': None,
'template_context_processors': {
None: [ < function _default_template_ctx_processor at 0x0000000002ED9BA8 > ]
},
'template_folder': 'templates',
'blueprints': {},
'url_map': Map([ < Rule '/static/<filename>' (HEAD, OPTIONS, GET) - > static > ]),
'name': 'asimply_app',
'_got_first_request': False,
'import_name': '__main__',
'root_path': 'D:\\myself\\flask_simply_dome',
'_static_folder': 'static',
'extensions': {},
'url_default_functions': {},
'url_build_error_handlers': []
}
2-------------------- {
'subdomain_matching': False,
'error_handler_spec': {},
'_before_request_lock': < thread.lock object at 0x00000000026A3DB0 > ,
'before_request_funcs': {},
'teardown_appcontext_funcs': [],
'shell_context_processors': [],
'after_request_funcs': {},
'cli': < flask.cli.AppGroup object at 0x0000000002FFB5F8 > ,
'_blueprint_order': [],
'before_first_request_funcs': [],
'view_functions': {
'static': < bound method Flask.send_static_file of < Flask 'asimply_app' >>
},
'instance_path': 'D:\\myself\\flask_simply_dome\\instance',
'teardown_request_funcs': {},
'url_value_preprocessors': {},
'config': 同上,
'_static_url_path': '',
'template_context_processors': {
None: [ < function _default_template_ctx_processor at 0x0000000002FDEBA8 > ]
},
'template_folder': 'templates',
'blueprints': {},
'url_map': Map([ < Rule '/<filename>' (HEAD, OPTIONS, GET) - > static > ]),
'name': 'asimply_app',
'_got_first_request': False,
'import_name': '__main__',
'root_path': 'D:\\myself\\flask_simply_dome',
'_static_folder': 'static',
'extensions': {},
'url_default_functions': {},
'url_build_error_handlers': []
}
3---------------------- """

结论

static_url_path主要用于改变url的path的,静态文件放在static下面,所以正常情况url是static/filename ,但是可以通过static_url_path来改变这个url
static_folder主要是用来改变url的目录的,默认是static,可以通过这个变量来改变静态文件目录。
要是项目是前后端分离的话,那这里的配置也就没影响了。

flask中static_folder与static_url_path的区别与联系的更多相关文章

  1. flask中filter和filter_by的区别

    filter_by表内部精确查询 User.query.filter_by(id=4).first() filter 全局查询 id必须指明来源于那张表User,而且需要用等号,而不是赋值 User. ...

  2. flask中的g、add_url_rule、send_from_directory、static_url_path、static_folder的用法

    Flask中的g对象是个很好的东西,主要用于在一个请求的过程中共享数据.可以随意给g对象添加属性来保存数据,非常的方便,下面的代码是一个使用g对象的例子.下面的这个例子会使用random随机产生一个0 ...

  3. flask中Flask()和Blueprint() flask中的g、add_url_rule、send_from_directory、static_url_path、static_folder的用法

    1.Blueprint()在蓝本注册函数register_blueprint()中,第一个参数为所注册的蓝本名称.当我们在应用对象上注册一个蓝图时,需要指定一个url_prefix关键字 参数(这个参 ...

  4. flask中的endpoint、自定义转化器、与djnago中session区别、利用装饰器实现登录认证

    flask路由中的endpoint 与自定义转化器 ''' endpoint主要用于 反向解析, 例如:login函数中配的路由是/login,其中endpoint='lg' 则在其他函数,可以用 u ...

  5. flask中的static_path和static_path_url和static_folder

    static_folder表示静态文件所在路径,默认为root_dir下的static文件夹 static_url_path的行为比较复杂 如果static_folder未被指定(也就是默认值stat ...

  6. flask中使用jsonify和json.dumps的区别

    一.实验 python的flask框架为用户提供了直接返回包含json格式数据响应的方法,即jsonify,在开发中会经常用到.如下一段简单的flask后端代码,服务端视图函数根据请求参数返回json ...

  7. flask中的蓝图实现模块化的应用

    Blueprint 蓝图的基本设想是当它们注册到应用上时,它们记录将会被执行的操作. 当分派请求和生成从一个端点到另一个的 URL 时,Flask 会关联蓝图中的视图函数. 简单来说,Blueprin ...

  8. Flask(2)- 装饰器的坑及解决办法、flask中的路由/实例化配置/对象配置/蓝图/特殊装饰器(中间件、重定义错误页面)

    一.装饰器的坑以及解决方法 1.使用装饰器装饰两个视图函数,代码如下 from flask import Flask, redirect, render_template, request, sess ...

  9. Flask中的蓝图(BluePrint)、

    蓝图 1.初识Flask蓝图(BluePrint) 创建一个项目然后将目录结构做成: user.py中的内容 from flask import Blueprint, render_template ...

随机推荐

  1. 关于java中Exception异常

    一.理解异常及异常处理的概念 异常就是在程序的运行过程中所发生的不正常的事件,它会中断正在运行的程序. 异常不是错误 程序中关键的位置有异常处理,提高程序的稳定性 二.掌握Java异常处理机制 Jav ...

  2. 【luogu P2936 [USACO09JAN]全流Total Flow】 题解

    题目链接:https://www.luogu.org/problemnew/show/P2936 菜 #include <queue> #include <cstdio> #i ...

  3. c语言描述的顺序表实现

    //顺序表的实现:(分配一段连续地址给顺序表,像数组一样去操作) #include<stdio.h> #include<stdlib.h> #define OK 1 #defi ...

  4. ProjectOnline同步数据到线下

    根据微软官方文档 我们能将office365上的应用系统projectonline数据同步到线下. 我们看看projectonline上面的数据: 同步后到达sqlserver的数据 这样office ...

  5. Java实现非递归归并排序

    public class nonRecursiveMergeSort { public static void main(String[] args) { int[] list = {8,4,3,6, ...

  6. 规避Javascript多人开发函数和变量重名问题

    函数和变量重名始终是一个令人头痛的问题,先讲变量吧,相信了解JS的朋友都知道,在JS中 是没有块级作用域的只有函数作用域,也就是说那些以大括号为界定符的代码块是管不住其中定义 的变量的作用域的,举例: ...

  7. MB/s与Mbit/s的区别

    数据传输率的单位一般采用MB/s或Mbit/s,尤其在内部数据传输率上官方数据中更多的采用Mbit/s为单位.此处有必要讲解一下两个单位二者之间的差异: MB/s的含义是兆字节每秒,Mbit/s的含义 ...

  8. 搭建docker registry (htpasswd 认证)

    1,拉取docker registry 镜像 docker pull registry 2,创建证书存放目录 mkdir -p /home/registry 3,生成CA证书Edit your /et ...

  9. javaScript 字符串与unicode码之间的相互转换,函数的封装

    在我们的开发过程中,有时在对数据进行储存的时候,我们需要将字符串转成unicode. 比如,在jsp开发时,前端使用页面间传值时,将传值参数先存入cookie中,然后在使用的时候,再从ookie中取出 ...

  10. vue-cli中vuex IE兼容

    vue2.0 兼容ie9及其以上 vue-cli中使用vuex的项目 在IE中会出现页面空白 控制台报错的情况:我们只需要安装一个插件,然后在main.js中全局引入即可 安装 npm install ...