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

<!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":"参数错误"}';

}

?>

 

10bc7091f3af40f59cdbcf905cd703a2.png

 

  • 12
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在使用Django进行账号注册和登陆时,需要通过连接数据库的方式来存储用户的信息。Django内置了多种数据库支持,例如SQLite、MySQL和PostgreSQL等。 首先,需要在settings.py文件中配置DATABASES,指定所使用的数据库类型、用户名和密码等信息。配置完成后,Django会在底层自动使用ORM(Object Relational Mapping)与数据库进行交互。 接下来,创建一个models.py文件,定义用户模型。用户模型中应该包含注册和登陆时所需要的字段,例如用户名、密码等。通过继承Django内置的AbstractBaseUser类和PermissionsMixin类,可以方便地利用Django提供的身份验证系统。 然后,在views.py文件中编写视图函数。注册视图函数需要通过表单接受用户提交的信息,并调用模型的create_user方法创建新用户。登陆视图函数需要对用户提交的用户名和密码进行校验,并调用Django内置的authenticate方法进行身份验证。 最后,在urls.py文件中将视图函数与url路径进行映射。用户访问/url/register时会调用注册视图函数,访问/url/login时会调用登陆视图函数。 通过上述步骤,就可以在Django中建立账号注册登陆界面并连接数据库进行用户信息的存储和验证。同时,Django还提供了丰富的身份验证和权限控制功能,方便开发者进行二次开发和扩展。 ### 回答2: Django连接数据库建立账号注册登录界面可以通过Django框架中的多种数据存储引擎来实现,包括MySQL,PostgreSQL,SQLite等。首先,在项目配置文件中指定所需的数据库类型和相关配置信息,例如数据库名称、用户名、密码、主机名等。然后在Django项目中新建一个应用程序,包含如注册、登录等主要功能,并设计相应的模型类,如User等。 在新建的应用程序中,通过编写视图处理函数和URL路由映射,来实现注册、登录等业务逻辑。对于用户注册,在前端界面设计中,需要包含用户名、密码、邮箱等注册信息,并对输入的信息进行验证和存储。通过验证码等方法防止机器人注册账号。在后端逻辑方面,需要处理注册信息,包括验证用户输入的各项信息是否合法、用户名或邮箱是否被占用等,最后将用户信息存储到数据库中,并向用户发送验证邮件等方式完成账号激活。 在用户登录方面,需要处理用户输入的用户名和密码并进行验证,从数据库中获取相应用户信息,判断密码是否正确,若验证成功,则将用户信息保存到会话中,实现用户的持久化登录。同时需要实现退出登录的逻辑,将用户信息从会话中删除。 此外,为了保证用户信息安全性,需要对密码进行加密存储,可使用Django提供的默认密码哈希算法或自定义加密方式。对于输入的敏感信息,则可以使用Django提供的表单验证功能进行验证,如验证邮箱格式等。 综上,使用Django框架连接数据库建立账号注册登录界面需要针对具体业务需求进行设计和开发,从数据模型、表单验证、前后端交互等多个层面来实现用户账号的注册和登录功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值