由于筆者后臺(tái)使用的是flask框架接收和前端使用的是原生的JavaScript和jQuery的ajax發(fā)送,能力有限蛀缝,在此僅寫下我開發(fā)項(xiàng)目過程中所得顷链,歡迎指正交流。
一屈梁、flask中的json數(shù)據(jù)接收
1嗤练、利用flask的request.form.get()方法
Python后臺(tái)部分代碼
from flask import Flask
from flask import jsonify
from flask import request
import json
...
# 登錄
@app.route("/flask/login", methods=['POST'])
def login():
data_ = request.form.get('data')
data = json.loads(data)
username = data['username']
password = data['password']
rem = False
if data['remember']:
rem = True
return jsonify({"login": Login.login(username, password, rem)}) # 返回布爾值
2榛了、 利用flask的request.get_data()方法
Python后臺(tái)代碼
from flask import Flask
from flask import jsonify
from flask import request
import json
...
# 登錄
@app.route("/flask/login", methods=['POST'])
def login():
data = request.get_data()
data = json.loads(data)
username = data['username']
password = data['password']
rem = False
if data['remember']:
rem = True
return jsonify({"login": Login.login(username, password, rem)}) # 返回布爾值
3、利用flask的request.get_json()方法
Python后臺(tái)代碼
from flask import Flask
from flask import jsonify
from flask import request
...
# 登錄
@app.route("/flask/login", methods=['POST'])
def login():
data = request.get_json()
username = data['username']
password = data['password']
rem = False
if data['remember']:
rem = True
return jsonify({"login": Login.login(username, password, rem)}) # 返回布爾值
二煞抬、前端發(fā)送json數(shù)據(jù)
1霜大、原生XMLHttp發(fā)送
function login() {
var username =document.getElementById("username").value;
var password = document.getElementById("password").value;
var remember =document.getElementById("remember").checked;
var xmlhttp;
if (window.XMLHttpRequest)
{
// IE7+, Firefox, Chrome, Opera, Safari 瀏覽器執(zhí)行代碼
xmlhttp=new XMLHttpRequest();
}
else
{
// IE6, IE5 瀏覽器執(zhí)行代碼
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState===4 && xmlhttp.status===200)
{
...
}
};
xmlhttp.open("POST","/flask/login",true);
xmlhttp.setRequestHeader("Content-type","application/json");
// 后面這兩部很重要,我看網(wǎng)上很多都是使用xmlhttp.send("username="+username+"&password="+"),這樣接收還要解析一番感覺還是直接發(fā)送以下格式的好些
var data = {
"username": username
"password": password
"remember": remember
};
var data_json = JSON.stringify(data);
xmlhttp.send(data_json);
}
附:json數(shù)據(jù)解析
var text = xmlhttp.responseText;
// 通過eval() 方法將json格式的字符串轉(zhuǎn)化為js對(duì)象革答,并進(jìn)行解析獲取內(nèi)容
var result = eval("("+text+")");
if (result) {
} else {
alert("請(qǐng)輸入正確的用戶名和密碼");
}
2战坤、ajax發(fā)送
$(document).ready(function () {
var data = {
"username": "adamin",
"password": "123456789",
"remember": true
}
$.ajax({
url: "/flask/login",
type: "POST",
data: data,
success: function () {
}
})
})