(一)前言

在开始学习之前,你需要确保你对Python, JavaScript, HTML, Markdown语法有非常基础的了解。项目的源码你可以在 https://github.com/zhu-y/markdown-toolkit 找到,最后的效果会像 http://yzhu.pythonanywhere.com 展示的一样。

本文分为三个部分:

Python+Flask+Gunicorn 项目实战(一) 从零开始,写一个Markdown解析器 —— 初体验

Python+Flask+Gunicorn 项目实战(二) 从零开始,写一个Markdown解析器 —— 后端(预计完成: 12月17日)

Python+Flask+Gunicorn 项目实战(三) 从零开始,写一个Markdown解析器 —— 前端(预计完成: 12月20日)

对前端不感兴趣的朋友可以不看第三部分,因为第二部分已经提供了我们需要的前端代码。在本项目中,我们将通过Python Flask实现后端,使用HTML/Javascript来实现前端,将前端用户输入的内容传输给后端,然后将后端返回的HTML样式展示给用户。


(二)环境配置

(1) 安装Python(如果已有Python可忽略): 前往https://www.python.org/downloads/ 下载并且安装。

(2) 安装Flask(推荐使用虚拟环境):

命令行输入

$ pip install flask

(3) 新建项目文件夹,命名为markdown-toolkit用于存放整个项目,然后进入文件夹中准备开始下一步

$ mkdir markdown-toolkit
$ cd markdown-toolkit/

(三)开始搭建后端API

(1) REST APIs 基础

如果我要做一个非常简单的应用——留言板,需求是:当我发布一个留言,其他人都可以看到我的留言;而我也可以看到其他人发布的留言。

当我打开这个应用的网页,其实我会通过一个API接口从前端把一个查看留言的请求发给后端,然后由后端去从数据库里找出保存的留言记录,然后返回给前端,显示到我的页面上。

当我想发布一条留言的时候,我会通过另一个对应的API接口从前端把发布留言的请求发送给后端,然后由后端去把我的留言写入数据库。这样当别人再去打开这个页面,他们就能看到我的留言了。

而我刚刚所讲述的这个过程,实际上就是很多web应用最基础的原型:(图片参考自https://dzone.com/articles/an-introduction-to-restful-apis)

REST APIs的服务有几个很大的特点:

a) 前后端分离:client是前端(比如我们看到的网页),server是后端(比如API接口),而他们是前后端分离的。

b) 无状态的:server端不保存任何数据。会话(session)保存在client(前端),其他数据则大部分存放在数据库。

c) 可缓存的:客户端一般可以将响应(response)存储在缓存中。这大大提高了API的性能。

在我们的即将要搭建的Markdown解析器项目中,我们暂时不需要用到数据库。Python+Flask将承担起我们后端的作用,而我们的前端将会由JavaScript+HTML完成.

(2) 准备工作

我们现在要建立我们的应用,我们可以叫它app。首先,在markdown-toolkit/文件夹中,新建run.py,插入以下代码,目的是架起我们的Flask应用:

#!flask/bin/python

from app import app
app.run(debug=True)

然后,在我们的项目文件夹 markdown-toolkit/ 中新建一个名为app的文件夹,并且进入这个文件夹:

$ mkdir app$ cd app

然后在markdown-toolkit/app文件夹中新建名为templates的文件夹用于存放html页面模板,static文件夹用于存放静态文件,在static文件夹中新建一个叫js的文件夹来存放JavaScript代码。

$ mkdir templates
$ mkdir static
$ mkdir static/js

在markdown-toolkit/app文件夹中,新建__init__.py,插入以下代码,目的是从我们的应用中调用我们即将新建的md2html.py这个文件中的代码:

from flask import Flask

app = Flask(__name__)
from app import md2html

然后在markdown-toolkit/app文件夹中新建md2html.py,插入以下代码:

from app import app

@app.route('/')
def index():
    return "HELLO WORLD"

