標籤:直接 methods %s false etc 資料庫 select upper admin
1、mock介面,類比一些介面,在別的介面沒有開發好的時候,你需要用它 假的支付介面,類比支付成功
2、
3、查看資料,避免直接操作資料庫flask web開發架構
執行個體化server
裝飾器,下面的函數變為一個介面
- 啟動服務
import flask,json#__name__代表當前這個python檔案server = flask.Flask(__name__)#執行個體化server,把當前這個python檔案,當做一個服務def my_db(sql): import pymysql conn = pymysql.connect( host=‘127.0.0.1‘, user=‘root‘, passwd=‘123456‘, port=3306, db=‘data‘, charset=‘utf8‘) cur = conn.cursor() #建立遊標 cur.execute(sql)#執行sql if sql.strip()[:6].upper()==‘SELECT‘: res = cur.fetchall() else: conn.commit() res = ‘ok‘ cur.close() conn.close() return res@server.route(‘/index‘,methods=[‘get‘])#裝飾器,下面的函數變為一個介面#method預設只有get,methods=[‘get‘,‘post‘]def index(): res = {‘msg‘:‘這是我開發的第一個介面‘,‘msg_code‘:0} # 返回狀態代碼0,表示返回成功 return json.dumps(res,ensure_ascii=False) #json.dumps 序列化時對中文預設使用的ascii編碼.想輸出真正的中文需要指定ensure_ascii=False@server.route(‘/reg‘,methods=[‘post‘])#/reg介面路徑def ref(): username = flask.request.values.get(‘username‘)#username是介面調用的key,即入參 pwd = flask.request.values.get(‘passwd‘)#passwd是介面調用的key,即入參 if username and pwd: sql = ‘select * from my_user where username = "%s";‘ % username if my_db(sql): res = {‘msg‘: ‘使用者已存在‘, ‘msg_code‘: 2001} # 2001,以2開頭都是跟使用者有關的 else: insert_sql = ‘insert into my_user(username,passwd,is_admin) VALUES ("%s","%s",0);‘ % (username, pwd) my_db(insert_sql) res = {‘msg‘: ‘註冊成功‘, ‘msg_code‘: 0} else: res = {‘msg‘:‘必要欄位未填,請查看介面文檔‘,‘msg_code‘:1001} # 1001必要欄位未填 return json.dumps(res, ensure_ascii=False)server.run(port=7788,debug=True)
Python學習筆記十五_開發介面