今天发现一个提升图片加载速度的方法就是使用服务器代理

最近在做我的网站的时候,发现调用nano banana接口时,返回的图片是一个国外地址,国内在客户端加载的时候会比较慢。于是研究了下如何提高速度,问了AI找到一个简单的方法,就是使用服务器代理。

php 复制代码
export async function GET(request: NextRequest) {
  try {
    const { searchParams } = new URL(request.url);
    const imageUrl = searchParams.get('url');
    
    if (!imageUrl) {
      return NextResponse.json({ error: 'Missing image URL' }, { status: 400 });
    }

    // 验证URL是否安全
    if (!imageUrl.startsWith('http://') && !imageUrl.startsWith('https://')) {
      return NextResponse.json({ error: 'Invalid URL' }, { status: 400 });
    }

    // 下载图片
    const response = await fetch(imageUrl, {
      headers: {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36',
        'Accept': 'image/*',
      },
      // 设置超时
      signal: AbortSignal.timeout(30000), // 30秒超时
    });
    
    if (!response.ok) {
      return NextResponse.json({ error: 'Failed to fetch image' }, { status: 500 });
    }

    const imageBuffer = await response.arrayBuffer();
    const contentType = response.headers.get('content-type') || 'image/jpeg';

    // 返回图片数据,设置缓存头
    return new NextResponse(imageBuffer, {
      headers: {
        'Content-Type': contentType,
        'Cache-Control': 'public, max-age=31536000, immutable', // 缓存1年
        'Access-Control-Allow-Origin': '*',
        'Access-Control-Allow-Methods': 'GET',
        'Access-Control-Allow-Headers': 'Content-Type',
        'Content-Length': imageBuffer.byteLength.toString(),
      },
    });

  } catch (error) {
    console.error('Proxy image error:', error);
    return NextResponse.json({ error: 'Internal server error' }, { status: 500 });
  }
}

然后在后端生成图片之后,调用服务器代理。

javascript 复制代码
if (generatedImageUrl && typeof generatedImageUrl === 'string' && generatedImageUrl.startsWith('http')) {
                try {
                  // 使用代理URL,这样图片会通过你的服务器加载,速度更快
                  const proxyUrl = `/api/proxy-image?url=${encodeURIComponent(generatedImageUrl)}`;
                  generatedImageUrl = proxyUrl;
                } catch (conversionError) {
                  console.error('Failed to create proxy URL:', conversionError);
                  // 如果转换失败,保持原URL
                }
              }

这样处理之后,加载图片快多了。不知道这样会不会对服务端性能有啥影响,有其他更好的办法吗,比如在服务端转化为base64位图片。

相关推荐
不可食用盐15 小时前
# AI开发基于 Tauri 2 + React 的所见即所得 Markdown 编辑器
react.js·rust·ai编程
光影少年17 小时前
useMemo 与 useCallback 区别、各自解决什么性能问题、依赖陷阱
react.js·前端框架·掘金·金石计划
骑自行车的码农20 小时前
react hooks原理:为什么不能在条件中使用 hook ?
vue.js·react.js
Highcharts.js20 小时前
无需搭建数据管道,如何快速上线投资基金筛选器?
开发语言·javascript·react.js·前端框架·highcharts
接着奏乐接着舞20 小时前
react native expo打包
javascript·react native·react.js
水云桐程序员1 天前
Web应用的分类
前端·javascript·vue.js·react.js·webkit
暗不需求1 天前
深入理解 React 受控组件与非受控组件:从源码到面试
前端·react.js·面试
声声codeGrandMaster1 天前
React框架的基础代码使用
前端·react.js·前端框架
Highcharts.js1 天前
Highcharts React 5.0 正式版:支持 ES 模块化、组件更精简、开发体验全面升级
前端·javascript·react.js·elasticsearch·前端框架·highcharts
光影少年1 天前
react的useRef 作用:获取DOM、保存可变数据、区别 createRef
前端·javascript·react.js