1.目的:
python+flask+mysql搭建一个简单的前端+后端博客,包含增删改查相关操作。
2.实现
下面的操作是从0到1,教大家一步步怎么实现的。 2.1 图1:新建index.html,render_template的作用是打开一个网页; 图2:templates文件夹下新建一个index.html data:image/s3,"s3://crabby-images/d2848/d2848b5825d7bb6bd6403a0db3fe1b3e393d13b5" alt="图1" data:image/s3,"s3://crabby-images/919c3/919c307afd999b1fc18b4561b658325e78a958eb" alt="图2" 2.2 图1:使用样式css美化网页,新建static/css/style.css; 图2:修改templates文件夹下的index.html,link代表连接样式表,{{}}代表动态的,变量 图3:运行展示效果 data:image/s3,"s3://crabby-images/8c6be/8c6be87e76c380798c7d03a0143757df3d3f805b" alt="图1" data:image/s3,"s3://crabby-images/5b5cb/5b5cbfc5c1e95e2142a74aebc04d61d76d8370cc" alt="图2" data:image/s3,"s3://crabby-images/9eeb3/9eeb3301a735d40eea4deb062ed477895de9725c" alt="图3" 2.3 图1:下载css和js模板(到github下载),放在static目录下 data:image/s3,"s3://crabby-images/6bfb4/6bfb4d67218458083f136b1f48cc1d502c3baf5d" alt="图1" 2.4 图1:使用模板,在template下新建base.html基础模板; 图2:修改templates下index.html里面的内容,先继承base.html,然后在往block title或content里面加内容 data:image/s3,"s3://crabby-images/cc03f/cc03f36c19c91791110c3a0f20f69aef365c8319" alt="图1" data:image/s3,"s3://crabby-images/c1815/c18152c53fc477eb2eeaa3019ecf2db10752198e" alt="图2" 2.5 图1:创建数据库,新建一个db.sql数据库; 图2:新建init_db.py去初始化数据库,在终端执行一下; 图3:删除生成的database库,插入两条数据,再执行一下 data:image/s3,"s3://crabby-images/4e296/4e296f58ae52e5966351907e2e50d6d733ffda13" alt="图1" data:image/s3,"s3://crabby-images/7f6ec/7f6ecc3bfb44d786a18b13e865c066dc02630101" alt="图2" data:image/s3,"s3://crabby-images/5a537/5a5374f20735728958087171deb7766cafb6a3cf" alt="图3" 2.6 图1:把数据库的信息显示在网页上,修改blog.py 定义数据库连接函数,把posts传到index网页中; 图2:index.html中添加展示post的title和created data:image/s3,"s3://crabby-images/88bbf/88bbf38227834b7e386b17e9ee5591b60697393c" alt="图1" data:image/s3,"s3://crabby-images/f59e5/f59e5c13bd866b1d31f190c7cf185a6521fd3c80" alt="图2" 2.7 图1:点击链接进去详情页 ,blog.py创建post_id函数,通过网页的id进入详情页; 图2:新建post.html(复制index.html),这里写完后,就可以在网页中直接输入id查看详情信息; 图3:index.html中加入跳转的连接 data:image/s3,"s3://crabby-images/18f47/18f478128cf8e60228ae72ffe6eadf546d8c0641" alt="图1" data:image/s3,"s3://crabby-images/9e5be/9e5be062ba5f448b756f68b1dc449f8770d960ce" alt="图2" data:image/s3,"s3://crabby-images/5929c/5929c4bf4d6cf4686aa1f0dffa6b27d940f65ad4" alt="图3" 2.8 图1:新建文章页面,新建文章有展示和提交,所以有get和post ; 图2:新建new.html,value的标题没有等于空,而是等于request.form,防止提交表单失败,之前填写的标题没有了,内容中的request.form也是同样的道理 图3:页面的展示效果 data:image/s3,"s3://crabby-images/d57f6/d57f693f61c8d778507ed7089251244e2eb0e79d" alt="图1" data:image/s3,"s3://crabby-images/688f0/688f0117aaaee6b16b6c167b2ad40995ca538ba5" alt="图2" data:image/s3,"s3://crabby-images/42ff3/42ff3e84331ae9daf144d3a85ced4b08d4105fab" alt="图3" 2.9 图1:app.config[SECRET_KEY]加密钥,防止被改动; 图2:新建文章保存,导入一些库文件,new函数中增加保存到数据库的代码,别忘记跳转到首页前加return ,如果是post也就是提交才保存 data:image/s3,"s3://crabby-images/e1822/e18223360bed4b70d291d74a8ef0a6079da5c315" alt="图1" data:image/s3,"s3://crabby-images/0a78c/0a78c48a4a2189bae3b3c56894a3710d5f148ab1" alt="图2" 2.10 图1、2、3:增加提示,最新的文章展示在前面,增加新建文章的连接 data:image/s3,"s3://crabby-images/68b26/68b267b030b98734400d92cf7705abb1c36b25d5" alt="图1" data:image/s3,"s3://crabby-images/adb52/adb524c20bfe47a929b4f1e6365da4e605a2a755" alt="图2" data:image/s3,"s3://crabby-images/31892/31892c563280a3f55557aa717bc079ef37e2a0b4" alt="图3" 2.11 图1:编辑文章,get_pist之前函数定义好的,看看title =request.form[title] ; 图2:新建edit.html,把new.html复制过来,标题改为编辑,注意编辑要么从数据库中取要么从已修改过中取; 图3:编辑连接放在时间后面 data:image/s3,"s3://crabby-images/75f2e/75f2ed2851ff9ecc9ae2a8054523300e71ef420a" alt="图1" data:image/s3,"s3://crabby-images/4e7a3/4e7a355f14a74b8efaf507b0627516a468e8239f" alt="图2" data:image/s3,"s3://crabby-images/d4603/d4603ca3504527dd175c914d2571286462a60663" alt="图3" 2.12 图1:在文章详情中添加删除,增加delete函数,用的是post防止爬虫,post不能用网页访问,用postman去访问 ; 图2:post.html文章详情页中添加删除连接 图3:网页展示效果 data:image/s3,"s3://crabby-images/6eab3/6eab36531d34027e00478a4fe4b83ae2c9a7ffe5" alt="图1" data:image/s3,"s3://crabby-images/9bfe5/9bfe50b3cedcd6c76f8ee4469596c98511bc730e" alt="图2" data:image/s3,"s3://crabby-images/78fdf/78fdfeb508d961489a11055617af62cba77346fe" alt="图3" 2.13 图1:关于麦叔,函数定义好; 图2:新建about.html ,注意写在里面; 图3:在base.html中herd里面连接指向修改为about.html data:image/s3,"s3://crabby-images/620b8/620b89cd518b663099cfb0e65977eefabf786eb9" alt="图1" data:image/s3,"s3://crabby-images/544b7/544b7cbc8b7c23fd5b89b959e3d01b8c84703d0d" alt="图2" data:image/s3,"s3://crabby-images/20f43/20f433bdfb5b6ba53bfcd68823f389f019410405" alt="图3"
3.下载
https://github.com/songteng2012/python-flask-mysql-blog
|