当前位置: 首页 > article >正文

前后分离Vue3+Django 之简单的登入

  1. 前端Vue3
<template>
  <div>
    <el-form :model="form" label-width="100px">
      <el-form-item label="用户名">
        <el-input v-model="form.username" placeholder="请输入用户名"></el-input>
      </el-form-item>
      <el-form-item label="密码">
        <el-input v-model="form.password" type="password" placeholder="请输入密码"></el-input>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="handleSubmit">登录</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script setup>
import { ref } from 'vue';
import axios from 'axios';

const form = ref({
  username: '',
  password: ''
});

const handleSubmit = () => {
  axios.post('http://127.0.0.1:8000/user/login/', form.value)
    .then(response => {
      if (response.data.status === 'success') {
        alert('登录成功');
        // 登录成功后的逻辑,例如跳转到主页
      } else {
        alert(response.data.message);
      }
    })
    .catch(error => {
      console.error('登录失败', error);
      alert('登录失败,请检查用户名和密码');
    });
};
</script>

效果:
在这里插入图片描述

  1. 后端Django
    models.py
    用于mysql
# Create your models here.
from django.contrib.auth.models import AbstractUser
from django.db import models

class CustomUser(models.Model):
    # 添加自定义字段
    name = models.CharField(max_length=100, verbose_name="姓名")
    password = models.CharField(max_length=100, verbose_name="密码")

views.py
处理

from django.contrib.auth import authenticate
from django.http import JsonResponse
from django.views.decorators.csrf import csrf_exempt
from django.views.decorators.http import require_http_methods
from .models import CustomUser

@csrf_exempt
@require_http_methods(["POST"])
def user_login(request):
    import json
    data = json.loads(request.body)
    print(data)
    username = data.get('username')
    password = data.get('password')
    password_mysql = CustomUser.objects.get(name=username)
    if password_mysql is not None:
        if password_mysql.password==password:
            return JsonResponse({'status': 'success', 'message': '登录成功'})
        else:
            return JsonResponse({'status': 'error', 'message': '用户名或密码错误'})
    else:
        return JsonResponse({'status': 'error', 'message': '用户名不存在'})

应用的urls.py
路由

from django.urls import path
from . import views

urlpatterns = [
    path('login/', views.user_login, name='login'),
]

项目的urls

from django.contrib import admin
from django.urls import path,include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('user/', include('myapp.urls')),

]

前后端分别启动,就可以进行尝试。
mysql数据里:
在这里插入图片描述
在这里插入图片描述

问题点:
如果发现前端输入信息后,后端报"OPTIONS /user/login/ HTTP/1.1" 405 0错误。

可以从2个方面去排查,①路由的路径配置 ②Setting中跨域的配置


http://www.kler.cn/a/516569.html

相关文章:

  • 抛弃node和vscode,如何用记事本开发出一个完整的vue前端项目
  • 煤矿场景下拖链检测数据集VOC+YOLO格式21407张1类别
  • 4_高并发内存池项目_高并发池内存释放设计_ThreadCache/CentralCache/PageCache回收并释放内存
  • Next.js:构建大模型智能体GPT研究者应用的 Web开发框架
  • 当使用 npm 时,出现 `certificate has expired` 错误通常意味着请求的证书已过期。
  • 2025.1.20——一、[RCTF2015]EasySQL1 二次注入|报错注入|代码审计
  • C++函数——fill
  • leetcode刷题记录(八十四)——739. 每日温度
  • 2.2.2 大小写敏感性
  • Facebook广告零支出无消耗:可能原因与解决方法
  • 鞅的定义_
  • Ubuntu二进制部署K8S 1.29.2
  • C语言数组详解:从基础到进阶的全面解析
  • bat批处理删除此电脑左侧及另存为下文档视屏等多余项
  • [java] java基础-字符串篇
  • PyTorch入门 - 为什么选择PyTorch?
  • arcgis for js只显示范围内的天地图,其余部分透明
  • Vue基础(2)
  • 前k个高频元素力扣--347
  • 详解C#中的特性(Attribute)
  • 小游戏源码开发搭建技术栈和服务器配置流程
  • 独立开发者产品日刊:将 Figma 设计转化为全栈应用、对话 PDF生成思维导图、视频转 AI 笔记、AI问答引擎、Mac 应用启动器切换器
  • Python散点统计栅格化
  • 动态规划(路径问题)
  • 安宝特方案 | AR在供应链管理中的应用:提升效率与透明度
  • HTML常用标签