您的位置:首页 > 编程语言 > Python开发

python开发web服务器——搭建简易网站

2018-01-17 14:51 871 查看
转自:http://blog.csdn.net/baidu_35085676/article/details/69807145?%3E



目标

用已有的丰富图片资源建一个看图网站

条件

开发语言:

python3

库:

flask :一个开源的python web服务器框架

jinja2:flask默认的模板引擎

编辑器:

推荐pycharm

一个最简单的web服务器

python给我们提供了一个接口:WSGI:Web Server Gateway Interface

它只要求Web开发者实现一个函数,就可以响应HTTP请求。而不用触到TCP连接、HTTP原始请求和响应格式。

下面实例一个最简单的web应用:

# hello.py

def application(environ, start_response):
start_response('200 OK', [('Content-Type', 'text/html')])
return [b'<h1>Hello, Python web!</h1>']

# server.py
# 从wsgiref模块导入:
from wsgiref.simple_server import make_server
# 导入我们自己编写的application函数:
from hello import application

# 创建一个服务器,IP地址为空,端口是8000,处理函数是application:
httpd = make_server('', 8000, application)
print('Serving HTTP on port 8000...')
# 开始监听HTTP请求:
httpd.serve_forever()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
environ:一个包含所有HTTP请求信息的dict对象;
start_response:一个发送HTTP响应的函数。
将两个脚本放在同一目录下,运行server.py,访问 http://127.0.0.1:8000 就能看到效果了。

处理url

其实web应用,就是对不同url的处理。

我们将hello.py进行修改

def application(environ, start_response):
method = environ['REQUEST_METHOD']
path = environ['PATH_INFO']
if method=='GET' and path=='/':
return handle_home(environ, start_response)
if method=='POST' and path='/signin':
return handle_signin(environ, start_response)
...
1
2
3
4
5
6
7
8
这样就会处理两个url,’/’和’/signin’

当然你可以这么一直写下去…如果你不嫌累的话。

使用模板

既然上面的方法太累太慢,那我们学点高级的:

flask

看代码

from flask import Flask
from flask import request

app = Flask(__name__)

@app.route('/', methods=['GET', 'POST'])
def home():
return '<h1>Home</h1>'

@app.route('/signin', methods=['GET'])
def signin_form():
return '''<form action="/signin" method="post">
<p><input name="username"></p>
<p><input name="password" type="password"></p>
<p><button type="submit">Sign In</button></p>
</form>'''

@app.route('/signin', methods=['POST'])
def signin():
# 需要从request对象读取表单内容:
if request.form['username']=='admin' and request.form['password']=='password':
return '<h3>Hello, admin!</h3>'
return '<h3>Bad username or password.</h3>'

if __name__ == '__main__':
app.run()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
注意,这个是单文件。

来分析这个脚本:

Flask通过Python的装饰器在内部自动地把URL和函数给关联起来。

启动运行后,我们访问

‘/’,看到的页面是一个“HOME”单词

‘/signin’,此刻是通过GET访问,看到的是一个表单,填写’admin’和’password’,点击登录 ——>

‘/signin’,此刻是通过POST访问,看但的是Hello, admin!或者Bad username or password.

对于不了解GET与POST和HTML表单的同学,推荐去学习html基础。

但这样还是有些不灵活,用户访问看到的内容需要全部写出来,不能复用,太麻烦

使用模板引擎

模板解决了我们上面的问题。先看一段代码

from flask import Flask, request, render_template
import os

app = Flask(__name__)

@app.route('/', methods=['GET', 'POST'])
def home():
path = '/'
all_file = os.listdir(path)
return render_template('home.html',all_file = all_file)

if __name__ == '__main__':
app.run()
1
2
3
4
5
6
7
8
9
10
11
12
13
这里读取了根目录下所有文件的名字,将其传给html模板页面

然后,在.py的同目录下建立目录templates,这里存放的是我们的模板,模板的特殊在于可以使用python指令及变量在html里

home.html

{% for i in all_file %}
<a href="/page/{{ i }}">{{ i }}</a>
{% endfor %}
1
2
3
{% %} 中写的是指令

{{ }} 中写的是变量

所以最终的结果是,会生成多个标签,标签的名字就是目录名。

以上基础教程参照廖雪峰。

那么,基础已经将完了,接下来就会是成品了:

成品

用我们上次爬取的图片来建站,good idea!

这里在.py脚本同目录下建立一个static目录存放图片。(图片放在.py所在目录外层会链接不到)

#beautiful_pic.py
from flask import Flask
from flask import request
from flask import render_template
import os

app = Flask(__name__)

#显示所有文件夹
@app.route('/',methods=['GET','POST'])
def list_all():
path = './static/mzitu/'
all_pic = os.listdir(path)
return render_template('welcome.html',all_pic = all_pic)

#具体展示图片
@app.route('/<path>',methods=['GET','POST'])
def list_pic(path):
#错误链接无法找到图片目录就提示错误链接
if(path not in os.listdir('./static/mzitu/')):
return render_template('error.html')
pic_path = './static/mzitu/' + path
all_pic = os.listdir(pic_path)
return render_template('pic.html',title = path,all_pic = all_pic)

if __name__ == '__main__':
#port为端口,host值为0.0.0.0即不单单只能在127.0.0.1访问,外网也能访问
app.run(host='0.0.0.0',port='2333')
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
然后是模板文件

welcome.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>欢迎来到福利页面</title>
</head>
<body>
{% for i in all_pic: %}
<a href="/{{i}}">{{i}}</a>
<br><br>
{% endfor %}
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
13
pic.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>{{ title }}</title>
</head>
<body>
{% for i in all_pic %}
<img src="./static/mzitu/{{title}}/{{i}}" alt="{{i}}">
<br>
{% endfor %}
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
13
error.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>出错了</title>
</head>
<body>
你要访问的页面不存在...
<br>
<a href="/">点此返回首页</a>
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
最后成品网站在这http://www.flycold.cn

端口为随机端口,范围在2000-2100之中,相信大家都能找到吧。

如果外网还是无法访问请关闭防火墙!!

最后一句:本节只是给大家一个示范,python如何写web服务器,个人感觉比apache+php有趣得多!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: