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

  1. 前端Vue3
typescript 复制代码
<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
python 复制代码
# 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

处理

python 复制代码
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

路由

python 复制代码
from django.urls import path
from . import views

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

项目的urls

python 复制代码
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中跨域的配置

相关推荐
Katecat996637 小时前
YOLO11分割算法实现甲状腺超声病灶自动检测与定位_DWR方法应用
python
野犬寒鸦7 小时前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习
玩大数据的龙威8 小时前
农经权二轮延包—各种地块示意图
python·arcgis
ZH15455891318 小时前
Flutter for OpenHarmony Python学习助手实战:数据库操作与管理的实现
python·学习·flutter
belldeep8 小时前
python:用 Flask 3 , mistune 2 和 mermaid.min.js 10.9 来实现 Markdown 中 mermaid 图表的渲染
javascript·python·flask
喵手8 小时前
Python爬虫实战:电商价格监控系统 - 从定时任务到历史趋势分析的完整实战(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·电商价格监控系统·从定时任务到历史趋势分析·采集结果sqlite存储
喵手8 小时前
Python爬虫实战:京东/淘宝搜索多页爬虫实战 - 从反爬对抗到数据入库的完整工程化方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·京东淘宝页面数据采集·反爬对抗到数据入库·采集结果csv导出
Honmaple8 小时前
OpenClaw 实战经验总结
后端
B站_计算机毕业设计之家9 小时前
猫眼电影数据可视化与智能分析平台 | Python Flask框架 Echarts 推荐算法 爬虫 大数据 毕业设计源码
python·机器学习·信息可视化·flask·毕业设计·echarts·推荐算法
PPPPPaPeR.9 小时前
光学算法实战:深度解析镜片厚度对前后表面折射/反射的影响(纯Python实现)
开发语言·python·数码相机·算法