Nginx——反向代理(三/五)
目录
- 1.Nginx 反向代理
- 1.1.Nginx 反向代理概述
- 1.2.Nginx 反向代理的配置语法
- 1.2.1.proxy_pass
- 1.2.2.proxy_set_header
- 1.2.3.proxy_redirect
- 1.3.Nginx 反向代理实战
- 1.4.Nginx 的安全控制
- 1.4.1.如何使用 SSL 对流量进行加密
- 1.4.2.Nginx 添加 SSL 的支持
- 1.4.3.Nginx 的 SSL 相关指令
- 1.4.3.1.生成证书
- 1.4.3.2.开启 SSL 实例
- 1.5.反向代理系统调优
本文笔记整理自黑马程序员 Nginx 教程,相关资料可在该视频评论区中领取。
1.Nginx 反向代理
Nginx 的反向代理在现代 Web 应用架构中扮演着重要角色,其主要作用包括但不限于以下几个方面,下面将结合具体例子进行说明:
- 负载均衡:当有多个后端服务器时,Nginx 反向代理可以根据预定义的规则(如轮询、最少连接、IP哈希等)将请求分发到不同的服务器,从而平衡各服务器的负载,提高整体系统的性能和可用性。例如,假设有三台后端服务器A、B、C,Nginx 可以根据配置将请求依次或按照特定比例分发到这三台服务器上,确保每台服务器都能处理适量的请求。
- 增强安全性:通过隐藏后端服务器的真实IP地址和架构细节,Nginx 反向代理可以有效地保护后端资源免受直接攻击。同时,它还可以集中实施安全策略,如 SSL/TLS 加密、请求过滤等。例如,Nginx 可以配置为仅允许特定 IP 地址或子网段的请求通过,或者基于请求头信息(如 User-Agent、Referer)进行访问控制,从而阻止或限制潜在的恶意访问。
- 提升缓存效率:Nginx 反向代理可以缓存静态内容和一些动态内容(如页面预渲染版本),减轻后端服务器的压力,同时提高响应速度。当客户端再次访问相同内容时,Nginx 可以直接从缓存中读取并返回给客户端,而无需再次请求后端服务器。例如,一个热门的新闻网站可能有很多用户频繁访问,Nginx 可以缓存这些新闻页面的内容,从而减少对后端服务器的请求次数和响应时间。
- 实现灵活的请求路由:通过配置不同的路由规则,Nginx 反向代理可以将不同类型的请求导向不同的后端服务,实现微服务架构或者API网关的功能。例如,可以将对 /api 路径的请求转发到后端 API 服务器,将对 /static 路径的请求转发到静态文件服务器。
- 简化客户端访问:对于包含多个子系统或服务的复杂应用,Nginx 反向代理可以提供一个统一的访问点,使得客户端无需关心后端的复杂结构。客户端只需与 Nginx 反向代理进行通信,即可访问到所需的资源或服务。例如,一个大型电商平台可能包含多个子系统(如商品系统、订单系统、支付系统等),Nginx可以配置为将不同类型的请求转发到相应的子系统上,客户端只需访问 Nginx 的域名或 IP 地址即可。
1.1.Nginx 反向代理概述
关于正向代理和反向代理,我们在前面的章节已经介绍过了,简而言之就是正向代理代理的对象是客户端,反向代理代理的是服务端,这是两者之间最大的区别。Nginx 即可以实现正向代理,也可以实现反向代理。我们先来通过一个小案例演示下 Nginx 正向代理的简单应用。具体需求如下:
(1)服务端的设置:
http {log_format main 'client send request=>clientIp=$remote_addr serverIp=>$host';server{listen 80;server_name localhost;access_log logs/access.log main;location {root html;index index.html index.htm;}}
}
(2)使用客户端访问服务端,打开日志查看结果:
(3)代理服务器设置:
server {listen 82;resolver 8.8.8.8; # 设置 DNS 的 IP,用来解析 proxy_pass 中的域名location / {proxy_pass http://$host$request_uri;}}
(4)查看代理服务器的 IP (192.168.200.146) 和 Nginx 配置监听的端口 (82)
(5)在客户端配置代理服务器:
(6)设置完成后,再次通过浏览器访问服务端
通过对比,上下两次的日志记录,会发现虽然我们是客户端访问服务端,但是如何使用了代理,那么服务端能看到的只是代理发送过去的请求,这样的化,就使用 Nginx 实现了正向代理的设置。但是 Nginx 正向代理,在实际的应用中不是特别多,所以我们简单了解下,接下来我们继续学习 Nginx 的反向代理,这是 Nginx 比较重要的一个功能。
1.2.Nginx 反向代理的配置语法
Nginx 反向代理模块的指令是由 ngx_http_proxy_module
模块进行解析,该模块在安装 Nginx 的时候已经自己加装到 Nginx 中了,接下来我们把反向代理中的常用指令一一介绍下:
- proxy_pass
- proxy_set_header
- proxy_redirect
1.2.1.proxy_pass
该指令用来设置被代理服务器地址,可以是主机名称、IP 地址加端口号形式。
语法 | proxy_pass URL; |
---|---|
默认值 | - |
位置 | location |
- URL:为要设置的被代理服务器地址,包含传输协议 (
http
、https://
)、主机名称或 IP 地址加端口号、URI 等要素。
那么在编写代理服务器的 proxy_pass 的时候,后面的值要不要加 “/”?接下来通过例子来说明刚才我们提到的问题:
server {listen 80;server_name localhost;location / {# proxy_pass http://192.168.200.146;proxy_pass http://192.168.200.146/;}
}
当客户端访问 http://localhost/index.html,效果是一样的。
server{listen 80;server_name localhost;location /server {# proxy_pass http://192.168.200.146; # 末尾不加 / 会把 /server 拼接到被代理的 IP 地址末尾proxy_pass http://192.168.200.146/; # 末尾加 / 则不会把 /server 拼接到被代理的 IP 地址末尾}
}
当客户端访问 http://localhost/server/index.html,这个时候,第一个 proxy_pass 就变成了 http://localhost/server/index.html
,第二个 proxy_pass 就变成了 http://localhost/index.html
,效果就不一样了。
1.2.2.proxy_set_header
该指令可以更改 Nginx 服务器接收到的客户端请求的请求头信息,然后将新的请求头发送给代理的服务器。
语法 | proxy_set_header field value; |
---|---|
默认值 | proxy_set_header Host $proxy_host; proxy_set_header Connection close; |
位置 | http、server、location |
需要注意的是,如果想要看到结果,必须在被代理的服务器上来获取添加的头信息。
被代理服务器: [192.168.200.146]
server {listen 8080;server_name localhost;default_type text/plain;return 200 $http_username;
}
代理服务器: [192.168.200.133]
server {listen 8080;server_name localhost;location /server {proxy_pass http://192.168.200.146:8080/;proxy_set_header username TOM;}}
1.2.3.proxy_redirect
该指令是用来重置头信息中的 “Location” 和 “Refresh” 的值。
语法 | proxy_redirect redirect replacement; proxy_redirect default; proxy_redirect off; |
---|---|
默认值 | proxy_redirect default; |
位置 | http、server、location |
》为什么要用该指令?
服务端[192.168.200.146]
server {listen 8081;server_name localhost;if (!-f $request_filename){return 302 http://192.168.200.146;}
}
代理服务端[192.168.200.133]
server {listen 8081;server_name localhost;location / {proxy_pass http://192.168.200.146:8081/;proxy_redirect http://192.168.200.146 http://192.168.200.133; # 可以防止向客户端暴露服务器端的 IP 地址。}
}
该指令的几组选项:
proxy_redirect redirect replacement;
- redirect:目标,Location 的值
- replacement:要替换的值
proxy_redirect default;
- default:将 location 块的 uri 变量作为 replacement,将 proxy_pass 变量作为 redirect 进行替换
proxy_redirect off;
:关闭 proxy_redirect 的功能
1.3.Nginx 反向代理实战
服务器 1、2、3 存在两种情况
- 第一种情况:三台服务器的内容不一样。
- 第二种情况:三台服务器的内容是一样。
上述服务器的 IP 地址如下:
- 代理服务器:192.168.200.133
- 服务端 1:192.168.200.146:9001
- 服务器 2:192.168.200.146:9002
- 服务器 3:192.168.200.146:9003
如果服务器 1、服务器 2 和服务器 3 的内容不一样,那我们可以根据用户请求来分发到不同的服务器。
# 代理服务器
server {listen 8082;server_name localhost;location /server1 {proxy_pass http://192.168.200.146:9001/;}location /server2 {proxy_pass http://192.168.200.146:9002/;}location /server3 {proxy_pass http://192.168.200.146:9003/;}
}
# 服务端 server1
server {listen 9001;server_name localhost;default_type text/html;return 200 '<h1>192.168.200.146:9001</h1>'
}
# 服务端 server2
server {listen 9002;server_name localhost;default_type text/html;return 200 '<h1>192.168.200.146:9002</h1>'
}
# 服务端 server3
server {listen 9003;server_name localhost;default_type text/html;return 200 '<h1>192.168.200.146:9003</h1>'
}
如果服务器 1、服务器 2 和服务器 3 的内容是一样的,该如何处理?见后续的负载均衡部分的内容。
1.4.Nginx 的安全控制
关于 Web 服务器的安全是比较大的一个话题,里面所涉及的内容很多,Nginx 反向代理是如何来提升 Web 服务器的安全呢?答案是安全隔离,即通过代理分开了客户端到应用程序服务器端的连接,实现了安全措施。在反向代理之前设置防火墙,仅留一个入口供代理服务器访问。
1.4.1.如何使用 SSL 对流量进行加密
(1)翻译成大家能熟悉的说法就是将我们常用的 http 请求转变成 https 请求,那么这两个之间的区别简单的来说两个都是 HTTP 协议,只不过 https 是身披 SSL 外壳的 http。https 是一种通过计算机网络进行安全通信的传输协议。它经由 http 进行通信,利用 SSL/TLS 建立全通信,加密数据包,确保数据的安全性。
- SSL (Secure Sockets Layer) 安全套接层
- TLS (Transport Layer Security) 传输层安全
(2)上述这两个是为网络通信提供安全及数据完整性的一种安全协议,TLS 和 SSL 在传输层和应用层对网络连接进行加密。总结来说为什么要使用 https:http 协议是明文传输数据,存在安全问题,而 https 是加密传输,相当于 http+ssl,并且可以防止流量劫持。
(3)Nginx 要想使用 SSL,需要满足一个条件即需要添加一个模块 --with-http_ssl_module
,而该模块在编译的过程中又需要 OpenSSL 的支持,这个我们之前已经准备好了。
1.4.2.Nginx 添加 SSL 的支持
(1)完成 --with-http_ssl_module
模块的增量添加:
- 将原有 /usr/local/nginx/sbin/nginx 进行备份
- 拷贝 Nginx 之前的配置信息
- 在 Nginx 的安装源码进行配置指定对应模块
./configure --with-http_ssl_module
- 通过 make 模板进行编译
- 将 objs 下面的 Nginx 移动到
/usr/local/nginx/sbin
下 - 在源码目录下执行 make upgrade 进行升级,这个可以实现不停机添加新模块的功能
1.4.3.Nginx 的 SSL 相关指令
因为刚才我们介绍过该模块的指令都是通过 ngx_http_ssl_module
模块来解析的。
ssl
:该指令用来在指定的服务器开启 HTTPS,可以使用 listen 443 ssl,后面这种方式更通用些。
语法 | ssl on | off; |
---|---|
默认值 | ssl off; |
位置 | http、server |
server{listen 443 ssl;
}
ssl_certificate
:为当前这个虚拟主机指定一个带有 PEM 格式证书的证书。
语法 | ssl_certificate file; |
---|---|
默认值 | — |
位置 | http、server |
ssl_certificate_key
:该指令用来指定 PEM secret key 文件的路径
语法 | ssl_ceritificate_key file; |
---|---|
默认值 | — |
位置 | http、server |
ssl_session_cache
:该指令用来配置用于 SSL 会话的缓存
语法 | ssl_sesion_cache off|none|[builtin[:size]] [shared:name:size] |
---|---|
默认值 | ssl_session_cache none; |
位置 | http、server |
- off:禁用会话缓存,客户端不得重复使用会话
- none:禁止使用会话缓存,客户端可以重复使用,但是并没有在缓存中存储会话参数
- builtin:内置 OpenSSL 缓存,仅在一个工作进程中使用。
- shared:所有工作进程之间共享缓存,缓存的相关信息用 name 和 size 来指定
- ssl_session_timeout:开启 SSL 会话功能后,设置客户端能够反复使用储存在缓存中的会话参数时间。
语法 | ssl_session_timeout time; |
---|---|
默认值 | ssl_session_timeout 5m; |
位置 | http、server |
ssl_ciphers
:指出允许的密码,密码指定为 OpenSSL 支持的格式
语法 | ssl_ciphers ciphers; |
---|---|
默认值 | ssl_ciphers HIGH:!aNULL:!MD5; |
位置 | http、server |
可以使用 openssl ciphers
查看 openssl 支持的格式。
ssl_prefer_server_ciphers
:该指令指定是否服务器密码优先客户端密码
语法 | ssl_perfer_server_ciphers on|off; |
---|---|
默认值 | ssl_perfer_server_ciphers off; |
位置 | http、server |
1.4.3.1.生成证书
方式一:使用阿里云/腾讯云等第三方服务进行购买。
方式二:使用 openssl 生成证书
先要确认当前系统是否有安装 openssl
openssl version
安装下面的命令进行生成
mkdir /root/cert
cd /root/cert
openssl genrsa -des3 -out server.key 1024 # 123456
openssl req -new -key server.key -out server.csr # 123456
cp server.key server.key.org
openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt
最终生成的文件如下:
1.4.3.2.开启 SSL 实例
server {listen 443 ssl;server_name localhost;ssl_certificate /root/cert/server.crt; # 根据实际情况进行配置ssl_certificate_key /root/cert/server.key; # 根据实际情况进行配置ssl_session_cache shared:SSL:1m;ssl_session_timeout 5m;ssl_ciphers HIGH:!aNULL:!MD5;ssl_prefer_server_ciphers on;location / {root html;index index.html index.htm;}
}
验证:
1.5.反向代理系统调优
反向代理值 Buffer 和 Cache:Buffer翻译过来是"缓冲",Cache 翻译过来是"缓存"。
总结下:
- 相同点:两种方式都是用来提供 IO 吞吐效率,都是用来提升 Nginx 代理的性能。
- 不同点:
- 缓冲主要用来解决不同设备之间数据传递速度不一致导致的性能低的问题,缓冲中的数据一旦此次操作完成后,就可以删除。
- 缓存主要是备份,将被代理服务器的数据缓存一份到代理服务器,这样的话,客户端再次获取相同数据的时候,就只需要从代理服务器上获取,效率较高,缓存中的数据可以重复使用,只有满足特定条件才会删除。
(1)Proxy Buffer 相关指令
- proxy_buffering:该指令用来开启或者关闭代理服务器的缓冲区;
语法 | proxy_buffering on|off; |
---|---|
默认值 | proxy_buffering on; |
位置 | http、server、location |
- proxy_buffers:该指令用来指定单个连接从代理服务器读取响应的缓存区的个数和大小。
语法 | proxy_buffers number size; |
---|---|
默认值 | proxy_buffers 8 4k | 8K;(与系统平台有关) |
位置 | http、server、location |
- number:缓冲区的个数
- size:每个缓冲区的大小,缓冲区的总大小就是 number * size
- proxy_buffer_size:该指令用来设置从被代理服务器获取的第一部分响应数据的大小。保持与 proxy_buffers 中的 size 一致即可,当然也可以更小。
语法 | proxy_buffer_size size; |
---|---|
默认值 | proxy_buffer_size 4k | 8k;(与系统平台有关) |
位置 | http、server、location |
- proxy_busy_buffers_size:该指令用来限制同时处于 BUSY 状态的缓冲总大小。
语法 | proxy_busy_buffers_size size; |
---|---|
默认值 | proxy_busy_buffers_size 8k|16K; |
位置 | http、server、location |
- proxy_temp_path:当缓冲区存满后,仍未被 Nginx 服务器完全接受,响应数据就会被临时存放在磁盘文件上,该指令设置文件路径。注意 path 最多设置三层。
语法 | proxy_temp_path path; |
---|---|
默认值 | proxy_temp_path proxy_temp; |
位置 | http、server、location |
- proxy_temp_file_write_size:该指令用来设置磁盘上缓冲文件的大小。
语法 | proxy_temp_file_write_size size; |
---|---|
默认值 | proxy_temp_file_write_size 8K|16K; |
位置 | http、server、location |
通用网站的配置
proxy_buffering on;
proxy_buffer_size 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
根据项目的具体内容进行相应的调节。
相关文章:

Nginx——反向代理(三/五)
目录 1.Nginx 反向代理1.1.Nginx 反向代理概述1.2.Nginx 反向代理的配置语法1.2.1.proxy_pass1.2.2.proxy_set_header1.2.3.proxy_redirect 1.3.Nginx 反向代理实战1.4.Nginx 的安全控制1.4.1.如何使用 SSL 对流量进行加密1.4.2.Nginx 添加 SSL 的支持1.4.3.Nginx 的 SSL 相关指…...

环动科技平均售价波动下滑:大客户依赖明显,应收账款周转率骤降
《港湾商业观察》施子夫 2024年12月18日,浙江环动机器人关节科技股份有限公司(以下简称,环动科技)的上市审核状态变更为“已问询”,公司在11月25日科创板IPO获上交所受理,独家保荐机构为广发证券。 此次环…...

源网荷储:构建智慧能源生态的关键方案设计
一、技术融合基石 多元能源采集技术:在 “源” 端,除了常见的光伏、风电、火电,生物质能发电、地热能利用技术也应纳入考量。例如在有丰富生物质原料的农村地区,小型生物质发电厂可实现废物利用与供电双赢;地热资源丰…...

进程间通讯
简介: 进程间通讯方式有: 1.内存映射(mmap): 使用mmap函数将磁盘空间映射到内存 2.管道 3.信号 4.套接字(socket) 5.信号机制 通过进程中kill函数,去给另一个函数发送信号&a…...

STM32-笔记33-OLED实验
实验目的 驱动 OLED 屏幕,显示点、线、字符、字符串、汉字、图片等内容。 项目实现-OLED通讯协议 复制项目文件19-串口打印功能 重命名为47-OLED实验 打开项目文件 加载文件 代码书写顺序: oled.c #include "oled.h"//初始化oled的gpio …...

低空管控技术-无人机云监视技术详解!
一、无人机监听技术的原理 无人机监听技术主要依赖于射频(RF)探测、光学和红外传感器等技术手段。这些技术通过被动监听和监测无人机与飞行员(或控制器)之间的通信链路传输,以确定无人机的位置,甚至在某些…...

RedisTemplate执行lua脚本及Lua 脚本语言详解
使用RedisTemplate执行lua脚本 在开发中,我们经常需要与Redis数据库进行交互,而Redis是一个基于内存的高性能键值存储数据库,它支持多种数据结构,并提供了丰富的命令接口。在某些情况下,我们可能需要执行一些复杂的逻…...

基于springboot的网上商城购物系统
作者:学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等 文末获取“源码数据库万字文档PPT”,支持远程部署调试、运行安装。 目录 项目包含: 开发说明: 系统功能: 项目截图…...

服务器攻击方式有哪几种?
随着互联网的快速发展,网络攻击事件频发,已泛滥成互联网行业的重病,受到了各个行业的关注与重视,因为它对网络安全乃至国家安全都形成了严重的威胁。面对复杂多样的网络攻击,想要有效防御就必须了解网络攻击的相关内容…...

【Unity3D】AB包加密(AssetBundle加密)
加密前: 加密后,直接无法加载ab,所以无法正常看到ab内容。 using UnityEngine; using UnityEditor; using System.IO; public static class AssetBundleDemoTest {[MenuItem("Tools/打包!")]public static void Build(){//注意:St…...

【FTP 协议】FTP主动模式
一、测试工具 服务器:FileZilla_Server-cn-0_9_60_2.exe 中文版本 客户端:FileZilla_3.66.5_win64 客户端IP: 192.168.9.186 服务端 IP: 192.168.9.161 在客户端请求PORT之前,抓包测试的结果跟被动模式流程相同。 二、客户端主动模式命令…...

十五、Vue 响应接口
文章目录 一、响应式系统基础什么是响应式系统响应式数据的声明与使用二、响应式原理深入Object.defineProperty () 方法的应用(Vue2)Proxy 对象的应用(Vue3)三、响应式接口之 ref 和 reactive(Vue3)ref 函数的使用reactive 函数的使用四、计算属性(computed)作为响应式…...

至强6搭配美光CZ122,证明CXL可以提高生成式AI的性能表现
最近发现了英特尔官网公布的一项最新测试报告,报告显示,将美光的CZ122 CXL内存模块放到英特尔至强6平台上,显著提升了HPC和AI工作负载的内存带宽,特别是在采用基于软件的交错配置(interleave configuration)…...

一文理解ssh,ssl协议以及应用
在使用基于密钥的认证方式的时候,私钥的位置一定要符合远程服务器规定的位置,否则找不到私钥的位置会导致建立ssh连接失败 SSH 全称是 “Secure Shell”,即安全外壳协议。 它是一种网络协议,用于在不安全的网络中安全地进行远程登…...

电子应用设计方案87:智能AI收纳箱系统设计
智能 AI 收纳箱系统设计 一、引言 智能 AI 收纳箱系统旨在为用户提供更高效、便捷和智能的物品收纳与管理解决方案,通过融合人工智能技术和创新设计,提升用户的生活品质和物品整理效率。 二、系统概述 1. 系统目标 - 实现物品的自动分类和整理…...

BloombergGPT: A Large Language Model for Finance——面向金融领域的大语言模型
这篇文章介绍了BloombergGPT,一个专门为金融领域设计的大语言模型(LLM)。以下是文章的主要内容总结: 背景与动机: 大语言模型(如GPT-3)在多个任务上表现出色,但尚未有针对金融领域的…...

LeetCode - #180 Swift 实现连续数字查询
文章目录 摘要描述SQL 解法Swift 题解代码Swift 题解代码分析核心逻辑关键函数 示例测试及结果测试 1测试 2 时间复杂度空间复杂度总结 摘要 本文将解决如何从日志数据中找出连续出现至少三次的数字。通过 SQL 查询语句结合 Swift 数据库操作,我们将完成这一任务。…...

为什么ip属地一会河南一会江苏
在使用互联网的过程中,许多用户可能会遇到这样一个问题:自己的IP属地一会儿显示为河南,一会儿又变成了江苏。这种现象可能会让人感到困惑,甚至产生疑虑,担心自己的网络活动是否受到了某种影响。为了解答这一疑问&#…...
使用最广泛的FastAPI项目结构推荐,命名规范等
使用最广泛的FastAPI项目结构推荐,命名规范等 一、FastAPI项目结构如下:二、组件管理:使用依赖注入三、命名约定四、建议分层架构的设计五、文档和测试六、版本控制和持续集成七、环境和配置管理工具八、性能优化与权限安全 一、FastAPI项目结…...

[大模型开源]SecGPT 网络安全大模型
模型介绍 SecGPT的愿景是将人工智能技术引入网络安全领域,以提高网络防御的效率和效果。其使命是推动网络安全智能化,为社会提供更安全的数字生活环境。 ① SecGPT开源地址:https://github.com/Clouditera/secgpt② 模型地址:htt…...

手游刚开服就被攻击怎么办?如何防御DDoS?
开服初期是手游最脆弱的阶段,极易成为DDoS攻击的目标。一旦遭遇攻击,可能导致服务器瘫痪、玩家流失,甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案,帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...

遍历 Map 类型集合的方法汇总
1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...

python/java环境配置
环境变量放一起 python: 1.首先下载Python Python下载地址:Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个,然后自定义,全选 可以把前4个选上 3.环境配置 1)搜高级系统设置 2…...

前端导出带有合并单元格的列表
// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...

现代密码学 | 椭圆曲线密码学—附py代码
Elliptic Curve Cryptography 椭圆曲线密码学(ECC)是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础,例如椭圆曲线数字签…...

html-<abbr> 缩写或首字母缩略词
定义与作用 <abbr> 标签用于表示缩写或首字母缩略词,它可以帮助用户更好地理解缩写的含义,尤其是对于那些不熟悉该缩写的用户。 title 属性的内容提供了缩写的详细说明。当用户将鼠标悬停在缩写上时,会显示一个提示框。 示例&#x…...

uniapp手机号一键登录保姆级教程(包含前端和后端)
目录 前置条件创建uniapp项目并关联uniClound云空间开启一键登录模块并开通一键登录服务编写云函数并上传部署获取手机号流程(第一种) 前端直接调用云函数获取手机号(第三种)后台调用云函数获取手机号 错误码常见问题 前置条件 手机安装有sim卡手机开启…...

MacOS下Homebrew国内镜像加速指南(2025最新国内镜像加速)
macos brew国内镜像加速方法 brew install 加速formula.jws.json下载慢加速 🍺 最新版brew安装慢到怀疑人生?别怕,教你轻松起飞! 最近Homebrew更新至最新版,每次执行 brew 命令时都会自动从官方地址 https://formulae.…...

Unity UGUI Button事件流程
场景结构 测试代码 public class TestBtn : MonoBehaviour {void Start(){var btn GetComponent<Button>();btn.onClick.AddListener(OnClick);}private void OnClick(){Debug.Log("666");}}当添加事件时 // 实例化一个ButtonClickedEvent的事件 [Formerl…...