前言
这次作业不仅需要我建立一个数据库(详情请点击这里),还需要我基于这个数据库写后端接口(注册和登录)供前端访问,接收前端的POST和GET请求,并将登录、注册是否成功传给前端。
本文介绍如何用Flask搭建后端,其中使用了pymysql操作mysql数据库,也会做这个部分的介绍。
正文
需要为前端提供的接口有两个:注册和登录,为此我定义了四个函数,分别是
- select_user(userid, password)
- insert_user(userid, password, phone, email, company)
- on_register()
- on_login()
前两个函数是操作数据库,被后两个函数调用;后两个函数是给前端的接口。
后端说明
整个后端的代码如下:
1 | from flask import Flask, request |
值得注意的是,这里的两个接口分别响应POST请求和GET请求。
可以发现,两个接口获取前端传过来的参数的方式是不同的:
GET
1
data = request.args.to_dict() # 需from flask import request
这样拿到的data是一个python的字典对象
POST
1
2data = request.get_data() # 需from flask import request
data = json.loads(data) # 转化为字典对象。需import json这两行代码才拿到一个python的字典对象
接口获取前端传过来的参数的方式与其响应的请求类型(如POST、GET、POST和GET)是对应的。
对应地,前端发过来的参数类型也需要和后端进行匹配。
前端代码
这里给出前端处理用户登录和注册请求的函数。
login
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
30function login() {
var url = "http://127.0.0.1:5000/api/login";
var userid = document.getElementById("userid");
var password = document.getElementById("password");
$.ajax({
url: url,
type: "GET",
data: {
userid: userid.value,
password: password.value,
},
success: function(data) {
var data1 = JSON.parse(data);
// console.log(data1);
if (data1.success) {
window.sessionStorage.setItem("userid", userid.value);
alert("登录成功!进入主页面!");
window.location.href = 'index.html';
} else {
alert("登录失败!请输入正确的账号和密码!");
}
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
if (textStatus === 'timeout') {
alert('请求超时,请重试!');
}
}
})
}register
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
38function register() {
var password1 = document.getElementById("password1").value;
var password2 = document.getElementById("password2").value;
var userid = document.getElementById("userid").value;
var phone = document.getElementById("phone").value;
var email = document.getElementById("email").value;
var company = document.getElementById("company").value;
if (password1 !== password2) {
alert("两次输入的密码不相同,请重新输入!");
return;
}
$.ajax({
url: "http://127.0.0.1:5000/api/register",
type: "POST",
// 转成json
data: JSON.stringify({
userid: userid,
password: password1,
phone: phone,
email: email,
company: company
}),
success: function(data) {
var data1 = JSON.parse(data);
if (data1.success) {
alert("注册成功,请登录!");
window.location.href = 'login.html';
} else {
alert("注册失败,请检查您输入的信息是否正确!");
}
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
if (textStatus === 'timeout') {
alert("请求超时!");
}
}
})
}
可以注意到,用ajax发送GET请求和PSOT请求时,我发的数据类型是不一样的。
login是GET请求,发送了json字符串
1
2
3
4
5
6
7JSON.stringify({
userid: userid,
password: password1,
phone: phone,
email: email,
company: company
})register是POST请求,发送了javascript的类的对象
1
2
3
4{
userid: userid.value,
password: password.value,
}
至此,本文对这次作业中后端搭建的介绍就结束了。
这次作业算是我第一次写后端,也是我第一次接触Flask,如果我有写错的地方,请在评论区指正!
作者:@臭咸鱼
转载请注明出处:https://www.cnblogs.com/chouxianyu/
欢迎讨论和交流!