JavaScript 获取短链接原始地址的解决方案

JavaScript 获取短链接原始地址的解决方案

📦 方法 1:服务器代理(推荐)

前端代码

javascript 复制代码
async function getOriginalUrl(shortUrl) {
  try {
    const response = await fetch(`/api/unshorten?url=${encodeURIComponent(shortUrl)}`);
    const data = await response.json();
    return data.originalUrl;
  } catch (error) {
    console.error("获取失败:", error);
  }
}

// 使用示例
getOriginalUrl("https://s.coze.cn/t/45uxprrK8vU/")
  .then(original => console.log("原始链接:", original));

Node.js 服务器端代码

javascript 复制代码
const express = require('express');
const axios = require('axios');
const app = express();

app.get('/api/unshorten', async (req, res) => {
  const shortUrl = req.query.url;
  try {
    const response = await axios.head(shortUrl, { maxRedirects: 0 });
    
    // 检测重定向状态码 (301/302)
    if ([301, 302].includes(response.status)) {
      res.json({ originalUrl: response.headers.location });
    } else {
      res.json({ originalUrl: shortUrl });
    }
  } catch (error) {
    if (error.response?.status === 302 && error.response.headers.location) {
      res.json({ originalUrl: error.response.headers.location });
    } else {
      res.status(500).json({ error: "解析失败" });
    }
  }
});

app.listen(3000, () => console.log('Server running on port 3000'));

优点

  • 避开浏览器 CORS 限制
  • 完全可控
  • 可添加缓存/安全验证

缺点

  • 需要搭建后端服务

🌐 方法 2:纯前端尝试(受限)

javascript 复制代码
async function getOriginalUrl(shortUrl) {
  try {
    const response = await fetch(shortUrl, {
      method: 'HEAD',
      redirect: 'manual'
    });
    
    if ([301, 302].includes(response.status)) {
      return response.headers.get('location');
    }
    return shortUrl;
  } catch (error) {
    console.error("请求失败:", error);
  }
}

注意

  • 大多数短链接服务(如 s.coze.cn)会因 CORS 限制失败
  • 仅适用于设置了 Access-Control-Allow-Origin 的服务

🔌 方法 3:使用第三方 API

javascript 复制代码
async function getOriginalUrl(shortUrl) {
  const API_KEY = "YOUR_API_KEY";
  const apiUrl = `https://unshorten.me/api/v2/unshorten?url=${shortUrl}`;
  
  try {
    const response = await fetch(apiUrl, { 
      headers: { "Authorization": API_KEY } 
    });
    const data = await response.json();
    return data.resolved_url;
  } catch (error) {
    console.error("解析失败:", error);
  }
}

常用服务

⚠️ 重要注意事项

  1. 浏览器限制:前端直接获取受 CORS 策略限制
  2. 安全风险
    • 短链接可能指向恶意网站
    • 建议服务器端进行安全验证
  3. 服务稳定性
    • 短链接服务可能变更策略导致解析失效
    • 建议添加错误处理和重试机制
  4. 性能优化
    • 添加缓存机制(localStorage/服务器缓存)
    • 避免频繁请求同一短链接

推荐方案:优先使用服务器代理方案(方法1),提供最大的灵活性和可控性

相关推荐
tedcloud12311 小时前
UI-TARS-desktop部署教程:构建AI桌面自动化系统
服务器·前端·人工智能·ui·自动化·github
UXbot14 小时前
AI原型设计工具如何支持团队协作与快速迭代
前端·交互·个人开发·ai编程·原型模式
ZC跨境爬虫15 小时前
跟着MDN学HTML_day_48:(Node接口)
前端·javascript·ui·html·音视频
PieroPc17 小时前
CAMWATCH — 局域网摄像头监控系统 Fastapi + html
前端·python·html·fastapi·监控
巴巴博一18 小时前
2026 最新:Trae / Cursor 一键接入 taste-skill 完整教程(让 AI 前端告别“AI 味”)
前端·ai·ai编程
kyriewen18 小时前
半夜三点线上崩了,AI替我背了锅——用AI排错,五分钟定位三年老bug
前端·javascript·ai编程
kyriewen18 小时前
我让 AI 当了 24 小时全年无休的“毒舌考官”
前端·ci/cd·ai编程
hexu_blog18 小时前
vue+java实现图片批量压缩
java·前端·vue.js
IT_陈寒19 小时前
为什么你应该学习JavaScript?
前端·人工智能·后端
lifejump19 小时前
Empire(帝国)CMS 7.5 XSS注入
前端·安全·xss