完成上述步骤后,我们项目文件夹的结构看起来应该是这样的:

└── markdown-toolkit
    ├── app
    │   ├── __init__.py
    │   ├── md2html.py
    │   ├── static
    │   │   └── js
    │   └── templates
    └── run.py

这个时候,我们回到项目的文件夹markdown-toolkit中去,然后执行命令:

python run.py

我们会得到:

 * Serving Flask app "app" (lazy loading)
 * Environment: production
   WARNING: Do not use the development server in a production environment.
   Use a production WSGI server instead.
 * Debug mode: on
 * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
 * Restarting with stat
 * Debugger is active!
 * Debugger PIN: --

这就代表我们成功运行起了这个应用,这时用浏览器打开http://127.0.0.1:5000/,我们就应该能够看到这样的一个画面:

我们再来回顾我们写在md2html.py这个文件中的代码:

from app import app

@app.route('/')
def index():
    return "HELLO WORLD"

这段代码的意思是,我们把"HELLO WORLD"返回给路径为"/"的API。这也就是说,如果我把这段代码改成了:

from app import app

@app.route('/hello')
def index():
    return "HELLO WORLD"

那么我们就需要打开http://127.0.0.1:5000/hello才能看到"HELLO WORLD"了。可是如果我想返回的是一个HTML页面怎么办?那么我们可以把我们想要返回的页面的html放在markdown-toolkit/app/templates/文件夹中,然后从Flask自带的库中使用render_template来将这个页面返回给前端。

想要尝试,你可以从https://github.com/zhu-y/markdown-toolkit/blob/master/app/templates/index.html 拷贝我这部分的代码到你的markdown-toolkit/app/templates/文件夹中。然后将 md2html.py的代码改为下方这样:

from app import app

from flask import render_template

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

再回到markdown-toolkit/,通过

python run.py

来运行应用,你就应该可以看到这样的页面了:

到此为止,你应该对Flask有一个基本的了解了。

下一章: Python+Flask+Gunicorn 项目实战(二) 从零开始,写一个Markdown解析器 —— 后端


在下一篇博文里,我会讲到更加具体的细节。如有疏漏、建议,还请大家指出。

本文为原创博文,请勿转载。

