导航


HTML

CSS

JavaScript

浏览器 & 网络

版本管理

框架

构建工具

TypeScript

性能优化

软实力

算法

UI、组件库

Node

冷门技能

针对性攻坚(TODO)

1. ⭐️ 服务器中转(代理服务器)

    const http = require('http');
    const url = require('url');

    // 创建代理服务器
    const proxyServer = http.createServer((req, res) => {
        // 解析目标服务器的 URL
        const targetUrl = '<http://target-domain.com>' + req.url;
        const options = {
            hostname: url.parse(targetUrl).hostname,
            port: 80,
            path: url.parse(targetUrl).path,
            method: req.method,
            headers: req.headers
        };

        // 向目标服务器发送请求
        const proxyReq = http.request(options, (proxyRes) => {
            // 将目标服务器的响应返回给客户端
            res.writeHead(proxyRes.statusCode, proxyRes.headers);
            proxyRes.pipe(res);
        });

        req.pipe(proxyReq);
    });

    proxyServer.listen(3000);

2. ⭐️ document.domain + iframe

3. ⭐️ window.name + iframe

4. ⭐️ postMessage + iframe

页面 a 和页面 b 相互发消息的示例:

页面 a(父页面)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Page A</title>
</head>
<body>
    <h1>Page A</h1>
    <button id="sendToB">Send Message to B</button>
    <iframe id="iframeB" src="<http://example.com/b.html>" width="600" height="400"></iframe>

    <script>
        const iframe = document.getElementById('iframeB');

        // 发送消息给 B 页
        document.getElementById('sendToB').addEventListener('click', function() {
            const message = { text: "Hello from A!" };
            iframe.contentWindow.postMessage(message, '<http://example.com>'); // 目标源应为 B 页的真实 URL
        });

        // 接收来自 B 页的消息
        window.addEventListener('message', function(event) {
            // 验证消息来源
            if (event.origin !== '<http://example.com>') return; // 目标源应为 B 页的真实 URL

            // 处理消息
            console.log('Message from B:', event.data);
        });
    </script>
</body>
</html>

页面 b(嵌入页面)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Page B</title>
</head>
<body>
    <h1>Page B</h1>
    <button id="sendToA">Send Message to A</button>

    <script>
        // 发送消息给 A 页
        document.getElementById('sendToA').addEventListener('click', function() {
            const message = { text: "Hello from B!" };
            window.parent.postMessage(message, '<http://parent.example.com>'); // 目标源应为 A 页的真实 URL
        });

        // 接收来自 A 页的消息
        window.addEventListener('message', function(event) {
            // 验证消息来源
            if (event.origin !== '<http://parent.example.com>') return; // 目标源应为 A 页的真实 URL

            // 处理消息
            console.log('Message from A:', event.data);
        });
    </script>
</body>
</html>

说明

重要提示

通过这种方式,你可以在不同源的页面之间建立安全且有效的双向通信。

5. hash + iframe

6. ⭐️ CORS 跨域

    const http = require('http');
    const url = require('url');

    http.createServer((req, res) => {
        const origin = req.headers.origin;
        // 允许指定源访问
        res.setHeader('Access-Control-Allow-Origin', '<http://allowed-domain.com>');
        // 允许的请求方法
        res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE');
        // 允许的请求头
        res.setHeader('Access-Control-Allow-Headers', 'Content-Type');

        const data = { response: 'Data from server' };
        res.end(JSON.stringify(data));
    }).listen(8081);