zdppy+vue3+onlyoffice文档管理系统实战 20240831上课笔记 继续完善登录功能

本文主要是介绍zdppy+vue3+onlyoffice文档管理系统实战 20240831上课笔记 继续完善登录功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

遗留的问题

  • 1、整合验证码的接口
  • 2、渲染验证码
  • 3、实现验证码校验的功能
  • 4、验证码校验通过之后,再校验登录功能

验证码框架怎么使用

安装:

pip install zdppy_captcha

使用示例:

import zdppy_api as api
import zdppy_captcha
import zdppy_cachecache = zdppy_cache.Cache("tmp/.captcha_cache")
app = api.Api(routes=[*zdppy_captcha.zdppy_api.captcha(api, cache),]
)if __name__ == '__main__':import zdppy_uvicornzdppy_uvicorn.run(app, host="0.0.0.0", port=8888)

最核心的代码:

app = api.Api(routes=[*zdppy_captcha.zdppy_api.captcha(api, cache),]
)

当前项目依赖

zdppy-amauth
zdppy-amcrud
zdppy-cache
zdppy-captcha==0.1.4
zdppy-env
zdppy-jwt
zdppy-log
zdppy-mauth
zdppy-mcrud
zdppy-mysql
zdppy-password
zdppy-rand
zdppy-req
zdppy-uvicorn
zdppy_api
zdppy_snowflake

将接口整合到项目中

routes/captcha.py

import zdppy_captcha
import zdppy_api as api
from zdppy_cache import Cachecache = Cache("./tmp/.captcha")def get_captcha_routes():"""获取验证码相关的路由"""return zdppy_captcha.zdppy_api.captcha(api, cache)

routes/init.py

import zdppy_amauth as amauthfrom .file import get_file_routes
from .doc import get_doc_routes
from .captcha import get_captcha_routesdef get_routes(db):"""初始化路由"""routes = []routes.extend(get_file_routes(db))  # 文件相关的路由routes.extend(get_doc_routes())  # 文档相关的路由routes.extend(amauth.routers.get_all_routers(db))  # 权限相关的路由routes.extend(get_captcha_routes())  # 验证码相关的路由return routes

渲染验证码

当前的登录界面

在这里插入图片描述

获取验证码信息

login/api.js

import axios from "axios";export default {getCaptcha: () => {axios({method: "get",url: `http://127.0.0.1:18888/zdppy_captcha`,}).then(resp => {console.log("获取验证码成功", resp.data)})}
}

index.vue

onMounted(() => {api.getCaptcha()
})

在这里插入图片描述

优化获取验证码图片的方法

api.js

import axios from "axios";export default {// 获取验证码图片信息getCaptcha: async () => {let key = ""let img = ""await axios({method: "get",url: `http://127.0.0.1:18888/zdppy_captcha`,}).then(resp => {if (resp.data && resp.data.data && resp.data.status && resp.data.code === 10000) {key = resp.data.data.keyimg = resp.data.data.img}})return {key, img}}
}

index.vue

const captchaKey = ref() // 验证码的key
const captchaImg = ref() // 验证码图片const formState = reactive({username: '',password: '',captcha: '',
});// 点击登录
const onFinish = data => {console.log('Success:', data);axios({method: "post",url: `/api/auth/user/login`,data: {username: data.username,password: data.password,}}).then(resp => {console.log("登录成功", resp.data)})};onMounted(async () => {const captcha = await api.getCaptcha()console.log("验证码信息:", captcha)
})

渲染验证码图片

获取地址:

onMounted(async () => {const captcha = await api.getCaptcha()console.log("验证码信息:", captcha)captchaKey.value = captcha.keycaptchaImg.value = captcha.img
})

渲染图片:

<img :src=" 'data:image/png;base64,' + captchaImg"style="width: 100%; height: 50px; margin-top: 10px">

成功渲染验证码。
在这里插入图片描述

要实现的

  • 1、点击切换验证码
  • 2、1分钟后自动切换验证码

这篇关于zdppy+vue3+onlyoffice文档管理系统实战 20240831上课笔记 继续完善登录功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125911

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个