Python搭建博客网站小结

发布时间:2019-09-09 08:45:33编辑:auto阅读(2272)

    引言

    断断续续终于过了一遍廖雪峰的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工作流程

    http流程
    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对象,返回给客户端

    作业成果

    博客首页:

    博客首页

    写博客:

    写博客

    文章管理:

    管理博客

    文章详情:

    博客详情

    总结

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

    参考

    廖雪峰官网Blog网站实战

    moling3650/mblog

    zhouxinkai/awesome-python3-webapp

    ReedSun/Preeminent

关键字