代码:前端与数据库交互的登陆界面

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>登录</title>

</head>

<body>

<p>账号:<input type="text" id="user"></p>

<p>密码:<input type="text" id="pass"></p>

<button id="login">登录</button>

<button id="add">注册</button>

<script src="ajax.js"></script>

<!--

接口文档

method: get

url: './data/user.php'

参数:

type = login 登录

add 注册

user = 用户名

pass = 用户密码

返回:

{err:0,msg:'登录成功'}

-->

<script>

var login = document.querySelector('#login');

var add = document.querySelector('#add');

var user = document.querySelector('#user');

var pass = document.querySelector('#pass');

login.onclick = function (){

ajax({

type: 'get',

url: './data/user.php',

data: {

type: 'login',

user: user.value,

pass: pass.value

},

success: function (data){

var json = JSON.parse(data);

if (json.err == 0){

alert(json.msg);

}

}

});

}

add.onclick = function (){

ajax({

type: 'get',

url: './data/user.php',

data: {

type: 'add',

user: user.value,

pass: pass.value

},

success: function (data){

var json = JSON.parse(data);

if (json.err == 0){

alert(json.msg);

}

}

});

}

</script>

<?php

/*

接口文档

method: get

url: './data/user.php'

参数:

type = login 登录

add 注册

user = 用户名

pass = 用户密码

返回:

{err:0,msg:'登录成功'}

*/

header('Content-Type:text/html;charset=utf-8');

type = _GET['type'];

user = _GET['user'];

pass = _GET['pass'];

if (type \&\& user && $pass) {

//连接数据库

$link = mysqli_connect('localhost','root','xiaoming','userlist');

if(!$link){

die('连接失败:'.mysqli_connect_error());

}

//设置编码

mysqli_set_charset($link,'utf8');

//判断要登录还是要注册

// 执行sql语句

if ($type === 'login'){

login_sql = "select \* from user where username='user' and password='$pass'";

login_res = mysqli_query(link,$login_sql);

login_arr = mysqli_fetch_all(login_res);

if (count($login_arr) > 0){

echo '{"err":0,"msg":"登录成功"}';

} else {

echo '{"err":-3,"msg":"账号或密码错误"}';

}

} else if($type === 'add') {

select_sql = "select \* from user where username='user'";

select_res = mysqli_query(link,$select_sql);

// print_r($select_res );

// die();

select_arr = mysqli_fetch_all(select_res);

if(count($select_arr) > 0){

die('{"err":-1,"msg":"用户名已被占用"}');

} else {

insert_sql = "insert into user (username,password) values ('user','$pass')";

insert_res = mysqli_query(link,$insert_sql);

if ($insert_res){

echo '{"err":0,"msg":"注册成功"}';

} else {

echo '{"err":-2,"msg":"注册失败"}';

}

}

} else {

die('{"err":-9,"msg":"参数错误"}');

}

mysqli_close($link);

} else {

echo '{"err":-9,"msg":"参数错误"}';

}

?>

相关推荐
鱼子星_4 分钟前
【数据结构与算法】OJ题目详解(一)-单链表:从易到难的面试OJ题目
c语言·数据结构·算法·链表·面试·职场和发展
人道领域5 分钟前
【LeetCode刷题日记】递归与回溯实战 257.二叉树的所有路径——一篇文章彻底搞懂回溯
开发语言·python·算法·leetcode
Gofarlic_OMS6 分钟前
Mastercam浮动许可利用率低:软件许可浪费,回收再分配
java·大数据·开发语言·架构·制造
ulias2126 分钟前
leetcode热题 - 7
数据结构·算法·leetcode
维双云7 分钟前
搭建商城型小程序,具备预约挂号功能,供医院使用,该怎么做?
大数据
云栖梦泽在8 分钟前
AI安全实战:AI供应链安全防护的实战案例
大数据·人工智能·安全
吃好睡好便好8 分钟前
在Matlab中用sphere( )函数绘制球面图
开发语言·前端·javascript·学习·算法·matlab·信息可视化
图码9 分钟前
矩阵中的“对角线强迫症”:如何优雅地判断Toeplitz矩阵?
数据结构·c++·线性代数·算法·青少年编程·矩阵
lynnlovemin9 分钟前
二分查找与二分答案算法详解(基于C++实现)
c语言·开发语言·算法·二分查找·二分答案
瑞行AI12 分钟前
一套数据格式框架搞定大模型微调和对齐训练
算法·语言模型