很久没来 testerhome 逛啦,得益于催饭大佬帮忙开通了专栏权限,秉着不打扰论坛用户,也能有个地方记录自己文章的心态,很不要脸地决定也同步一份文章到 testerhome。
这个教程目前已经更新到了 80 多节,也不算教程,算半个参考吧,希望大家轻拍。
代码都会在这里有所展示,喜欢的话可以帮点个 star,谢谢大家了!如果你喜欢该教程,也可以分享给其他人。
想了很久,本来打算用Gin做为后端服务,或者作为网关层,后面想了一下好像没这个必要。这个平台的用户量会比较有限,而且也会做一定的服务拆分。于是还是采用了更大众一点的口味: Flask,有的同学可能会说,那怎么不用Django?
哈哈,问到点了,Django笔者是真不会,基本上没有接触过,从接触Python Web 开发的时候,我就用的是Flask。好在Flask比较精简,django 用户也能比较快的上手。
笔者其实比较好奇,不知道大家是要看一个很完整的过程,还是一个大概的,所以可能比较随性哈,复杂的地方尽量完整,毕竟又写文章又写代码的话,还是比较费事的。前期可能讲的比较仔细,后期可能以代码为主。所以有的地方如果有疑问的话,可以在文章下面评论或者联系本人。
笔者目前的目录在: J:\projects\github.com\wuranxu
以后的代码都会以这个目录为准,仅供参考。
在当前目录 (pity) 下打开终端并输入:
pip3 install flask
如果安装过程很缓慢,可以加上豆瓣源:
pip3 install flask -i https://pypi.douban.com/simple
由于笔者已经安装好了,所以没有详细的安装过程。
建立pity/app/__init__.py
编辑__init__.py
from flask import Flask
pity = Flask(__name__)
代码讲解: 这是 flask 的约定用法, 引入 Flask 类并实例化了一个 Flask 对象, 其中__name__为通俗写法。
至此,我们就得到了这样的一个名为"pity"的 Flask实例。
编写pity/run.py
from app import pity
@pity.route('/')
def hello_world():
return 'Hello World!'
if __name__ == "__main__":
pity.run("0.0.0.0", threaded=True, port="7777")
其中@pity.route("/")
是一个装饰器, 代表 hello_world 这个函数与路由/
进行绑定,也就是说当访问到/
路由的时候,函数 hello_world 会自动执行。
pity.run("0.0.0.0", threaded=True, port="7777")
这句话表示启动 web 服务, 第一个参数 0.0.0.0 表示接受任何 ip 的访问,threaded 表示如果有多人同时访问一个接口时是非阻塞的,port 代表服务挂载的端口,这里我们以clearlove为端口号: 7777。
运行 run.py,可在 pycharm 运行也可以在终端里输入python3 run.py
运行。
可以看到Running on http://0.0.0.0:7777
, 说明服务启动成功了!
咱们都知道HTTP是有很多种方法的,咱们这种 pity.route 如果没有指定方法的话,默认就是GET方法。
打开浏览器输入: http://localhost:7777/
如果看到这个 hello world 说明你成功了!
今天的课程就到这里了,下期见。说实话写的有点累,代码没写几行,屁话写了一大堆,后面可能要加快速度了!
全部代码地址: https://github.com/wuranxu/pity
觉得有用的话可以帮忙点个 Star 哦 QAQ