Node.js 实现一个 HTTP/2 的例子

要在前端使用 HTTP/2,通常不需要在 JavaScript 代码中做特殊处理,因为 HTTP/2 是在网络传输层处理的,浏览器会自动处理请求的协议选择。然而,可以通过设置一个简单的项目,使用 HTTP/2 来加载资源,并通过浏览器的开发者工具来查看 HTTP/2 的效果。

示例说明

创建一个简单的 Node.js 服务器,它使用 HTTP/2 提供静态文件。然后在前端 JavaScript 中发起请求来加载一些资源。

1. 创建一个 Node.js HTTP/2 服务器

首先,确保已经安装了 Node.js。接着,创建一个目录来存放项目文件:

mkdir http2-demo
cd http2-demo
npm init -y
npm install express spdy

spdy 是一个 Node.js 模块,帮助我们在 Express 中轻松启用 HTTP/2。

server.js 文件

创建一个简单的 HTTP/2 服务器来提供静态文件服务:

const express = require('express');
const spdy = require('spdy');
const fs = require('fs');
const path = require('path');const app = express();// 提供静态文件服务
app.use(express.static(path.join(__dirname, 'public')));// 设置一个简单的API
app.get('/api/data', (req, res) => {res.json({ message: "Hello from HTTP/2!" });
});// 配置 HTTPS(需要 SSL/TLS 证书)
const options = {key: fs.readFileSync('server.key'),cert: fs.readFileSync('server.crt')
};// 启动服务器
spdy.createServer(options, app).listen(3000, (err) => {if (err) {console.error('Failed to start server:', err);return;}console.log('HTTP/2 server listening on port 3000');
});

