68 # 中间层如何请求其他服务

简介: 68 # 中间层如何请求其他服务

前端 ajax 有跨域问题,可以先访问中间层,在通过 node 去请求别的服务端口,可以解决跨域问题

编写中间层调用

// 中间层的方式
const http = require("http");
// http.get 默认发送 get 请求
// http.request 支持其他请求格式 post
let client = http.request(
    {
        path: "/login",
        hostname: "localhost",
        port: 3000,
        method: "POST",
        headers: {
            "Content-Type": "application/json"
        }
    },
    (res) => {
        console.log("状态码", res.statusCode);
        console.log("请求头", res.headers);
        res.on("data", (chunk) => {
            console.log(chunk.toString());
        });
    }
);
client.end(`{"kaimo": "313"}`);

服务端代码:

const http = require("http");
const url = require("url");
const querystring = require("querystring");
let server = http.createServer();
server.on("request", (req, res) => {
    let { pathname } = url.parse(req.url);
    console.log("req.method---->", req.method);
    // 1)配置跨域
    // 当前请求我的源
    // res.setHeader("Access-Control-Allow-Origin", req.headers.origin);
    // 允许携带header
    // res.setHeader("Access-Control-Allow-Headers", "Content-Type,Authorization");
    // 默认支持 get 和 post
    // res.setHeader("Access-Control-Allow-Methods", "GET,POST,PUT");
    /**
     * 预检请求(Preflight Request)是跨域资源共享(CORS)的一部分,它允许在请求头中包含一些特殊信息,
     *      以便服务器确认客户端是否具有足够的权限来访问受保护的资源。
     * 预检请求通常在请求方法为 OPTIONS 时发生,以检查客户端是否能够成功请求受保护的资源。
     * */
    // 设置 OPTIONS 发送频率
    // res.setHeader("Access-Control-Max-Age", 10); // 设置缓存预检响应为 10 秒
    // 遇到 OPTIONS 预检请求,直接成功即可
    // if (req.method === "OPTIONS") {
    //     res.statusCode = "200";
    //     res.end(); // 内部会自己判断是否加了跨域头
    // }
    // 2)解析请求体
    const arr = [];
    req.on("data", (chunk) => {
        arr.push(chunk);
    });
    req.on("end", () => {
        let result = Buffer.concat(arr).toString();
        let obj;
        if (req.headers["content-type"] === "application/x-www-form-urlencoded") {
            obj = querystring.parse(result, "&", "=");
        } else if (req.headers["content-type"] === "application/json") {
            obj = JSON.parse(result);
        }
        console.log("obj---->", obj);
        // 3)根据不同路径返回对应内容
        if (pathname === "/login" && req.method == "POST") {
            res.setHeader("Content-Type", "application/json");
            res.end("登录成功");
        }
        if (pathname === "/regist" && req.method == "POST") {
            res.setHeader("Content-Type", "application/json");
            res.end(JSON.stringify(obj));
        }
    });
});
server.listen(3000);

我们启动服务端的服务,然后执行中间层

nodemon "68 # 中间层如何请求其他服务.js"
node client.js

可以看到请求成功

目录
相关文章
|
负载均衡 网络协议 安全
负载均衡4层和7层区别
所谓四层就是基于IP+端口的负载均衡;七层就是基于URL等应用层信息的负载均衡
|
5月前
|
消息中间件 缓存 监控
中间件服务层
【6月更文挑战第13天】
69 2
|
6月前
|
存储 网络协议 Linux
《网络是怎么样连接的》读书笔记 - WEB服务端请求和响应(五)
《网络是怎么样连接的》读书笔记 - WEB服务端请求和响应(五)
69 0
|
6月前
|
JavaScript 中间件 API
中间件应用请求和响应处理
【5月更文挑战第1天】中间件应用请求和响应处理
77 4
中间件应用请求和响应处理
|
5月前
|
XML 前端开发 JavaScript
后端请求响应和分层解耦web开发的三层架构
后端请求响应和分层解耦web开发的三层架构
39 0
|
6月前
|
JavaScript 中间件 Java
中间件应用程序请求接收
【5月更文挑战第13天】
43 3
|
5月前
|
Web App开发 JSON Java
JavaWeb基础第五章(请求,响应与分层解耦)
JavaWeb基础第五章(请求,响应与分层解耦)
|
6月前
|
存储 中间件 API
中间件应用程序发起读取数据的请求
【5月更文挑战第12天】中间件应用程序发起读取数据的请求
41 4
|
6月前
|
网络协议 数据库 数据安全/隐私保护
客户端一个处理多个请求的弊端及解决方案
客户端一个处理多个请求的弊端及解决方案
72 0
|
网络协议 网络架构
计算机网络模型、客户端与服务端请求与解析过程
计算机网络模型、客户端与服务端请求与解析过程
91 0