Python搭建博客网站小结

  • 引言
  • 文件结构
  • 关键技术
    • http工作流程
    • ORM框架Day3-Day4
    • web框架Day5
  • 作业成果
      • 博客首页
      • 写博客
      • 文章管理
      • 文章详情
  • 总结
  • 参考

引言

断断续续终于过了一遍廖雪峰的Python教程,于此梳理教程实战作业:搭建一个Blog网站。
由于欠缺前端知识,有些代码直接引用于项目源码,个人做了尽量详尽的注释以帮助理解,希望在今后能够学习HTML(HTML 30分钟入门教程)、CSS、JavaScript等知识,然后回头重新理解本项目。
作业托管于我的github

文件结构

awesome-python3-webapp/     <--根目录
|
+-www/                      <--web项目目录
    |
    +-static/               <--静态资源目录
    |
    +-templates/            <--模板文件目录
    |   |
    |   +-__base__.html         <--基础模版,父模版
    |   |
    |   +-blog.html             <--文章详情模版,后加文章id构成完整路径
    |   |
    |   +-blogs.html            <--首页模版
    |   |
    |   +-manage_blog_edit.html <--编辑文章模版
    |   |
    |   +-manage_blogs.html     <--文章管理模版
    |   |
    |   +-manage_comments.html  <--评论管理模版
    |   |
    |   +-manage_users.html     <--用户管理模版
    |   |
    |   +-register.html         <--注册模版
    |   |
    |   +-signin.html           <--登陆模板
    |
    +-apis.py            <--api接口,定义几个错误异常类和Page类用于分页
    |
    +-app.py             <--HTTP服务器以及处理HTTP请求;拦截器、jinja2模板、URL处理函数注册等
    |
    +-config.py           <--默认和自定义配置文件合并
    |
    +-config_default.py   <--默认的配置文件信息
    |
    +-config_override.py  <--自定义的配置文件信息
    |
    +-coroweb.py         <--封装aiohttp,即写个装饰器更好的从Request对象获取参数和返回Response对象 
    |
    +-favicon.ico         <--网页缩略图标
    |
    +-handlers.py         <--处理各种URL请求
    |
    +-markdown2.py        <--支持markdown显示的插件
    |
    +-models.py          <--采用ORM构建三个映射数据库表的类:User、Blog、Comment
    |
    +-models_test.py      <--测试ORM
    |
    +-orm.py              <--ORM框架
    |
    +-pymonitor.py        <--用于支持自动检测代码改动重启服务
    |
    +-schema.sql          <--创建表的SQL脚本

关键技术

1.http工作流程

Python搭建博客网站小结_第1张图片
1. 客户端(浏览器)发起请求
2. 路由分发请求(这个框架自动帮处理),add_routes函数就是注册路由。
3. 中间件预处理
- 打印日志
- 验证用户登陆
- 收集Request(请求)的数据
4. RequestHandler清理参数并调用控制器(Django和Flask把这些处理请求的控制器称为view functions)
5. 控制器做相关的逻辑判断,有必要时通过ORM框架处理Model的事务。
6. 模型层的主要事务是数据库的查增改删。
7. 控制器再次接管控制权,返回相应的数据。
8. Response_factory根据控制器传过来的数据产生不同的响应。
9. 客户端(浏览器)接收到来自服务器的响应。

2.ORM框架Day3-Day4

ORM全称为对象关系映射(Object Relation Mapping),即用一个类来对应数据库中的一个表,一个对象来对应数据库中的一行,表现在代码中,即用类属性来对应一个表,用实例属性来对应数据库中的一行。具体步骤如下:

  1. orm.py中实现元类 ModelMetaclass:创建一些特殊的类属性,用来完成类属性和表的映射关系,并定义一些默认的SQL语句,如SELECT, INSERT, UPDATE, DELETE等
  2. orm.py实现Model类:包含基本的getattr,setattr方法用于获取和设置实例属性的值,并实现相应的SQL处理函数,如find、findAll、save、remove等
  3. model.py中实现三个映射数据库表的类:User、Blog、Comment,在应用层用户只要使用这三个类即可

3.web框架Day5

aiohttp已经是一个Web框架了,在此主要对aiohttp库做更高层次的封装,从简单的WSGI接口到一个复杂的web framework,本质上还是对request请求对象和response响应对象的处理,可以将这个过程想象成工厂中的一条流水线生产产品,request对象就是流水线的原料,这个原料在经过一系列的加工后,生成一个response对象返回给浏览器。具体步骤如下:

  1. coroweb.py中@get()装饰器给http请求添加请求方法和请求路径这两个属性;RequestHandler()调用url参数,将结果转换位web.response
  2. app.py中传入拦截器middlewares,通过add_routes()批量注册URL处理函数、init_jinja2()初始化jinja2模版、add_static()添加静态文件路径
  3. create_server()创建服务器监听线程
  4. 监听线程收到一个request请求
  5. 经过几个拦截器(middlewares)的处理(app.py中的app = web.Application..这条语句指定)
  6. 调用RequestHandler实例中的call方法;再调用call方法中的post或者get方法
  7. 调用handlers.py中响应的URL处理函数,并返回结果
  8. response_factory在拿到经URL处理函数返回过来的对象,经过一系列类型判断后,构造出正确web.Response对象,返回给客户端

作业成果

博客首页:

Python搭建博客网站小结_第2张图片

写博客:

Python搭建博客网站小结_第3张图片

文章管理:

Python搭建博客网站小结_第4张图片

文章详情:

Python搭建博客网站小结_第5张图片

总结

通过该作业,基本了解了一个webapp的开发流程和部分技术,了解了http的工作原理,复习了python的使用。但是也深刻认识到python知识点的不熟练和前端相关知识的匮乏,后续仍要加强python项目练习和前端知识的学习。

参考

廖雪峰官网Blog网站实战

moling3650/mblog

zhouxinkai/awesome-python3-webapp

ReedSun/Preeminent

你可能感兴趣的:(Python,python,博客)