Python+Flask+Gunicorn 项目实战(一) 从零开始,写一个Markdown解析器 —— 初体验的更多相关文章

  1. 一起写一个JSON解析器

    [本篇博文会介绍JSON解析的原理与实现,并一步一步写出来一个简单但实用的JSON解析器,项目地址:SimpleJSON.希望通过这篇博文,能让我们以后与JSON打交道时更加得心应手.由于个人水平有限 ...

  2. DIY:从零开始写一个 SQL 构建器

    最近在项目中遇到了一个棘手的问题,因为 EF Core 不支持直接生成 Update 语句,所以这个项目就用到了 EFCore.Plus 来实现这个功能,但是 EFCore.Plus 对 SQLite ...

  3. 《python灰帽子》学习笔记:写一个windos 调试器(一)

    一.开发内容介绍 为了对一个进程进行调试,你首先必须用一些方法把调试器和进程连接起来.所以, 我们的调试器要不然就是装载一个可执行程序然后运行它, 要不然就是动态的附加到一个运行的进程.Windows ...

  4. Python NLP完整项目实战教程(1)

    一.前言 打算写一个系列的关于自然语言处理技术的文章<Python NLP完整项目实战>,本文算是系列文章的起始篇,为了能够有效集合实际应用场景,避免为了学习而学习,考虑结合一个具体的项目 ...

  5. Python Django CMDB项目实战之-3创建form表单,并在前端页面上展示

    基于之前的项目代码 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页.index页.文章页面 Python Django CMDB项目实战之-2创建APP. ...

  6. Python Django CMDB项目实战之-2创建APP、建模(models.py)、数据库同步、高级URL、前端页面展示数据库中数据

    基于之前的项目代码来编写 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页index页文章页面 现在我们修改一个文章列表是从数据库中获取数据, 下面我们就需 ...

  7. Python Django CMDB项目实战之-1如何开启一个Django-并设置base页、index页、文章页面

    1.环境 win10 python 2.7.14 django 1.8.2 需要用到的依赖包:MySQLdb(数据库的接口包).PIL/pillow(处理图片的包) 安装命令: pip install ...

  8. [AST实战]从零开始写一个wepy转VUE的工具

    为什么需要 wepy 转 VUE "转转二手"是我司用 wepy 开发的功能与 APP 相似度非常高的小程序,实现了大量的功能性页面,而新业务 H5 项目在开发过程中有时也经常需要 ...

  9. 深入浅出React Native 3: 从零开始写一个Hello World

    这是深入浅出React Native的第三篇文章. 1. 环境配置 2. 我的第一个应用 将index.ios.js中的代码全部删掉,为什么要删掉呢?因为我们准备从零开始写一个应用~学习技术最好的方式 ...

随机推荐

  1. python统计文档中词频

    python统计文档中词频的小程序 python版本2.7 效果如下: 程序如下,测试文件与完整程序在我的github中 #统计空格数与单词数 本函数只返回了空格数 需要的可以自己返回多个值 def ...

  2. Spring + Mybatis应该如何配置

    ### 1. MYBATIS简介 MYBATIS是持久层框架,大大的简化了持久层开发. 当使用MYBATIS框架时,开发人员不必再编写繁琐的JDBC代码,只需要定义好每个功能对应的抽象方法与需要执行的 ...

  3. 爬虫——Scrapy框架案例二:阳光问政平台

    阳光热线问政平台 URL地址:http://wz.sun0769.com/index.php/question/questionType?type=4&page= 爬取字段:帖子的编号.投诉类 ...

  4. mysql中用HEX和UNHEX函数处理二进制数据的导入导出

    读取数据并拼写sql语句,然后进行导入.具体方法为: (1)导出时采用HEX函数读取数据,把二进制的数据转为16进制的字符串: select HEX(binField) from testTable; ...

  5. JSP/Servlet开发——第十章 Ajax与JQuery

    1. 认识Ajax: ◆在传统的 Web 应用中,每次请求服务器都会生成新的页面,用户在提交请求后,总是要等待服务器的响应,如果前一个请求没有得到响应,则后一个请求就不能发送. ◆由于这是一种独占式的 ...

  6. vi模式下的编辑、删除、保存和退出

    vi + 文件名:进入 vi 模式 编辑模式:shift+: 退出编辑模式:Esc 退出编辑模式后可进行光标的上下左右移动(偶尔会出现ABCD,还不知道怎么解决,目前只能出来一个删除一个) 光标处:按 ...

  7. nginx ssl pathinfo 伪静态 301 配置文件

    server { listen ; root /www/web/test_com/public_html; server_name test.com test.com; if ($host != '* ...

  8. Oracle_11g桌面版 中解决被锁定的scott 教学数据库的方法

    Oracle 11g中修改被锁定的用户:scott 在安装完Oracle10g和创建完oracle数据库之后,想用数据库自带的用户scott登录,看看连接是否成功. 在cmd命令中,用“sqlplus ...

  9. 插入排序,C语言实现

    插入排序是稳定排序,时间复杂度最低为O(n),最高为O(n^2),平均为O(n^2). 插入排序是将数组分为两部分,一部分已经排好序,另一部分未排好序,每次从未排好序的部分取第一个元素插入到已经排好序 ...

  10. Go 入门 - 控制流

    主要内容来自中文版的官方教程Go语言之旅 目的为总结要点 循环 Go 只有 for循环 for 由三部分组成,用分号间隔开 初始化语句:在第一次迭代之前执行,通常为一句短变量声明(i:=0) 条件表达 ...