首页 > 代码库 > python学习笔记十三:Flask demo

python学习笔记十三:Flask demo

一、Flask简介

Flask 是一个 Python 实现的 Web 开发微框架。官网:http://flask.pocoo.org/

二、Demo

1、代码结构

.├── blog.py├── static│   ├── css│   │   └── index.css│   ├── images│   │   ├── cat.jpg│   │   └── sheying1229.jpg│   └── js└── templates    ├── index.html    ├── login.html    ├── regist.html    └── upload.html5 directories, 8 files

2、主程序blog.py

#!/usr/bin/python#coding:utf8from flask import Flask, render_template, url_for, request,redirect,make_response,sessionimport os,MySQLdbapp = Flask(__name__)app.secret_key=afjlsjfowflajflkajfkjfkaljfuser_list = [jim,max,py]imagepath = os.path.join(os.getcwd(),"static/images")@app.route(/)def index():    username = request.cookies.get(username)    if not username:        username = u请先登录    islogin = session.get(islogin)    nav_list = [u首页,u经济,u文化,u科技,u娱乐]    blog = {title:welcome to my blog,content:hello, welcome to my blog.}    blogtag = {javascript:10,"python":20,"shell":5}    img = url_for(static, filename="images/cat.jpg")    return render_template(index.html, nav_list=nav_list, username=username, blog = blog, blogtag = blogtag, img=img, islogin=islogin)@app.route(/reg, methods=[GET,POST])def regist():    if request.method == POST:        username = request.form[username]        conn = MySQLdb.connect(user=root,passwd=admin,host=127.0.0.1)        conn.select_db(blog)        curr = conn.cursor()        sql = insert into `user` (`id`,`username`) values (%d,"%s") % (1,username)        curr.execute(sql)        conn.commit()        curr.close()        conn.close()        return "user %s regist ok!" % request.form[username]    else:        #request.args[‘username‘]        return render_template(regist.html)@app.route(/upload, methods=[GET,POST])def upload():    if request.method == POST:        username = request.form[username]        file = request.files[img]        filename = file.filename        file.save(os.path.join(imagepath,filename))        return "<img src=http://www.mamicode.com/‘static/images/%s‘ alt=‘‘/>" % filename    else:        return render_template(upload.html)@app.route(/login/, methods=[GET,POST])def login():    if request.method == POST:        username = request.form.get(username)        if username in user_list:            response = make_response(redirect(/))            response.set_cookie(username, value=http://www.mamicode.com/username, max_age=300)            session[islogin] = 1            return response        else:            session[islogin] = 0            return redirect(/login/)    else:        return render_template(login.html)if __name__ == __main__:    app.run(debug=True,host=0.0.0.0,port=5000)

主要有首页、注册、登录、上传页面。

blog.py主要是展示了Flask中常见功能用法:路由,数据库操作,cookie,session,redirect,表单,文件上传,调试,Web服务器的IP和端口,静态文件读取等。

3、首页模板index.html

<!DOCTYPE html><html><head>    <meta charset="utf-8"/>    <title>Flask DEMO</title>    <link rel="stylesheet" type="text/css" href="static/css/index.css"/></head><body>    <div class="header">        {%if islogin == ‘1‘ %}        <h1>Welcome ,{{username}}!</h1>        {%else%}        <h1>{{username}}!</h1>        {%endif%}        <div class="nav">            <ul>                {%for nav in nav_list%}                <li><a href="{{nav}}">{{nav}}</a></li>                {%endfor%}            </ul>        </div>    </div>    <div class="container">        <div class="item">            <h1>{{blog[‘title‘]}}</h1>            <div class="content">                <img src="/static/images/cat.jpg" alt="cat" />                <p>{{blog[‘content‘]}}</p>                <img src="{{img}}" alt="cat" />            </div>        </div>        <div class="side">            <ul>                {%for key,value in blogtag.items()%}                    <li>{{key}}({{value}})</li>                {%endfor%}            </ul>        </div>    </div></body></html>

这个模板主要展示了在Flask模板中如何读取各种类型的变量。

4、登录页面login.html

<!DOCTYPE html><html><head>    <meta charset="utf-8"/>    <title>Login</title>    <link rel="stylesheet" type="text/css" href="static/css/index.css"/></head><body>    <div class="header">        <h1>Login</h1>    </div>    <div class="container">        <div class="item">            <form action="" method="post">                <input type="text" placeholder="please input username" name="username" /><br/>                <input type="submit" value="Login"/>            </form>        </div>    </div></body></html>

结合blog.py主要展示表单如何提交取值,cookie和session应用。

5、注册页面regist.html

<!DOCTYPE html><html><head>    <meta charset="utf-8"/>    <title>Regist</title>    <link rel="stylesheet" type="text/css" href="static/css/index.css"/></head><body>    <div class="header">        <h1>Regist</h1>    </div>    <div class="container">        <div class="item">            <form action="" method="post">                <input type="text" placeholder="please input username" name="username" /><br/>                <input type="submit" value="Regist"/>            </form>        </div>    </div></body></html>

结合blog.py主要展示了数据库操作。

6、上传页面upload.html

<!DOCTYPE html><html><head>    <meta charset="utf-8"/>    <title>Upload</title>    <link rel="stylesheet" type="text/css" href="static/css/index.css"/></head><body>    <div class="header">        <h1>Upload</h1>    </div>    <div class="container">        <div class="item">            <form action="" method="post" enctype="multipart/form-data">                <input type="text" name="username" /><br/>                <input type="file" name="img" /><br/>                <input type="submit" value="Upload"/>            </form>        </div>    </div></body></html>

结合blog.py主要展示了如何上传文件。

7、运行效果

技术分享

三、参考资料

1、Flask快速入门

python学习笔记十三:Flask demo