注意:需要生成或获取 SSL/TLS 证书server.keyserver.crt`,可以通过自签名证书进行开发测试,或者使用 Let’s Encrypt 等服务获取免费证书。

生成自签名证书(开发用途)

如果没有现成的 SSL/TLS 证书,可以用以下命令生成自签名证书:

openssl req -nodes -new -x509 -keyout server.key -out server.crt -days 365

2. 创建前端页面

public 目录下创建 index.htmlscript.js 文件。

public/index.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>HTTP/2 Demo</title>
</head>
<body><h1>HTTP/2 Demo</h1><button id="fetchButton">Fetch Data</button><p id="response"></p><script src="script.js"></script>
</body>
</html>

public/script.js

document.getElementById('fetchButton').addEventListener('click', () => {fetch('/api/data').then(response => response.json()).then(data => {document.getElementById('response').textContent = data.message;}).catch(error => console.error('Error fetching data:', error));
});

3. 运行服务器

确保所有文件都准备好后,启动服务器:

node server.js

服务器将会在 https://localhost:3000 上运行。

4. 使用浏览器查看效果

打开浏览器并访问 https://localhost:3000。可能需要绕过自签名证书的警告页面。

在页面上点击 “Fetch Data” 按钮,查看来自 /api/data 的数据请求。

验证 HTTP/2

打开浏览器的开发者工具(F12),然后进入 Network 面板。刷新页面,并查看资源加载的协议列,应该能看到 h2,表示资源通过 HTTP/2 协议加载。

总结

这个示例展示了如何设置一个使用 HTTP/2 的服务器,并在前端通过 JavaScript 发起请求。由于 HTTP/2 是在传输层实现的,前端 JavaScript 并不需要对 HTTP/2 进行特殊处理,只要服务器和浏览器支持,它就会自动使用 HTTP/2 进行资源请求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/50904.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux之HTTP服务器的构建

欢迎诸位来阅读在下的博文~ 在这里&#xff0c;在下会不定期发表一些浅薄的知识和经验&#xff0c;望诸位能与在下多多交流&#xff0c;共同努力! 江山如画&#xff0c;客心如若&#xff0c;欢迎到访&#xff0c;一展风采 文章目录 参考环境参考书籍一、HTTP的工作原理1. 建立连…

Windows 11上RTX 4090深度学习与大模型微调环境安装指南

【本文原作者&#xff1a;擎创科技资深产品专家 布博士】 在安装深度学习及大模型微调环境时&#xff0c;经历了多次反复操作&#xff08;如CUDA、cuDNN、PyTorch的安装与卸载&#xff09;。为了避免走弯路&#xff0c;总结了以下步骤&#xff1a; 步骤 1&#xff1a;显卡驱动…

11-sentinel利用nacos作持久化

本文介绍sentinel配置数据的持久化方法。由于sentinel官方并没有提供持久化功能&#xff0c;大家在测试过程中也能发现sentinel服务重启后&#xff0c;原来配置的数据就丢了&#xff0c;本文就是来处理这一问题的。 做好心理准备&#xff0c;我们要修改sentinel的源代码&#…

Qt消息对话框的实现

Widget.cpp #include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);this -> setWindowIcon(QIcon(":/picture/hp.jpg"));//设置窗口图标this -> setW…

Leetcode JAVA刷刷站(57)插入区间

一、题目概述 二、思路方向 为了解决这个问题&#xff0c;我们可以遍历给定的区间列表 intervals&#xff0c;并同时构建一个新的列表来存储最终的合并结果。遍历过程中&#xff0c;我们检查当前区间是否与 newInterval 重叠或相邻&#xff0c;并根据需要进行合并。如果不重叠…

2024新生训练营 8.20 做题活动

A 输出题罢了不讲直接看代码 #inlclude<stdio.h> int main() {printf("Eclipse First&#xff0c;the Rest Nowhere.");return 0; }B 首先要知道的是凡是大于1的整数要么是质数要么是合数&#xff0c;而1既不是质数也不是合数&#xff0c;题目问从0到n所有质数…

高级java每日一道面试题-2024年8月16日-设计模式篇-解释装饰者模式和代理模式的区别?

如果有遗漏,评论区告诉我进行补充 面试官: 解释装饰者模式和代理模式的区别&#xff1f; 我回答: 在Java中&#xff0c;装饰者模式&#xff08;Decorator Pattern&#xff09;和代理模式&#xff08;Proxy Pattern&#xff09;都是常用的设计模式&#xff0c;它们在结构上看…

微信小程序--30(网络数据请求)

1.小程序中网络数据请求的限制 只能请求HTTPS类型的接口必须将接口的域名添加到信任列表中 2.配置request合法域名 需求描述 希望请求某个域名下的接口 步骤 登录小程序管理后台→开发→开发设置→服务器域名→修改request合法域名 练习 注意事项 域…

TensorFlow和它的弟弟们

TensorFlow、TensorFlow Lite、TensorFlow Lite Micro是Google在深度学习领域推出的三个不同产品&#xff0c;它们各自有着不同的设计目标和适用场景。以下是它们之间的主要区别&#xff1a; 1. TensorFlow (PC\GPU) 设计目标&#xff1a;TensorFlow是一个开源的机器学习框架…

常见的GPU性能对比

写这篇博客的目的就是想搞清楚英伟达不同显卡之间的性能差异以及移动端GPU的性能达到了英伟达显卡的哪一代&#xff0c;让自己也让大家明白不同显卡的算力差异。所有的数据均从网络搜索&#xff0c;有不正确的地方欢迎批评指正。同一显卡会有一个首次发布&#xff0c;此外还有一…

系统架构:分而治之

系统架构&#xff1a;分而治之 引言“分而治之”在架构中的应用模块化设计分层化架构微服务架构 分而治之的优势降低复杂性提高灵活性和可扩展性增强可维护性促进团队协作 分而治之的劣势复杂性转移性能开销开发和运维的复杂性数据一致性挑战 结论 引言 “分而治之”是一种分析…

wo是如何克服编程学习中的挫折感的?

你是如何克服编程学习中的挫折感的&#xff1f; 编程学习之路上&#xff0c;挫折感就像一道道难以逾越的高墙&#xff0c;让许多人望而却步。然而&#xff0c;真正的编程高手都曾在这条路上跌倒过、迷茫过&#xff0c;却最终找到了突破的方法。你是如何在Bug的迷宫中找到出口的…

5.1、生成树协议stp

一、广播风暴 广播风暴&#xff08;Broadcast Storm&#xff09;是网络中的一种现象&#xff0c;通常发生在局域网&#xff08;LAN&#xff09;中。当网络中的交换机或路由器配置错误&#xff0c;或环路没有被有效控制时&#xff0c;广播帧会在网络中无限制地传播&#xff0c;…

QT基础知识4

思维导图 项目文件里面要加texttospeech模块 widget.h: #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTime>//时间类 #include <QTextToSpeech>//语音播报类QT_BEGIN_NAMESPACE namespace Ui { class Widget; } QT_END_NAMESPACEclass…

C:每日一练:单身狗(2.0版本)

前言&#xff1a; 今天在刷题的时候突然看到一道题&#xff0c;疑似一位故题。仔细一看&#xff0c;欸&#xff01;这不是就是单身狗的升级版吗&#xff1f;我想那必须再安排一篇&#xff0c;不过由于本篇文章与上一篇单身狗文章所涉及的知识点基本相同&#xff0c;所以还请大…

K8S 容器调度

在Kubernetes中&#xff0c;容器调度是一个自动化的过程&#xff0c;负责将容器&#xff08;在Kubernetes中称为Pod&#xff09;分配到集群中的合适节点上运行。这一过程由Kubernetes的调度器&#xff08;kube-scheduler&#xff09;控制&#xff0c;它通过一系列算法和策略来确…

流媒体服务器二:2.RTMP协议学习

RTMP协议详解 一.总体介绍 RTMP协议是应⽤层协议&#xff0c;是要靠底层可靠的传输层协议&#xff08;通常是TCP&#xff09;来保证信息传输的可靠性的。在 基于传输层协议的链接建⽴完成后&#xff0c;RTMP协议也要客户端和服务器通过“握⼿”来建⽴基于传输层链接之 上的RT…

(五)Flink Sink 数据输出

经过上面的 Transformation 操作之后,最终形成用户所需要的结果数据集。通常情况下,用户希望将结果数据输出到外部存储介质或者传输到下游的消息中间件中,在 Flink 中,将 DataStream 数据输出到外部系统的过程被定义为 Sink 操作。 目录 (一)基本数据输出 (二)第三方…

滴滴开源新项目Unify:聚焦Flutter与原生通信难题,助力跨端应用落地

引言 在移动开发领域&#xff0c;移动跨端技术因其提效收益&#xff0c;逐渐成为业界趋势之一。Flutter 作为近年来热门的跨端技术&#xff0c;以高性能、自渲染、泛跨端著称&#xff0c;得到广泛应用。在滴滴国际化业务中&#xff0c;我们大量应用 Flutter。目前已在滴滴国际化…

JavaScript typeof

在 JavaScript 中有 5 种不同的可以包含值的数据类型&#xff1a; stringnumberbooleanobjectfunction 有 6 种类型的对象&#xff1a; ObjectDateArrayStringNumberBoolean 以及 2 种不能包含值的数据类型&#xff1a; nullundefined typeof 运算符 您可以使用 typeof …