• 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.html
    
    5 directories, 8 files

    2、主程序blog.py

    #!/usr/bin/python
    #coding:utf8
    
    from flask import Flask, render_template, url_for, request,redirect,make_response,session
    import os,MySQLdb
    
    app = Flask(__name__)
    app.secret_key='afjlsjfowflajflkajfkjfkaljf'
    user_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='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=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快速入门

  • 相关阅读:
    基于动态IP的Internet视频监控解决方案(作者:吴晓晖)
    Avid
    Silverlight 自定义控件的继承问题
    VOD三种VOD视频点播技术的简介和比较
    服务器主流存储:SAS存储知识问答
    获取oracle系统数据的sql
    C#去除字符串空格的几种方法
    利用Windows Media实现IP组播
    两种宽带接入方式HFC与ADSL的比较
    C#中用XMLDocument写文件时,去掉XMLNS属性
  • 原文地址:https://www.cnblogs.com/lurenjiashuo/p/python-note-flask-demo.html
Copyright © 2020-2023  润新知