CORS Anywhere:解锁跨域限制
约 702 字大约 2 分钟...
CORS Anywhere 是一个基于 NodeJS 的代理服务,它通过向跨源请求中注入 CORS(跨源资源共享)头部,实现了跨域访问的功能。这个服务的存在是基于浏览器的同源策略:通常,浏览器会阻止前端 JavaScript 代码从一个域访问另一个域的内容,除非被访问的域设置了合适的 CORS 头部。借助 CORS Anywhere,这些浏览器的安全限制就可以被轻松绕过。
若你想要自行部署 CORS Anywhere,可以自建镜像,或者使用我提供的预先配置好的 Docker 镜像 rockben/cors-anywhere。
部署代码
推荐通过 Docker Compose 部署 CORS Anywhere,详情请见 Docker Compose 部署教程。以下是 Docker Compose 配置示例:
version: "3"
services:
cors-anywhere:
image: ghcr.io/rockbenben/cors-anywhere
container_name: cors-anywhere
ports:
- "49152:8080"
restart: unless-stopped
部署完成后,通过访问 http://<你的服务器IP或域名>:49152
,你就能开始使用 CORS Anywhere API 服务。
在前端项目中使用 CORS Anywhere 非常直接,以下是一个简单的 AJAX 请求示例:
var corsAnywhereUrl = "http://192.168.2.3:49152/";
var targetUrl = "http://example.com/";
$.ajax({
type: "get",
// 使用 CORS Anywhere URL 前缀和目标 URL
url: corsAnywhereUrl + targetUrl,
success: function (data) {
// 展示从资源获取的数据
$("#rawid").val(data);
},
});
构建自定义 Docker 镜像
cors-anywhere 镜像已同步到 ghro.io 和 docker hub。
## ghcr.io(国内推荐)
docker run -d -p 49152:8080 --name cors-anywhere ghcr.io/rockbenben/cors-anywhere
## docker hub
docker run -d -p 49152:8080 --name cors-anywhere rockben/cors-anywhere
如果你有自定义 CORS Anywhere 配置的需求,可以根据以下 Dockerfile 来构建专属镜像:
# 使用 Alpine 为基础镜像,该镜像体积较小
FROM node:lts-alpine as builder
WORKDIR /app
# 克隆 CORS Anywhere 的代码,并清理 git 以及其它不必要的文件
RUN apk add --no-cache git && \
git clone https://github.com/Rob--W/cors-anywhere.git . && \
npm install && \
apk del git && \
npm cache clean --force && \
rm -rf /var/cache/apk/* /tmp/* /var/tmp/*
# 使用多阶段构建
FROM node:lts-alpine
WORKDIR /app
# 从上一个阶段拷贝构建好的 node_modules 目录和必要的文件
COPY --from=builder /app/node_modules ./node_modules/
COPY --from=builder /app/lib/ ./lib/
COPY --from=builder /app/server.js ./server.js
# 设置服务运行的端口
EXPOSE 8080
# 启动服务
CMD ["node", "server.js"]
在 Dockerfile 所在的目录下,执行以下命令即可构建并运行 cors-anywhere:
# 构建 Docker 镜像
sudo docker build -t cors-anywhere .
# 运行 Docker 容器
sudo docker run -d --name cors-anywhere -p 49152:8080 cors-anywhere
通过上述步骤,你可以快速部署并开始使用 CORS Anywhere,轻松解锁跨域访问的限制,使前端开发更加灵活和便捷。如果你在部署或使用过程中遇到任何问题,欢迎在评论区留言交流,我们可以一起探讨解决方案。