第一次尝试着针对一个需求开发,也是第一次使用flask框架,前前后后搞了三天,其间接触了大量新知识,包括python中sqlite3的使用,sql基本语句的使用,POST的用法,关于json的处理等等,虽然走了不少弯路,感觉学习十分效率低下…
最后做出来的东西只有两个简单功能,一个是响应POST请求向数据库写入时间用户和留言内容,另一个还是响应POST请求,以json形式返回数据库中全部内容,其实在思考到底有没有必要用json形式返回,但是大家既然都这么做,那我也先这么做吧.
想把这个功能简陋的小程序继续完善,最后实现一个美观的留言板,路漫漫其修远兮.
暂时还没搞明白怎么贴代码,先以图片形式贴上吧

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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#!/usr/bin/env python
# config = utf-8
from flask import Flask
from flask import request
from flask import jsonify
from flask import json
import sqlite3
import time

app = Flask(__name__)
@app.route('/')
def index():
return '<h1>Hello,World!</h1>'
@app.route('/user/<name>')
def user(name):
return '<h1>Hello, %s!</h1>' % name

@app.route('/writedb',methods=['POST'])
def writedb():
t = time.time()
name = request.form['name']
content = request.form['content']
lyb = sqlite3.connect('lyb.db')
homu = lyb.cursor()
homu.execute('create table if not exists user (name,content,time)')
homu.execute('insert into user (name,content,time) values (\'%s\',\'%s\', \'%s\' )' % (name ,content ,t))
for i in homu.execute('select * from user'):
print i
homu.close()
lyb.commit()
lyb.close()
return 'Success'

@app.route('/readdb',methods=['POST'])
def readdb():
lyb = sqlite3.connect('lyb.db')
homu = lyb.cursor()
r = []
for i in homu.execute('select * from user'):
r.append(json.dumps({'name':i[0],'content':i[1],'time':i[2]}))
for i in r:
print i
return jsonify(text = r)
homu.close()
lyb.commit()
lyb.close()

if __name__ == '__main__':
app.run(debug = True)