nuxt中访问外部图片链接 403

本文指导你在Nuxt项目中遇到403错误时,如何通过设置`referrer`头部和修改本地hosts来解决图片防盗链问题。首先,更新nuxt.config.js的meta部分,然后考虑支付功能可能带来的影响并适当调整。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

nuxt中访问外部图片链接 403

1、在nuxt.config.js文件中找到meta
2、在 meta 中 添加 { name: ‘referrer’, content: ‘no-referrer’ },配置保存即可

head: {
    title: process.env.npm_package_name || 'GoFunny',
    meta: [
      { charset: 'utf-8' },
      { name: 'viewport', content: 'width=device-width, initial-scale=1,user-scalable=0' },
      { name: 'referrer', content: 'no-referrer' },
      { hid: 'description', name: 'description', content: '' }
      //在此处添加
      { name: 'referrer', content: 'no-referrer' },
    ]
  },

3、如果有支付功能的话可能会出现问题,403也有可能是运维设置了图片防盗链,修改本机hosts文件即可

### Nuxt 3 中动态加载和使用本地图片的方法 在 Nuxt 3 项目中,为了实现本地图片的动态加载,可以利用 Vue 的 `require` 或者 ES Module 的 `import()` 函数来处理静态资源路径。对于更现代的方式,则推荐采用 URL 路径结合公共目录下的文件夹结构[^1]。 当涉及到组件内部或者页面逻辑里动态获取图像时,可以通过如下方式完成: #### 方法一:通过 require 动态引入 如果已知图片名称并希望基于某些条件改变显示哪张图的话,可以在模板部分这样写: ```vue <template> <img :src="getImagePath(imageName)" alt="Dynamic Image"> </template> <script setup> function getImagePath(name) { return new URL(`/assets/images/${name}`, import.meta.url).href; } </script> ``` 这里假设所有的图片都存放在 `/assets/images/` 文件夹下,并且可以根据变量 `imageName` 来决定具体要展示哪一个[^2]。 #### 方法二:使用 Vite 插件特性 (推荐) 由于 Nuxt 3 基于 Vite 构建工具链,在开发过程中可以直接引用位于源码树中的任何地方的媒体文件而无需额外配置。只需要确保这些资源被放置在一个合适的子目录内即可访问它们。 例如,创建名为 `public/uploads/photo.jpg` 的图片后,就可以像下面这样做: ```html <img src="/uploads/photo.jpg" /> ``` 这种方式适用于那些不需要打包到最终构建产物里的大尺寸素材或者是预期会经常变动的内容[^3]。 另外需要注意的是,如果是 SSR 场景下使用动态路径,请务必确认所使用的解决方案能够在服务端正常工作,因为有些方法可能仅限客户端有效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值