Nuxt3【服务器】server 详解
server 文件夹中的内容,会被自动注册为API和服务器处理程序。
服务器 API
对应路径 server/api
server/api/hello.ts
export default defineEventHandler((event) => {return {hello: 'world'}
})
页面中使用
<script setup lang="ts">
const { data } = await useFetch('/api/hello')
</script><template><pre>{{ data }}</pre>
</template>
动态参数 []
server/api/hello/[name].ts
export default defineEventHandler((event) => {const name = getRouterParam(event, 'name')return `Hello, ${name}!`
})
[…slug].ts 全匹配
捕获所有API,并通过 event.context.params.slug 访问匹配的内容
export default defineEventHandler((event) => {// 访问 /api/bar/baz ,则 event.context.params.slug 获取路由段:'bar/baz'return `Default foo handler`
})
定义HTTP方法
文件名中使用.get、.post、.put、.delete等后缀来定义HTTP方法
server/api/test.get.ts
export default defineEventHandler(() => 'Test get handler')
GET方法请求 /test 会返回Test get handler
获取 GET 方法中的参数 getQuery
如查询 /api/query?foo=bar&baz=qux
server/api/query.get.ts
export default defineEventHandler((event) => {const query = getQuery(event)return { a: query.foo, b: query.baz }
})
获取 POST 中的请求体 readBody
server/api/submit.post.ts
export default defineEventHandler(async (event) => {const body = await readBody(event)return { body }
})
获取运行时配置 useRuntimeConfig
export default defineEventHandler(async (event) => {const config = useRuntimeConfig(event)const repo = await $fetch('https://api.github.com/repos/nuxt/nuxt', {headers: {Authorization: `token ${config.githubToken}`}})return repo
})
配置信息在 nuxt.config.ts 中定义
export default defineNuxtConfig({runtimeConfig: {githubToken: ''}
})
获取和设置 Cookie 信息
方式一:parseCookies
export default defineEventHandler((event) => {const cookies = parseCookies(event)return { cookies }
})
**方式二:getCookie 和 setCookie **
来自 h3 包
export default defineEventHandler(event => {// 读取counter cookielet counter = getCookie(event, 'counter') || 0// 将counter cookie增加1setCookie(event, 'counter', ++counter)// 发送JSON响应return { counter }
})
错误处理
- 没有抛出错误,将返回状态码200 OK
- 任何未捕获的错误都将返回500 Internal Server Error
- 返回其他错误代码,请使用createError抛出异常
server/api/validation/[id].ts
export default defineEventHandler((event) => {const id = parseInt(event.context.params.id) as numberif (!Number.isInteger(id)) {throw createError({statusCode: 400,statusMessage: 'ID should be an integer',})}return 'All good'
})
状态码
返回其他状态码,请使用setResponseStatus实用程序。
server/api/validation/[id].ts
export default defineEventHandler((event) => {// 返回202 AcceptedsetResponseStatus(event, 202)
})
重定向 sendRedirect
export default defineEventHandler(async (event) => {await sendRedirect(event, '/path/redirect/to', 302)
})
服务器路由
对应路径 server/routes
server/routes/hello.ts
export default defineEventHandler(() => 'Hello World!')
即定义了 /hello 路由
服务器中间件
对应路径 server/middleware
中间件处理程序将在任何其他服务器路由之前在每个请求上运行,以添加或检查标头、记录请求或扩展事件的请求对象。
- 中间件处理程序不应返回任何内容(也不应关闭或响应请求),只能检查或扩展请求上下文或抛出错误。
server/middleware/log.ts
export default defineEventHandler((event) => {console.log('New request: ' + getRequestURL(event))
})
server/middleware/auth.ts
export default defineEventHandler((event) => {event.context.auth = { user: 123 }
})
服务器插件
对应路径 server/plugins
它们会被注册为Nitro插件。这允许扩展Nitro的运行时行为并钩入生命周期事件。
server/plugins/nitroPlugin.ts
export default defineNitroPlugin((nitroApp) => {console.log('Nitro plugin', nitroApp)
})
服务器工具
对应路径 server/utils
可以添加更多的自定义辅助函数
server/utils/handler.ts
import type { EventHandler, EventHandlerRequest } from 'h3'export const defineWrappedResponseHandler = <T extends EventHandlerRequest, D> (handler: EventHandler<T, D>
): EventHandler<T, D> =>defineEventHandler<T>(async event => {try {// 在路由处理程序之前执行某些操作const response = await handler(event)// 在路由处理程序之后执行某些操作return { response }} catch (err) {// 错误处理return { err }}})
服务器类型
对应路径 server/tsconfig.json
Nuxt >= 3.5 版本中可用
下方代码可提高IDE中对来自’nitro’和’vue’的自动导入的清晰度
server/tsconfig.json
{"extends": "../.nuxt/tsconfig.server.json"
}
服务器类型
对应路径 server/tsconfig.json
相关文章:
Nuxt3【服务器】server 详解
server 文件夹中的内容,会被自动注册为API和服务器处理程序。 服务器 API 对应路径 server/api server/api/hello.ts export default defineEventHandler((event) > {return {hello: world} })页面中使用 <script setup lang"ts"> const { da…...
防火墙技术原理与应用
防火墙概述 防火墙概念 防火墙:通过一种网络安全设备,控制安全区域间的通信,隔离有害通信,进而阻断网络攻击。一般安装在不同安全区域边界处,用于网络通信安全控制,由专用硬件或软件系统组成。 根据网络安全信任程度和需保护的对象,划分安全区域 公共外部网络:Inter…...
【BUU】[NewStarCTF 2023 公开赛道]Final -CP读取文件内容
漏洞检测 访问首页发现是ThinkPHP5 的站点 用工具扫描一下,发现存在ThinkPHP5.0.23 RCE漏洞 访问验证,写入shell 成功写入shell. 根目录发现flag,但是权限不足 提权获取flag 准备提权,这里一开始尝试了find,但是find权限不足 尝试采用cp命令,移动到web目录,发现访问还是…...
火绒安全:一款强大且高效的国产杀毒软件
火绒安全(Huorong Security)是一款国产的杀毒软件,以其轻量、高效和对系统资源占用低的特点受到广泛欢迎。与许多其他杀毒软件不同,火绒注重低调实用,旨在为用户提供无干扰且稳定的系统保护。 火绒安全的主要特点&…...
Oracle 的DBA有哪些权限
Oracle数据库的**DBA(数据库管理员)**拥有全部特权,是Oracle数据库系统最高权限的用户。DBA的权限包括但不限于: 1.创建和管理数据库结构: DBA可以创建、修改和删除数据库中的所有对象,如表、索引、视图等&…...
在navicat上运行sql文件
前言 本文简单介绍在navicat上运行sql文件 第一步: 打开navicat,点击连接->mysql 第二步: 输入连接名,可以随便取 然后点击确定 第三步: 双击连接名,颜色变化代表连接上了 第四步࿱…...
STM32裸机和RTOS中的线程安全问题及STM32cubeMX中的线程安全策略
STM32线程安全问题 术语“线程” 和“多线程” 适用于裸机和基于RTOS的应用程序,线程安全问题并不只存在于基于RTOS的应用程序中;裸机应用程序中也存在这个问题,在裸机应用程序中,中断服务程序允许调用C库函数。线程安全问题可能…...
图的遍历
一、深度优先遍历(DFS) 二、广度优先遍历(BFS)...
CUDA-MODE课程笔记 第8课: CUDA性能检查清单
我的课程笔记,欢迎关注:https://github.com/BBuf/how-to-optim-algorithm-in-cuda/tree/master/cuda-mode CUDA-MODE课程笔记 第8课: CUDA性能检查清单 课程笔记 这节课实际上算是CUDA-MODE 课程笔记 第一课: 如何在 PyTorch 中 profile CUDA kernels 这…...
【备战蓝桥杯青少组】第二天 奇特的砖墙
真题 第十四届省赛 编程题 第5题 工人砌了一面奇特的砖墙,该墙由N列砖组成(1≤N≤1e6),且每列砖的数量为Ki(1≤Ki≤1e4,相邻砖块之间无缝隙),每块砖的长宽高都为1。小蓝为了美化这面…...
图像处理 -- 仿射变换之Affine Transformation
仿射变换(Affine Transformation) 仿射变换是图像处理中的一种基本操作,通过线性变换和平移实现图像的几何变换。仿射变换包括旋转、缩放、平移、翻转、错切(shear)等操作。 1. 仿射变换的作用 旋转:将图…...
Nuxt3【项目配置】nuxt.config.ts
按环境添加配置 export default defineNuxtConfig({// 生产环境的配置$production: {routeRules: {/**: { isr: true }}},// 开发环境的配置$development: {//} })运行时的配置 runtimeConfig export default defineNuxtConfig({runtimeConfig: {// 只在服务器端可用的私有键ap…...
中智讯“2024高校人工智能边缘应用项目实战师资培训班”圆满举办
7月24日——7月28日,中智讯“2024高校人工智能&边缘应用项目实战师资培训班”在昆明理工大学成功举办。本次培训由昆明理工大学人工智能产业学院主办,中智讯(武汉)科技有限公司承办。来自昆明理工大学、西南林业大学、云南民族…...
IIS发布打包后文件
1.打开IIS软件 2 添加网站, 自定义网站名称-选择要放置的资源路径-选择IP地址 3.打开放置的资源目录放置打包后文件 4.选择浏览 搜索不到IIS可进行一下操作 控制面板-程序和功能-启用或关闭windows功能-勾选IIS...
四个自定义 SHAP 图
超越 Python 包,创建 SHAP 值的定制可视化 SHAP 值是了解模型如何进行预测的绝佳工具。SHAP 包提供了许多可视化效果,使这个过程更加简单。话虽如此,我们不必完全依赖这个包。我们可以通过创建自己的 SHAP 图来进一步了解模型的工作原理。在本…...
为什么使用HTTPS?
HTTPS现在是所有Web活动的首选协议,因为它是用户保护敏感信息的最安全方式。 HTTPS不仅对请求用户信息的网站至关重要。除了用户直接发送的信息外,攻击者还可以从不安全的连接中跟踪行为和身份数据。 HTTP为网站所有者带来的好处除了数据安全之外&…...
软件设计-系统架构师(五十五)
1在网络规划中,政府内外网之间应该部署网络安全防护设备。在下图部署的设备A是(),对设备A作用描述错误的是()。 问题1 A IDS B 防火墙 C 网闸 D UTM 问题2 A 双主机系统,即使外网被黑客攻击…...
三分钟学会线缆电流估算
今天带你用三分钟的时间,学会电源线承受电流估算,不浪费时间,直接开始吧。 工作温度30℃,长期连续90%负载下的载流量 1.5平方毫米――14A 2.5平方毫米――26A 4平方毫米――32A 6平方毫米――47A 16平方毫米――92A 25平方毫米――120A 3…...
Snipaste 的一款替代工具 PixPin,支持 gif 截图、长截图和 OCR 文字识别,功能不是一点点强!
Snipaste 的一款替代工具 PixPin,支持 gif 截图、长截图和 OCR 文字识别,功能不是一点点强! PixPin 的名字来源于“Pixel Pin”,简单来说是一个截图、贴图的工具,但是 PixPin 以截图和贴图两大功能为核心做了大量的优…...
Oracle基础教程
体系结构 数据库 一个操作系统仅有一个数据库 实例 拥有一系列后台进程和存储结构,一个数据库可拥有一个或多个实例,一般只有1个实例 数据文件(.dbf/.ora) 数据文件是数据库的物理存储单元,一个表空间由一个或多…...
ThinkPad散热控制新境界:TPFanCtrl2全方位应用指南
ThinkPad散热控制新境界:TPFanCtrl2全方位应用指南 【免费下载链接】TPFanCtrl2 ThinkPad Fan Control 2 (Dual Fan) for Windows 10 and 11 项目地址: https://gitcode.com/gh_mirrors/tp/TPFanCtrl2 一、核心价值解析:为何选择TPFanCtrl2 突破…...
从HTTP/3看TCP的困境:QUIC协议如何用UDP实现可靠传输?对比Wireshark抓包实例
HTTP/3时代TCP的困境与QUIC协议的革新之路 当你在手机上观看YouTube视频时,是否注意到缓冲速度比几年前快了许多?这背后隐藏着一场互联网传输协议的静默革命。传统TCP协议在移动互联网时代暴露出诸多局限性,而基于UDP的QUIC协议正在悄然改变游…...
掌握VESC Tool:从零到精通的电机控制调试指南
掌握VESC Tool:从零到精通的电机控制调试指南 【免费下载链接】vesc_tool The source code for VESC Tool. See vesc-project.com 项目地址: https://gitcode.com/gh_mirrors/ve/vesc_tool 想要轻松驾驭无刷电机,实现电动滑板、平衡车或机器人项目…...
AI 模型推理延迟优化方案
AI模型推理延迟优化方案:提升效率的关键路径 在人工智能技术快速发展的今天,AI模型的推理延迟已成为影响用户体验和系统性能的关键因素。无论是实时语音识别、自动驾驶,还是在线推荐系统,高延迟都会导致响应缓慢,甚至…...
【python】MacOS下永久配置pip镜像源
核心方法:修改 pip 的配置文件在 macOS 上,您需要创建或修改一个位于用户主目录下的配置文件 pip.conf。详细步骤第一步:打开终端按 Command 空格键 打开 Spotlight 搜索。输入“终端”或“Terminal”,然后按回车键打开。第二步&…...
KART-RERANK在AIGC内容审核中的应用:自动化识别与排序低质生成文本
KART-RERANK在AIGC内容审核中的应用:自动化识别与排序低质生成文本 1. 引言 现在打开任何一个内容平台,无论是文章、评论还是商品描述,你都能看到大量由AI生成的内容。这些内容来得快、数量多,但质量却参差不齐。有的写得有模有…...
NeuroKit2深度解析:Python神经生理信号处理的进阶实战指南
NeuroKit2深度解析:Python神经生理信号处理的进阶实战指南 【免费下载链接】NeuroKit NeuroKit2: The Python Toolbox for Neurophysiological Signal Processing 项目地址: https://gitcode.com/gh_mirrors/ne/NeuroKit 在当今神经科学和生物医学工程领域&a…...
后软件时代:当交互成为本能
从显式操作到隐式协同,从界面到无界 范式转移:从“使用工具”到“与伙伴共存” 当软件不再以独立形态存在,交互的本质将从主动操作变为自然协同。这不仅是技术变革,更是人类与机器关系的根本重构。 交互层级的演进 第一层:意图直连 过去:打开App → 点击按钮 → 输入…...
实战构建多房间直播平台:基于快马AI生成核心业务代码框架
今天想和大家分享一个实战项目的搭建过程——多房间直播平台。这个项目涉及高并发、实时交互等典型直播场景需求,正好用InsCode(快马)平台来快速验证核心功能。以下是具体实现思路和关键设计: 整体架构设计 直播平台的核心在于实时性和扩展性。采用前后端…...
基于Yalmip+Matlab的主从博弈优化:电动汽车充电定价策略实战解析
1. 主从博弈与电动汽车充电定价的实战背景 当你在手机APP上查看不同时段的充电价格时,背后其实隐藏着一场精妙的数学博弈。充电站运营商希望最大化收益,而车主则追求最低充电成本,这种"定价-响应"的互动关系,正是典型的…...
