proxy.js 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. var express = require('express');
  2. var router = express.Router();
  3. const fetch = require('node-fetch');
  4. // 代理请求的中间件
  5. router.use('/', async (req, res) => {
  6. console.log(`proxy req.url = ${req.url}`);
  7. const targetUrl = `http://color.jccytech.cn${req.url}`; // 替换为目标服务器的 URL
  8. const method = req.method;
  9. const headers = {
  10. ...req.headers,
  11. // 可能需要根据目标服务器的要求调整或添加请求头
  12. };
  13. // 如果请求包含请求体(例如 POST 请求),则读取它
  14. let body;
  15. if (req.method === 'POST' || req.method === 'PUT') {
  16. body = await getRawBody(req); // 使用 getRawBody 函数读取请求体
  17. }
  18. try {
  19. const response = await fetch(targetUrl, {
  20. method,
  21. headers,
  22. body,
  23. });
  24. // 在这里添加 CORS 响应头
  25. res.setHeader('Access-Control-Allow-Origin', '*');
  26. res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
  27. res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With');
  28. // 将目标服务器的响应转发给客户端
  29. const responseData = await response.buffer(); // 获取响应的 Buffer
  30. res.status(response.status).send(responseData);
  31. } catch (error) {
  32. // 处理错误,并将错误信息返回给客户端
  33. console.error('Proxy error:', error);
  34. res.status(500).send('Internal Server Error');
  35. }
  36. });
  37. // 辅助函数:读取请求体的原始数据
  38. async function getRawBody(req) {
  39. return new Promise((resolve, reject) => {
  40. let chunks = [];
  41. req.on('data', (chunk) => {
  42. chunks.push(chunk);
  43. });
  44. req.on('end', () => {
  45. resolve(Buffer.concat(chunks));
  46. });
  47. req.on('error', reject);
  48. });
  49. }
  50. module.exports = router;