nuxt3 服务端请求其他接口犯的问题与解决

目的

老项目迁移到 nuxt3,为了减少代码修改量,打算封装一个在服务端运行的请求函数,用于在服务端渲染页面的同时,将接口数据请求回来一起返回给客户端

在服务端请求接口并渲染到页面上、在客户端不请求该接口,但需要能够拿到存储的值

用到的 API

  • useAsyncData/useFetch

  • useState

犯的问题

useAsyncDatauseFetch返回的response数据都是被Proxy代理的数据,当时为了老项目中能少改点东西,用 toRaw 去掉了代理

export async function serverRequest(url,data) {...const options = {...obj,onRequest({ request, options }) {...},onResponse({ request, response, options }) {...},};const res = await useFetch( url, {...options, ...config})if (res.status.value === "error") {return toRaw(Promise.reject(res.error?.value));} else {return toRaw(res.data); // 核心错误就是加了个toRaw}
}

解释

useAsyncData/useFetch返回的代理数据,是类似useState生成的SSR 友好组合代理,会根据内部的key来校验是否需要重复请求的,删掉了就很容易出现重复请求的结果

解决过程

在使用toRaw的情况下,找到了两个解决方案:

  1. 在 vue 钩子“onServerPrefetch”中执行该方法,就只在服务端运行了

    这种写法的问题是在拦截器“onResponse”中,没办法使用 Nuxt 提供的“useCookie”方法,也就没办法实现在response时最常见的存token的功能了

  2. 通过“useState”创建,在回调中执行请求函数,利用useState的特性,接口就只会在服务端请求了

    这个方法的问题是在同一页面写多个请求,会报莫名其妙的错误,也有第一种方法中的拦截器问题

上边两个案总结:因为没有看源码,也没有深入了解 Nuxt 的运行模式,从表面上来感觉,nuxt 服务端运行似乎并没有刻意等待请求完全结束再返回给客户端,所以才会有各种各样的问题

最后在查资料的过程中找到了启发,删掉了toRaw,实现了个人认为较为“合理”的写法:

const config = {server: true,...
}export function serverRequest(url,data) {...const options = {...obj,onRequest({ request, options }) {...},onResponse({ request, response, options }) {...},};return useFetch( url, {...options, ...config})
}
<script setup>const { data: bannerList } = await serverRequest('basic/banner/list')</script>

不带toRaw后,很轻松就解决了一直困扰我的问题

useFetch会根据urlfetch选项自动生成一个key,判断接口是否需要请求

将上边方法放入我的项目后,发现useFetch请求的数据还是会在服务端和客户端都请求一次,排查后发现,是因为在项目中,我在请求前做了url的处理导致的

  • 客户端请求数据,通过nitro进行代理转发,实现接口请求

  • 服务端请求数据,需要直接请求域名

根据这个需求,我在请求前增加了对接口地址的处理

...
export function serverRequest(url,data) {...// url = /api/xxx/xxxlet _url = getUrl() // /api/xxx/xxx => http://aaa.com/xxx/xxx...const options = {...obj,onRequest({ request, options }) {...},onResponse({ request, response, options }) {...},};return useFetch( url, {...options, ...config})
}

因为对“url”进行了修改,导致useFetch在服务端和客户端自动生成的key不同,所以还会导致多次请求的问题

解决办法:使用useAsyncData代替useFetch,自定义key值以达到控制请求的效果

...
export function serverRequest(url,data) {...let name = obj.url + JSON.stringify(data);// url = /api/xxx/xxxlet _url = getUrl() // /api/xxx/xxx => http://aaa.com/xxx/xxx...const options = {...obj,onRequest({ request, options }) {...},onResponse({ request, response, options }) {...},};// 发起请求// return useFetch( url, {...options, ...config}) 改为 return useAsyncData(name, () => $fetch(url, options), config);// 错误处理let { data, error, status } useAsyncData(name, () => $fetch(url, options), config);if (error.value !== 'success') {...} else {return data}
}

–end–

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/597634.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

5G工业物联网网关:连接未来的智能工业

在当今数字化时代&#xff0c;工业物联网正迅速崛起&#xff0c;并引领着全球工业的数字转型。而5G工业物联网网关作为实现IIoT的关键基础设施&#xff0c;在连接未来的智能工业中发挥着举足轻重的作用。 什么是5G工业物联网网关 5G工业物联网网关是连接工业设备和5G网络的关键…

(湖科大教书匠)计算机网络微课堂(下)

第四章、网络层 网络层概述 网络层主要任务是实习网络互连&#xff0c;进而实现数据包在各网络之间的传输 因特网使用TCP/IP协议栈 由于TCP/IP协议栈的网络层使用网际协议IP&#xff0c;是整个协议栈的核心协议&#xff0c;因此TCP/IP协议栈的网络层常称为网际层 网络层提供…

SpringBoot整合sentinel

1、引入依赖 <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> </dependency> 2、 配置文件添加 spring:cloud:sentinel:transport:dashboard: ip:8858 项目重启&#x…

15.三数之和(双指针,C解答附详细分析)

题目描述&#xff1a; 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 注意&#xff1a;答案中不可以包含…

暴力破解的基础知识和Burpsuite基础知识

定义 暴力破解 (Brute Force)也称为字典攻击&#xff0c;通常被用于攻击网站的用户账户名/密码 使用自动化脚本以枚举的方式尝试所有可能的用户名或密码组合。通过攻击用户的账户名和密码&#xff0c;窃取用户个人信息或获取网站管理权限等。 暴力破解攻击产生原因 1、用户口…

【mujoco】Ubuntu20.04中解决mujoco报错raise error.MujocoDependencyError

【mujoco】Ubuntu20.04中解决mujoco报错raise error.MujocoDependencyError 文章目录 【mujoco】Ubuntu20.04中解决mujoco报错raise error.MujocoDependencyError1. 报错的具体情况2. 解决过程3. 其他问题3.1 ModuleNotFoundError: No module named OpenGL3.2 ModuleNotFoundEr…

AUTOSAR汽车电子嵌入式编程精讲300篇-面向不平衡样本的车载网入侵检测系统 设计与实现 (续)

目录 3.2 传统CANTransfer模型原理 3.2.1 传统CANTransfer模型结构及特点 3.2.2 二维空间变换分析

nc的用法

nc的用法 测试udp端口是否可用 如果是测试某个IP地址地址是否可以访问&#xff0c;通常会使用 ping 命令&#xff0c;执行之后如果可以到达就会得到数据反馈&#xff1a; alberthome-pc:~$ ping 82.156.125.169 PING 82.156.125.169 (82.156.125.169) 56(84) bytes of data.…

第84讲:基于各种场景使用mysqldump逻辑备份数据库

文章目录 1.mysqldump备份工具的语法格式2.使用mysqldump进行全库备份3.备份单个库或者多个库的数据4.备份某个库下的单表或者多表的数据5.mysqldump备份数据库时必加的一些参数5.1.基本参数5.2.核心参数 6.mysqldump备份数据库时的一些其他参数 1.mysqldump备份工具的语法格式…

Docker Compose--部署SpringBoot项目--实战

原文网址&#xff1a;Docker Compose--部署SpringBoot项目--实战-CSDN博客 简介 本文用实战介绍Docker Compose部署SpringBoot项目。 1.创建SpringBoot项目 Controller package com.knife.example.controller;import io.swagger.annotations.Api; import io.swagger.annot…

HTTP基础知识总结

目录 一、什么是HTTP&#xff1f; 二、与HTTP有关的协议 三、HTTP请求特征 四、HTTP组成格式 五、HTTP标头 1.通用标头 2.实体标头 3.请求标头 4.响应标头 六、HTTP状态码分类 我们在日常测试过程中&#xff0c;也可以通过浏览器F12简单定位是前端问题还是后端问题&a…

Linux mrd命令教程:如何删除MS-DOS文件系统中的目录(附实例教程和注意事项)

Linux mrd命令介绍 mrd命令是用于删除MS-DOS文件系统中的目录。这是mtools工具指令&#xff0c;模拟MS-DOS的rd指令&#xff0c;可以删除MS-DOS的目录。 Linux mrd命令适用的Linux版本 mrd命令在所有主流的Linux发行版中都可以使用&#xff0c;包括但不限于Ubuntu&#xff0…

KeyError: ‘model_state_dict‘

问题 加载模型权重文件时获取model_state_dict键失败 解决 单步调试发现保存模型权重时正确保存了该键值对&#xff0c;再次调试时发现莫名奇妙又没错了 首先确认保存模型时的状态字典键名&#xff1a;确保在保存模型权重时&#xff0c;正确地使用了 model.state_dict() 方法…

局部与整体的关联特性,如图所示

局部与整体的关联特性是指事物的局部部分与整体之间存在一定的关联关系。它强调整体是由局部构成&#xff0c;局部又反向影响整体。具体包括以下几个方面的特性&#xff1a; 互依性&#xff1a;局部与整体相互依赖&#xff0c;一个的变动会影响另一个的变动。局部的变化会对整体…

Python-CSV文件的存储

CSV文件存储 CSV其文件以纯文本形式存储表格数据。CSV文件是一个字符序列&#xff0c;可以由任意数目的记录组成&#xff0c;各种记录由某种换行符分隔开。它比Excel文件更加简洁&#xff0c;XLS文本是电子表格&#xff0c;包含文本、数值、公式和格式等内容&#xff0c;CSV中则…

Linux系统使用超详细(六)~进程管理

目录 一、认识进程 二、进程号 2.1.进程号概念 2.2.进程号作用 三、进程查看 3.1. ps命令&#xff1a; 3.2. top命令&#xff1a; 3.3. htop命令&#xff1a; 3.4. pstree命令&#xff1a; 3.5. pgrep命令&#xff1a; 四、进程状态 五、进程优先级 六、进程优先…

neo4j图数据库安装和测试

neo4j图数据库安装和测试 1. 下载合适的neo4j软件版本。 https://we-yun.com/doc/neo4j/ https://neo4j.com/deployment-center/#enterprise 2. 下载JAVAJDK 由于neo4j是一个用Java编写的图形数据库&#xff0c;因此在安装和运行Neo4j之前&#xff0c;需要先安装Java Developm…

真机调试HarmonyOS应用报错

问题表现&#xff1a; 01/04 19:00:01: Launching com.example.simplevideo $ hdc shell am force-stop com.example.simplevideo $ hdc shell bm uninstall com.example.simplevideo $ hdc file send E:\harmony\SimpleVideo\entry\build\default\outputs\default\entry-defau…

docker (portainer 安装nginx)

汉化版步骤可以参考&#xff1a;写文章-CSDN创作中心https://mp.csdn.net/mp_blog/creation/editor/135258056 一、创建容器 二、配置端口&#xff0c;以及容器卷挂载 挂载目录配置&#xff1a;(下方截图的目录如下&#xff0c;docker 改为 mydocker&#xff0c;用docker作为根…

使用KVM命令集管理虚拟机

1、KVM基本功能管理 1&#xff09;查看命令帮助 [rootlocalhost ~]# virsh -h ......//省略输出内容 2&#xff09;查看KVM的配置文件存放目录&#xff08;rhel7.1是虚拟机系统实例的配置文件&#xff09; [rootlocalhost ~]# ls /etc/libvirt/qemu autostart networks r…