因此,若要生成不依赖于request的绝对URL(比如异步发送邮件时在邮件中生成网站某个页面的URL),就必须要设置SERVER_NAME。
二、第二件事:子域名支持
SERVER_NAME键是用于子域名支持。因为 Flask 在得知现有服务器名之前不能猜测出子域名部分,所以如果你想使用子域名,这个选项必要的,并且也用于会话cookie。
请牢记不只有 Flask 存在不知道子域名的问题,你的浏览器同样存在这样的问题。 大多数现代 web 浏览器不允许服务器名不含有点的跨子域名 cookie。因此如果你的服务器的 名称为 localhost,你将不能为 localhost 和所有它的子域名设置一个 cookie。 请选择一个合适的服务器名,像 'myapplication.local', 并添加你想要的服务器名 + 子域名 到你的 host 配置或设置一个本地 bind。
Examples
-------->http://book.muxistudio.com || http://muxistudio.com-------->http://blog.muxistudio.com || -------->http://share.muxistudio.com
1.本地测试
修改 /etc/hosts 文件
注意:仅在本地测试中有效!
将所有需要使用的子域名添加到其中,例:
127.0.0.1 flask.dev localhost # 域名 127.0.0.1 test.flask.dev localhost # 子域名 127.0.0.1 othertest.flask.dev localhost # 子域名
在Flask应用的配置文件中添加'SERVER_NAME'
在应用配置中将'SERVER_NAME'设置为指定的域名及默认监听的端口,例:
#... app = Flask(__name__) app.config['SERVER_NAME'] = 'flask.dev:5000' #...
2.配置蓝图
蓝图中的subdomain为hosts文件中所添加的子域名
#...
# Blueprint declaration
bp = Blueprint('subdomain', __name__, subdomain="<user>")
#...
# Register the blueprint into the application
app.register_blueprint(bp)
#...
3.服务器端配置
讲Flask应用设置中的'SERVER_NAME'修改为生产环境中注册的域名
flask.dev:5000 ----> muxistudio.com
4.Nginx配置
配置监听端口,下面的例子中使用正则表达式获取用户访问的子域名,对于www,应该在正则表达式获取时将其过滤,在用户访问时对其进行重定向至www.yourdomain.com页面,否则www将会被视为子域名。
配置实例:
server {
listen 80;
listen 443 ssl;
ssl_certificate /usr/local/nginx/ssl/nginx.crt;
ssl_certificate_key /usr/local/nginx/ssl/nginx.key;
server_name ~^www.(?<user>.+.)?markdownblog.com$;
return 301 "$scheme://${user}markdownblog.com$request_uri";
}
server {
listen 80;
listen 443 ssl;
ssl_certificate /usr/local/nginx/ssl/nginx.crt;
ssl_certificate_key /usr/local/nginx/ssl/nginx.key;
server_name ~^.+.markdownblog.com$ markdownblog.com;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8085;
}
}










