用Flask搭建一个简易的博客

看了张宏伦的全栈学习视频,在此做个笔记。

一、创建项目环境

1.安装flask
2.工程目录

本人已安装Anaconda,所以直接创建项目easy_blog_flask。目录结构如下:

staic放css,图片等静态资源;templates放模板文件;run.py是程序入口;config.py配置参数。

3.创建数据库,建立表

由于本人用mac进行开发,所以用mamp进行数据库的操作。安装好mamp后,启动mamp,点击start servers开启服务,在preferences进行端口以及项目路径设置。
端口:


路径:

建立数据库:点击Open WebStart page,然后点击MySQL下的phpMyAdmin。点击左边栏的New创建数据库blogDB,然后创建表post,如下:

4.开始代码

在config.py中进行一些项目的参数配置:

HOST="localhost"
PORT=8889
USER='root'
PASSWORD='root'
DATABASE='blogDB'
CHARSET='utf8'

在templates文件夹下创建界面,套用模板layout.html,首页index.html,文章列表list.html,文章详情post.html。在run.py中连接数据库:

import sys
from flask import *
import warnings
warnings.filterwarnings("ignore")
import pymysql
from config import *
import time
import numpy as np

app = Flask(__name__)
app.config.from_object(__name__)
#链接数据库
def connectdb():
    db=pymysql.connect(host=HOST,user=USER,passwd=PASSWORD,db=DATABASE,port=PORT,charset=CHARSET)
    db.autocommit(True)
    cursor=db.cursor()
    return (db,cursor)
#关闭数据库
def closedb(db,cursor):
    db.close()
    cursor.close()
#首页
@app.route('/')
def index():
    return render_template('index.html')

if __name__ =='__main__':
    app.run(debug=True)
5.测试

进入项目根目录,然后python run.py结果如下:

 * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
 * Restarting with stat
 * Debugger is active!
 * Debugger PIN: 330-801-124

http://127.0.0.1:5000/ 就是项目根地址.

6.页面之间的跳转以及URL定义

比如首页index.html跳转到列表界面list.html,那么在index.html中:<a href="{{url_for('list')}}">文章列表</a>。而run.py中list函数为:

@app.route('/list')
def list():
    return render_template('list.html')

如上所见, route()装饰器把一个函数绑定到对应的 URL 上。这样index.html就可以跳转到list.html界面了。要在界面之间进行参数传递,可以在URL绑定相应的变量。比如在文字列表页面list.html跳转到文字详情界面post.html要传递文章id,那么在list.html界面要传递参数id:

<div>
    {% for item in arr %}
    <h5>第{{item[0]}}篇文章:</h5>
        <div class="artical">
            <h4>
                <a href="{{url_for('post',post_id=item[0])}}">
                    {{item[1]}}
                </a>
            </h4>
            <p> {{item[3]}}</p>
        </div>
    {% endfor %}
</div>

而在run.py中接收参数post_id,然后从数据看获取相应的文章,然后返回给post.html页面:

#文章详情页
@app.route('/post/<post_id>')#<post_id>参数
def post(post_id):
    (db,cursor) = connectdb()
    cursor.execute('select * from post where id=%s',post_id)
    item1=cursor.fetchone()
    item=np.array(item1)
    item[-1]=time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(int(item[-1])))
    closedb(db,cursor)
    return render_template('post.html',item=item)

以上为什么要item=np.array(item1)因为从数据看获取的数据时tuple,不能进行更改,而时间要进行转换就要把tuple进行转换后才能更改,再传给post.html页面.

7. 模板渲染

post.html页面获取到相应的文章item过后,在此页面展示文章内容:

{% extends 'layout.html' %}
{% block body %}
<h1>文章详情</h1>
<h2>{{item[1]}}</h2>
<h5>{{item[-1]}}</h5>
<p>{{item[2]}}</p>
{% endblock %}
8.表单数据提交

在首页进行文章的编辑,然后提交给数据库,跳转到文字列表界面。那么在首页index.html页面:

<form action="{{url_for('handel')}}" method="post">
    <h4>添加文章</h4>
    <input type="text" name="title" placeholder="标题">
    <textarea name="content" cols="30" rows="10" placeholder="内容"></textarea>
    <button type="submit">提交</button>
</form>

用handel函数进行post表单提交,在run.py中接收数据:

#处理提交
@app.route('/handel',methods=['POST'])
def handel():
    data = request.form
    arr=[data['title'],data['content'],int(time.time())]
    print(arr)
    (db,cursor) = connectdb()
    cursor.execute("insert into post(title,content,timestamp) values(%s,%s,%s)",arr)
    db.commit()
    closedb(db,cursor)
    return redirect(url_for('list'))  #跳转到list.html界面

获取到文字结构然后插入数据库,跳转到list.html页面,展示文章列表,那么run.py中list函数就要从数据库获取所以数据,然后传递给list.html页面。run.py的list函数:

#文章列表页
@app.route('/list')
def list():
    (db,cursor) = connectdb()
    cursor.execute("select * from post")
    data=cursor.fetchall()
    closedb(db,cursor)
    arr=[]
    for i in range(0,len(data)):
        lists=np.array(data[i])
        lists[-1]=time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(int(lists[-1])))
        arr.append(lists)
    return render_template('list.html',arr=arr)

在list.html页面渲染:

{% for item in arr %}
    <h5>第{{item[0]}}篇文章:</h5>
        <div class="artical">
            <h4>
                <a href="{{url_for('post',post_id=item[0])}}">
                    {{item[1]}}
                </a>
            </h4>
            <p> {{item[3]}}</p>
        </div>
    {% endfor %}
这样,一个简单的博客网站就搭建成功了。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,319评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,801评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,567评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,156评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,019评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,090评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,500评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,192评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,474评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,566评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,338评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,212评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,572评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,890评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,169评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,478评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,661评论 2 335

推荐阅读更多精彩内容