loginApi
import request from "@/utils/request";
import { AxiosPromise } from "axios";
import { CaptchaResult, LoginData, LoginResult } from "./types";/*** 登录API** @param data {LoginData}* @returns*/
export function loginApi(data: LoginData): AxiosPromise<LoginResult> {const formData = new FormData();formData.append("username", data.username);formData.append("password", data.password);formData.append("captchaId", data.captchaId as string);formData.append("captchaCode", data.captchaCode as string);formData.append("grant_type", "password");return request({url: "/youlai-auth/oauth2/token",method: "post",data: formData,headers: {"Content-Type": "multipart/form-data",Authorization: "Basic bWFsbC1hZG1pbjoxMjM0NTY=", // 客户端信息Base64明文:mall-admin:123456},});
}
这段代码定义了一个名为loginApi的函数,它用于处理用户登录的API请求。函数接收一个LoginData类型的参数data,并返回一个AxiosPromise<LoginResult>类型的对象。下面是详细的解释:
-
import request from "@/utils/request";:这行代码从@/utils/request模块中导入了一个名为request的函数。这个函数可能是用来发送HTTP请求的工具函数。 -
import { AxiosPromise } from "axios";:从axios库中导入了AxiosPromise类型,这是用来表示一个返回值是AxiosPromise类型的函数的返回值类型。 -
import { CaptchaResult, LoginData, LoginResult } from "./types";:从当前目录下的types模块中导入了三个类型:CaptchaResult、LoginData和LoginResult。这些类型可能用于类型检查,以确保传入的数据和返回的结果符合预期的格式。 -
export function loginApi(data: LoginData): AxiosPromise<LoginResult> { ... }:定义了一个名为loginApi的导出函数,它接收一个LoginData类型的参数data,并返回一个AxiosPromise<LoginResult>类型的对象。 -
在函数体内部,首先创建了一个
FormData对象:const formData = new FormData();。FormData是一个用于构建表单数据的类,可以方便地添加键值对。 -
接下来,使用
formData.append(key, value)方法向formData对象中添加了四个键值对,分别是用户名、密码、验证码ID和验证码代码。这些数据是从传入的data参数中获取的。 -
formData.append("grant_type", "password");:向表单数据中添加了一个固定的键值对,键为"grant_type",值为"password"。这表明登录授权类型是密码类型。 -
return request({ ... });:最后,函数通过调用之前导入的request函数发起一个POST请求到URL"/youlai-auth/oauth2/token"。请求的方法是"post",请求体是之前构建的表单数据formData。同时设置了请求头,其中包含了内容类型为多部分表单数据("Content-Type": "multipart/form-data")和基础认证信息(Authorization: "Basic bWFsbC1hZG1pbjoxMjM0NTY=")。这里的认证信息是一个Base64编码的字符串,解码后是客户端ID和密钥的组合,例如:“mall-admin:123456”。
总结来说,loginApi函数用于通过POST请求发送用户的登录信息(包括用户名、密码、验证码等),并返回一个包含登录结果的Promise对象。
request.ts
import axios, { InternalAxiosRequestConfig, AxiosResponse } from "axios";
import { useUserStoreHook } from "@/store/modules/user";// 创建 axios 实例
const service = axios.create({baseURL: import.meta.env.VITE_APP_BASE_API,timeout: 50000,headers: { "Content-Type": "application/json;charset=utf-8" },
});// 请求拦截器
service.interceptors.request.use((config: InternalAxiosRequestConfig) => {const accessToken = localStorage.getItem("accessToken");if (accessToken) {config.headers.Authorization = accessToken;}return config;},(error: any) => {return Promise.reject(error);}
);// 响应拦截器
service.interceptors.response.use((response: AxiosResponse) => {const { code, msg } = response.data;if (code === "00000") {return response.data;}// 响应数据为二进制流处理(Excel导出)if (response.data instanceof ArrayBuffer) {return response;}ElMessage.error(msg || "系统出错");return Promise.reject(new Error(msg || "Error"));},(error: any) => {if (error.response.data) {const { code, msg } = error.response.data;// token 过期,重新登录if (code === "A0230") {ElMessageBox.confirm("当前页面已失效,请重新登录", "提示", {confirmButtonText: "确定",cancelButtonText: "取消",type: "warning",}).then(() => {const userStore = useUserStoreHook();userStore.resetToken().then(() => {location.reload();});});} else {ElMessage.error(msg || "系统出错");}}return Promise.reject(error.message);}
);// 导出 axios 实例
export default service;相关文章:
loginApi
import request from "/utils/request"; import { AxiosPromise } from "axios"; import { CaptchaResult, LoginData, LoginResult } from "./types";/*** 登录API** param data {LoginData}* returns*/ export function loginApi(data: LoginD…...
【RAG检索增强生成】Ollama+AnythingLLM本地搭建RAG大模型私有知识库
目录 前言一、Ollama:革新性的本地LLM服务工具1.核心优势2.技术亮点 二、AnythingLLM 概览1.核心特性2.技术生态支持 三、搭建本地智能知识库1. Ollama的安装启航2. AnythingLLM的安装对接3. AnythingLLM的配置精调4. 工作区与文档管理5. 聊天与检索的智能交互 四、…...
【wiki知识库】08.添加用户登录功能--前端Vue部分修改
🍊 编程有易不绕弯,成长之路不孤单! 目录 🍊 编程有易不绕弯,成长之路不孤单! 一、今日目标 二、前端Vue模块的修改 2.1 the-header组件 2.2 store工具 2.3 router路由配置修改 一、今日目标 上篇文章…...
写给非机器学习人员的 embedding 入门
你好,我是 shengjk1,多年大厂经验,努力构建 通俗易懂的、好玩的编程语言教程。 欢迎关注!你会有如下收益: 了解大厂经验拥有和大厂相匹配的技术等 希望看什么,评论或者私信告诉我! 文章目录 一…...
Oracle【plsql编写九九乘法表】
九九乘法表 DECLAREi NUMBER : 1;j NUMBER : 1; BEGINFOR i IN 1 .. 9LOOPFOR j IN 1 .. iLOOPDBMS_OUTPUT.put (i || * || j || || i * j || );END LOOP;DBMS_OUTPUT.put_line ( );END LOOP; END;输出结果...
ansible安装K8s
部署Kubernetes (k8s) 集群使用Ansible是一个常见的自动化解决方案。下面我将提供一个基本的步骤概述和所需的命令,用于在CentOS 7.8上使用Ansible部署k8s集群,包括Master节点和Worker节点(Web和DB节点)。 步骤 1: 准备环境 确保所…...
restful传值
GetMapping 普通的get请求 后端: restfule的get请求 通过/asd/123这种方式get请求传入后端 前端 url: /system/role/deptTree/ roleId / tenantId, method: get后端PathVariable从path上取对应的值 通过 GetMapping(value "/deptTree/{roleId}/{tenan…...
Qt自定义TreeWidget,实现展开折叠按钮在右侧,且一条竖直线上对齐
效果如下: 图片随便找的,可能需要调下样式,代码复制可用,留给有需要的人。 #ifndef CustomTreeWidget_h__ #define CustomTreeWidget_h__#include <QTreeWidget> #include <QPushButton>class CCustomTreeWidget : p…...
硅步千里:如何入行?——之入行成为软件开发者
无论何时,你是否有遇到这样的场景(在自己从未涉足过的行业或领域,现在需要自己去这个行业或领域学习探索,最初的目标是熟悉行业,快速融入进去,很多时候,我们只是了解了个大概,并没能…...
Sandbox: rsync.samba(80134) deny(1) file-write-create
Xcode15运行报错:Sandbox: rsync.samba(80134) deny(1) file-write-create/xxx/xxx 如下图: 解决办法: Build Settings 搜索 sandbox,把 Build Options 中的 User Script Sandboxing改为 NO...
lvs的dr模式综合实践
目录 编辑虚拟机准备工作 编辑编辑编辑 配置过程 配置client主机 配置router主机 配置lvs主机(vip使用环回来创建) 配置server1主机(vip使用环回来创建) 配置server2主机(vip使用环回来创建࿰…...
什么是自然语言处理
自然语言处理(Natural Language Processing, NLP)是人工智能(AI)的一个子领域,涉及计算机与人类语言的交互。它的目标是让计算机能够理解、分析、生成和操作自然语言,从而实现与人类的有效沟通。 自然语言处…...
快速理解互联网中的常用名词
并发与并行 并发:任务交替执行,伪并行,涉及CPU时间片和上下文切换。并行:任务真正同时执行,需要多核处理器,无上下文切换。 并发量(Concurrency) 概念:服务端程序单位…...
统计接口调用耗时_黑白名单配置
黑名单配置 黑名单就是那些被禁止访问的URL创建自定义过滤器 BlackListUrlFilter,并配置黑名单地址列表blacklistUrl如果有其他需求,还可以实现自定义规则的过滤器来满足特定的过滤要求 /*** 黑名单过滤器** author canghe*/ Component public class B…...
树莓派4 AV没有视频输出
使用AV接口输出,没有画面 需要在config.txt文件中 增加配置 enable_tvout1config.txt 中的 dtoverlayvc4-kms-v3d 行末尾添加,composite: dtoverlayvc4-kms-v3d,composite默认情况下,输出 NTSC 复合视频。要选择不同的模式,请在…...
短信群发平台:解决短信验证码接收问题的5大策略
在享受数字化服务时,如APP注册或网站登录,若遇到短信验证码无法接收的困扰,无疑会增添不少烦恼。为了帮助您迅速解决这一问题,我们精心总结了以下十大原因及对应的解决方法,助您顺畅完成验证流程。 一、优化网络环境 …...
WebSocket 初体验:构建实时通信应用
WebSocket是一种在客户端和服务器之间建立持久连接的协议,它允许双方进行双向通信,从而实现低延迟的数据交换。WebSocket非常适合需要实时交互的应用场景,比如聊天应用、在线游戏、实时数据分析等。 WebSocket简介 什么是WebSocket…...
LISA: Reasoning Segmentation via Large Language Model
发表时间:CVPR 2024 论文链接:https://openaccess.thecvf.com/content/CVPR2024/papers/Lai_LISA_Reasoning_Segmentation_via_Large_Language_Model_CVPR_2024_paper.pdf 作者单位:CUHK Motivation:尽管感知系统近年来取得了显…...
企业发展与数字化转型:创新驱动未来增长的关键策略
引言 在当今全球化和信息化高度融合的时代,数字化转型已经成为企业寻求增长和保持竞争优势的关键战略。随着技术的飞速进步,数字化不仅改变了商业模式和市场格局,还深刻影响了企业的内部运作和外部生态系统。大数据、人工智能、物联网等新兴技…...
如何选择适合自己的编程语言,为什么R是非计算机专业数据分析的最佳选择,五大点告诉你
在如今的数据驱动世界中,编程语言已成为希望在行业中进行数据分析的专业人士不可或缺的技能。对于非计算机专业背景的学者和学生来说,选择适合自己的编程语言可能看似困难。本文将探讨为什么对于那些需要进行本科生论文、研究生论文、或者发表学术成果的…...
Phi-4-Reasoning-Vision快速部署:CI/CD自动化测试流水线搭建
Phi-4-Reasoning-Vision快速部署:CI/CD自动化测试流水线搭建 1. 项目概述 Phi-4-Reasoning-Vision是基于微软Phi-4-reasoning-vision-15B多模态大模型开发的高性能推理工具,专为双卡4090环境优化。这个工具严格遵循官方SYSTEM PROMPT规范,支…...
手把手教你用GrsAi的Webhook和轮询,搞定GPT Image 1.5的异步图片生成任务
实战指南:基于GrsAi构建高可靠异步图像生成系统 当你的应用需要处理大量图像生成请求时,同步调用API往往会遇到超时、连接不稳定等问题。我曾在一个电商项目中使用同步调用,结果在促销高峰期系统频繁崩溃——直到改用异步架构才彻底解决问题。…...
WorkBuddy技能系统详解:推荐6大实用Skill
文章目录一、给你的AI同事装上"专业技能包"二、Excel智能处理:表格操作的"一键魔法"三、PPT智能生成:从构思到成稿的"全自动流水线"四、浏览器自动化:让AI替你去"网上冲浪"五、智能文件整理…...
终极OctoSQL部署指南:从Docker容器化到Kubernetes集群的完整实践
终极OctoSQL部署指南:从Docker容器化到Kubernetes集群的完整实践 【免费下载链接】octosql OctoSQL is a query tool that allows you to join, analyse and transform data from multiple databases and file formats using SQL. 项目地址: https://gitcode.com/…...
SEO关键词长尾词怎么找
SEO关键词长尾词怎么找?一步步教你掌握高效方法 在当今数字营销的环境中,SEO(搜索引擎优化)无疑是一个至关重要的环节。对于想要在百度上取得高排名的网站来说,找到合适的SEO关键词是至关重要的。尤其是长尾词&#x…...
ScriptGen Modern Studio在短视频/微短剧创作中的应用实战
ScriptGen Modern Studio在短视频/微短剧创作中的应用实战 1. 短视频创作的新工具革命 短视频和微短剧行业正在经历前所未有的爆发式增长。根据最新行业报告,2023年短视频内容创作量同比增长超过60%,而专业级微短剧的市场规模预计将在2025年突破千亿大…...
基于Qwen3-1.7B的智能对话开发:入门到实战
基于Qwen3-1.7B的智能对话开发:入门到实战 1. 认识Qwen3-1.7B:轻量级大语言模型 Qwen3-1.7B是阿里巴巴通义千问系列中的轻量级成员,特别适合开发者快速搭建智能对话系统。相比传统大模型,它具有以下特点: 参数规模适…...
天龙八部GM工具终极指南:5步掌握高效游戏管理技巧
天龙八部GM工具终极指南:5步掌握高效游戏管理技巧 【免费下载链接】TlbbGmTool 某网络游戏的单机版本GM工具 项目地址: https://gitcode.com/gh_mirrors/tl/TlbbGmTool TlbbGmTool是一款专为《天龙八部》单机版本设计的专业游戏管理工具,为游戏管…...
万象熔炉 | Anything XL快速上手:拖拽上传参考图进行ControlNet扩展
万象熔炉 | Anything XL快速上手:拖拽上传参考图进行ControlNet扩展 安全声明:本文仅讨论本地化部署的AI图像生成技术,所有数据处理均在用户本地设备完成,不涉及任何网络传输或云端服务,确保数据隐私和安全。 1. 工具简…...
Mac开发环境神器:OpenClaw+千问3.5-27B调试日志分析
Mac开发环境神器:OpenClaw千问3.5-27B调试日志分析 1. 为什么开发者需要日志分析助手 作为一个长期在Mac上折腾各种开发环境的程序员,我经历过太多深夜调试的痛苦时刻。那些密密麻麻的终端日志输出,往往包含着关键错误线索,但要…...
