六、Nginx-正向代理和反向代理

目录

一、正向代理

1、参数详解

 2、常用变量详解

3、配置示例

二、反向代理

三、 Nginx的安全控制

1、如何使用SSL对流量进行加密

2、nginx添加SSL的支持

3、 Nginx的SSL相关指令

(1)ssl

(2)ssl_certificate

(3)ssl_certificate_key

(4)ssl_session_cache

(5)ssl_session_timeout

(6)ssl_ciphers

(7)ssl_prefer_server_ciphers

(8)生成证书

四、 反向代理系统优化

1、proxy_buffering

2、proxy_buffers

3、proxy_buffer_size

4、proxy_busy_buffers_size

5、proxy_temp_path

6、proxy_temp_file_write_size


一、正向代理

        正向代理,意思是一个位于客户端和原始服务器之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。

        假设 我们想要访问国外的网站,此时你会发现国外的网站我们通过浏览器是无法访问的,这时大家可能都会用一个操作翻墙进行访问,翻墙的方式主要是找到一个可以访问国外网站的代理服务器,我们将请求发送给代理服务器,代理服务器去访问国外的网站,然后将访问到的数据传递给我们!这就称为正向代理。

        正向代理最大的特点是客户端非常明确要访问的服务器地址;服务器只清楚请求来自哪个代理服务器,而不清楚来自哪个具体的客户端;正向代理模式屏蔽或者隐藏了真实客户端信息。

总结:正向代理就是代理客户端,客户端与代理服务器处在同一LAN(局域网)中。

1、参数详解

listen指令:
    #用于指定Nginx监听的端口和地址。
    #示例:listen 8080; 表示Nginx监听在8080端口上。
resolver指令:
    #用于指定DNS解析器的地址。
    #示例:resolver 8.8.8.8 valid=300s; 表示使用Google的公共DNS服务器进行域名解析,并设置解析结果的有效期为300秒。
proxy_pass指令:
    #用于指定请求应该被转发到的目标地址。
    #示例:proxy_pass http://backend_server; 表示将请求转发到名为backend_server的上游服务器。
proxy_set_header指令:
    #用于修改转发给上游服务器的请求头。
    #示例:proxy_set_header Host $host; 表示将原始请求的Host头转发给上游服务器。
proxy_cache指令:
    #用于启用缓存功能,缓存上游服务器的响应。
    #示例:proxy_cache path/to/cache; 表示启用缓存,并将缓存文件存储在path/to/cache目录下。
proxy_cache_valid指令:
    #用于为不同的响应状态码设置不同的缓存有效期。
    #示例:proxy_cache_valid 200 304 12h; 表示对于状态码为200和304的响应,缓存有效期为12小时。
proxy_connect_timeout指令:
    #用于设置与上游服务器建立连接的超时时间。
    #示例:proxy_connect_timeout 60s; 表示建立连接的超时时间为60秒。
proxy_read_timeout指令:
    #用于设置从上游服务器读取响应的超时时间。
    #示例:proxy_read_timeout 60s; 表示读取响应的超时时间为60秒。
proxy_send_timeout指令:
    #用于设置向上游服务器发送请求的超时时间。
    #示例:proxy_send_timeout 60s; 表示发送请求的超时时间为60秒。
client_max_body_size指令:
    #用于设置客户端请求体的最大允许大小。
    #示例:client_max_body_size 10m; 表示客户端请求体的最大允许大小为10MB。
    
------    
Proxy Buffer相关指令
1. proxy_buffering
#该指令用来开启或者关闭代理服务器的缓冲区
#语法:proxy_buffering on|off;
#默认值:proxy_buffering on;
#位置:http、server、location
2、proxy_buffers
#该指令用来指定单个连接从代理服务器读取响应的缓存区的个数和大小。
#语法:proxy_buffers number size;
#    number:缓冲区的个数
#    size:每个缓冲区的大小,缓冲区的总大小就是number*size
#默认值:proxy_buffers 8 4k | 8K;(与系统平台有关)
#位置:http、server、location
3、proxy_buffer_size
#该指令用来设置从被代理服务器获取的第一部分响应数据的大小。保持与proxy_buffers中的size一致即可,当然也可以更小。
4、proxy_busy_buffers_size
#高负荷下缓冲大小(proxy_buffers*2)
5、proxy_temp_path
#当缓冲区存满后,仍未被Nginx服务器完全接受,响应数据就会被临时存放在磁盘文件上,该指令设置文件路径
#默认值:proxy_temp_path proxy_temp;
6、 proxy_temp_file_write_size
#设定缓存文件夹大小,大于这个值,将从upstream服务器传

示例:
proxy_buffering on;
proxy_buffer_size 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;

 2、常用变量详解

$arg_NAME:
#这个变量用于获取 GET 请求中指定名称(NAME)的参数值。
#例如,如果请求是 /example?name=John,那么 $arg_name 的值就是 "John"。
$uri:
#此变量包含请求中的当前 URI(不带请求参数),参数位于 $args 中。它可能不同于浏览器传递的 $request_uri 的值,因为它可以通过内部重定向或使用 index 指令进行修改。$uri 不包含主机名。
$request_uri:
#这个变量包含完整的原始请求 URI(包括参数),即客户端在 HTTP 请求行中发送的 URI。
$host:
#包含了请求行中的主机名,以及可能的端口号。
$http_HEADER:
#这里的 HEADER 是指 HTTP 请求头中的字段名。使用这个变量可以获取到请求头中对应字段的值。例如,$http_user_agent 会获取到用户代理字符串。
$remote_addr:
#客户端的 IP 地址。
$document_root:
#当前请求在服务器上的根目录。
$server_name:
#请求到达的服务器名。
$server_port:
#请求到达的服务器的端口号。
$request_filename:
#当前请求的文件路径名,由 $document_root 和 $uri 组成。

3、配置示例

#正向代理转发http请求
server {               
    listen 80;    
    resolver 114.114.114.114;        
    server_name  localhost;  
    #正向代理转发http请求    
    location / {        
        proxy_pass                 http:$host$request_uri; #设定代理服务器的协议和地址       
        proxy_set_header           HOST $host;        
        proxy_buffers              256 4k;        
        proxy_max_temp_file_size   0k;        
        proxy_connect_timeout      30;        
        proxy_send_timeout         60;        
        proxy_read_timeout         60;        
        proxy_next_upstream error  timeout invalid_header http_502;
    }
}

#正向代理转发https请求
server {     
    resolver 114.114.114.114;    
    #监听443端口,https默认端口443    
    listen 443;   
    #正向代理转发https请求   
    proxy_connect;   
    proxy_connect_allow            443 563;   
    proxy_connect_connect_timeout  10s;   
    proxy_connect_read_timeout     10s;   
    proxy_connect_send_timeout     10s;   
    location / {        
        proxy_pass http:$host;        
        proxy_set_header Host $host;   
    }
}

检查配置是否正确
sbin/nginx -t
启动,验证

二、反向代理

        反向代理指的是位于客户端与服务端之间的代理服务器。与正向代理不同的是,客户端直接访问代理服务器,然后代理服务器向服务端转发请求并将服务端返回的资源返回给客户端。

        客户端对代理是无感知的,因为客户端不需要配置任何配置参数就可以访问,客户端只需要将请求发送到反向代理服务器,由反向代理服务器去请求目标服务器获取数据后,再返回给客户端,此时反向代理服务器和目录服务器对外就是一个服务器,暴露的是代理代理服务器地址,隐藏了真实服务器IP地址。

        总结:反向代理就是代理服务端,服务端与代理服务器处在同一LAN(局域网)中。

        反向代理的主要作用是提供负载均衡和高可用性。

        Nginx反向代理模块的指令是由 ngx_http_proxy_module模块进行解析,该模块在安装Nginx的时候已经自己加装到Nginx中了,接下来我们把反向代理中的常用指令一一介绍下: 

proxy_pass http://127.0.0.1:80;
#该指令用来设置被代理服务器地址,可以是主机名称、IP地址加端口号形式。
#位置:location

proxy_set_header 
#该指令可以更改Nginx服务器接收到的客户端请求的请求头信息,然后将新的请求头发送给被代理的服务器即目标服务器。
#默认值:
    proxy_set_header Host $proxy_host;
    proxy_set_header Connection close;
    
proxy_redirect off;
#在使用Nginx做反向代理功能时,有时会出现重定向的url不是我们想要的url,这时候就可以使用proxy_redirect进行url重定向设置了。
#proxy_redirect功能比较强大,其作用是对发送给客户端的URL进行修改。
#默认:proxy_redirect default;
#配置块(使用的字段):http、server、location
#我们是关闭此项的。
proxy_set_header X-Real-IP $remote_addr;
#把源IP 【$remote_addr,建立HTTP连接header里面的信息】赋值给X-Real-IP;这样在代码中 $X-Real-IP来获取 源IP
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#后端的Web服务器可以通过X-Forwarded-For获取用户真实IP(作为代理服务器时,设置的IP列表,会把经过的机器ip,代理机器ip都记录下来,用 【,】隔开;代码中用 echo $x-forwarded-for |awk -F, '{print $1}' 来作为源IP)

#以下是一些反向代理的配置,可选。

# 这将帮助减少缓冲区溢出攻击的可能性
    #允许客户端请求的最大单文件字节数。外面的快设置之后这里不需要在设置了。
    client_max_body_size 10m;
    #缓冲区代理缓冲用户端请求的最大字节数,
    client_body_buffer_size 128k;
# 为客户端设置超时时间    
#nginx跟后端服务器连接超时时间(代理连接超时);#nginx服务器与被代理的服务器建立连接的超时时间,默认60秒
proxy_connect_timeout 60;
#后端服务器数据回传时间(代理发送超时);#nginx服务器想被代理服务器组发出read请求后,等待响应的超时间,默认为60秒。
proxy_send_timeout 30;
#连接成功后,后端服务器响应时间(代理接收超时);#nginx服务器想被代理服务器组发出write请求后,等待响应的超时间,默认为60秒。
proxy_read_timeout 90;
#支持客户端的请求方法。post/get;
proxy_method get;
#客户端断网时,nginx服务器是否中断对被代理服务器的请求。默认为off。
proxy_ignore_client_abort on;
#存放http报文头的哈希表容量上限,默认为512个字符。
proxy_headers_hash_max_size 1024;
#nginx服务器申请存放http报文头的哈希表容量大小。(默认64)
proxy_headers_hash_bucket_size 128;
#反向代理upstream中设置的服务器组,出现故障时,被代理服务器返回的状态值。error|timeout|invalid_header|http_500|http_502|http_503|http_504|http_404|off
proxy_next_upstream timeout;

示例: 

#反向代理转发请求
server {
   listen       80;    #监听端口
   server_name  locahost;                                              
   error_page 404  /404.html;
   error_page 403  /403.html;
   location /AsynSlProj/webService{
        proxy_headers_hash_max_size 512;    #设置头部哈希表的最大值
        proxy_headers_hash_bucket_size 128;    #设置头部哈希表大小
        proxy_redirect off;    #关闭代理重定向
        proxy_set_header Host $host:$server_port;    #将代理服务WSDL地址转换为代理服务器本机地址
        proxy_set_headerX-Real-IP $remote_addr;
        proxy_set_headerX-Forwarded-For $proxy_add_x_forwarded_for;
        client_max_body_size 50m;    #允许客户端请求的最大单文件字节数
        client_body_buffer_size 256k;    #缓冲区代理缓冲用户端请求的最大字节数
        proxy_connect_timeout 10;    #nginx跟后端服务器连接超时时间
        proxy_read_timeout 600;    #连接成功后,后端服务器响应时间
        proxy_send_timeout 600;    #后端服务器数据回传时间
        proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
        proxy_pass http://127.0.0.1:80;
        index  index.html index.htm index.jsp;
    }
       error_page   500 502 503 504  /50x.html;
       location = /50x.html {
           root   html;
       }
}

三、 Nginx的安全控制

        关于web服务器的安全是比较大的一个话题,里面所涉及的内容很多,Nginx反向代理是如何来提升web服务器的安全呢?

        – 安全隔离。

        什么是安全隔离

        通过代理分开了客户端到应用程序服务器端的连接,实现了安全措施。在反向代理之前设置防火墙,仅留一个入口供代理服务器访问。

1、如何使用SSL对流量进行加密

        翻译成大家能熟悉的说法就是将我们常用的http请求转变成https请求,那么这两个之间的区别简单的来说两个都是HTTP协议,只不过https是身披SSL外壳的http。

        HTTPS是一种通过计算机网络进行安全通信的传输协议。它经由HTTP进行通信,利用SSL/TLS建立全通信,加密数据包,确保数据的安全性。

        SSL(Secure Sockets Layer)安全套接层。

        TLS(Transport Layer Security)传输层安全。

        上述这两个是为网络通信提供安全及数据完整性的一种安全协议,TLS和SSL在传输层和应用层对网络连接进行加密。

        总结来说为什么要使用https:

        http协议是明文传输数据,存在安全问题,而https是加密传输,相当于http+ssl,并且可以防止流量劫持。

        Nginx要想使用SSL,需要满足一个条件即需要添加一个模块--with-http_ssl_module,而该模块在编译的过程中又需要OpenSSL的支持

2、nginx添加SSL的支持

        nginx添加支持 的模块在此不做详解

3、 Nginx的SSL相关指令

(1)ssl

该指令用来在指定的服务器开启HTTPS,可以使用 listen 443 ssl,后面这种方式更通用些。

语法

ssl on | off;

默认值

ssl off;

位置

http、server

server{
  listen 443 ssl;
  server_name locahost;
  #或者
  ssl on;
}

(2)ssl_certificate

ssl_certificate:为当前这个虚拟主机指定一个带有PEM格式证书的证书。

语法

ssl_certificate file;

默认值

位置

http、server

(3)ssl_certificate_key

该指令用来指定PEM secret key文件的路径

语法

ssl_ceritificate_key file;

默认值

位置

http、server

server {
  ssl on;
  ssl_certificate  /usr/local/nginx/cert/server.crt;
  ssl_certificate_key /usr/local/nginx/cert/server.key;
}

(4)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来指定

(5)ssl_session_timeout

开启SSL会话功能后,设置客户端能够反复使用储存在缓存中的会话参数时间。

语法

ssl_session_timeout time;

默认值

ssl_session_timeout 5m;

位置

http、server

(6)ssl_ciphers

指出允许的密码,密码指定为OpenSSL支持的格式.可以使用openssl ciphers查看openssl支持的格式。

语法

ssl_ciphers ciphers;

默认值

ssl_ciphers HIGH:!aNULL:!MD5;

位置

http、server

(7)ssl_prefer_server_ciphers

该指令指定是否服务器密码优先客户端密码

语法

ssl_perfer_server_ciphers on|off;

默认值

ssl_perfer_server_ciphers off;

位置

http、server

(8)生成证书

在此使用openssl生成证书。步骤是创建一个私钥和一个自签名证书,然后将它们配置到 Nginx 中

创建证书存放目录
mkdir  /usr/local/nginx/cert
cd /use/local/nginx/cert
1、生成服务器私钥,这个命令生成了一个 1024 位的 RSA 私钥,并且用 DES3 对其进行了加密保护。在执行此命令时,会提示您输入一个密码短语来保护私钥。
openssl genrsa -des3 -out server.key 1024
2. 根据服务器私钥文件生成证书请求文件,这个文件中会包含申请人的一些信息,所以执行下面这行命令过程中需要用户在命令行输入一些用户信息,随便填写,一路回车即可。
openssl req -new -key server.key -out server.csr
3、为了不需要在每次重启nginx的时候都输入密码
cp server.key server.key.org
openssl rsa -in server.key.org -out server.key
4、用第一步的私钥和第二步的请求文件生成证书
openssl x509 -req -in server.csr -signkey server.key -days 3650 -out server.crt 

四、 反向代理系统优化

反向代理值Buffer和Cache

Buffer翻译过来是"缓冲",Cache翻译过来是"缓存"。

总结下:

相同点:
两种方式都是用来提供IO吞吐效率,都是用来提升Nginx代理的性能。
不同点:
缓冲主要用来解决不同设备之间数据传递速度不一致导致的性能低的问题,缓冲中的数据一旦此次操作完成后,就可以删除。
缓存主要是备份,将被代理服务器的数据缓存一份到代理服务器,这样的话,客户端再次获取相同数据的时候,就只需要从代理服务器上获取,效率较高,缓存中的数据可以重复使用,只有满足特定条件才会删除.

Proxy Buffer相关指令

1、proxy_buffering

该指令用来开启或者关闭代理服务器的缓冲区

语法

proxy_buffering on|off;

默认值

proxy_buffering on;

位置

http、server、location

2、proxy_buffers

该指令用来指定单个连接从代理服务器读取响应的缓存区的个数和大小。

语法

proxy_buffers number size;

默认值

proxy_buffers 8 4k | 8K;(与系统平台有关)

位置

http、server、location

number:缓冲区的个数

size:每个缓冲区的大小,缓冲区的总大小就是number*size

3、proxy_buffer_size

该指令用来设置从被代理服务器获取的第一部分响应数据的大小。保持与proxy_buffers中的size一致即可,当然也可以更小。

语法

proxy_buffer_size size;

默认值

proxy_buffer_size 4k | 8k;(与系统平台有关)

位置

http、server、location

4、proxy_busy_buffers_size

该指令用来限制同时处于BUSY状态的缓冲总大小。

语法

proxy_busy_buffers_size size;

默认值

proxy_busy_buffers_size 8k|16K;

位置

http、server、location

5、proxy_temp_path

当缓冲区存满后,仍未被Nginx服务器完全接受,响应数据就会被临时存放在磁盘文件上,该指令设置文件路径

语法

proxy_temp_path path;

默认值

proxy_temp_path proxy_temp;

位置

http、server、location

6、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 4k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Tuxera NTFS与Paragon NTFS:两款NTFS驱动软件的深度对比 tuxera和paragon NTFS哪个好

在Mac上使用NTFS格式的磁盘,通常需要借助第三方的驱动软件。其中,Tuxera NTFS和Paragon NTFS是两款备受欢迎的选择。虽然它们的基本功能相似,但在细节和使用体验上却有所不同。本文将带你深入了解这两款软件的差异,帮助你做出更明…

【python】OpenCV—Segmentation

文章目录 cv2.kmeans牛刀小试 cv2.kmeans cv2.kmeans 是 OpenCV 库中用于执行 K-Means 聚类算法的函数。以下是根据参考文章整理的 cv2.kmeans 函数的中文文档: 一、函数功能 cv2.kmeans 用于执行 K-Means 聚类算法,将一组数据点划分到 K 个簇中&…

响应式高端网站模板源码图库素材 资源下载平台源码

源码介绍 亲测可用,可用于做娱乐网资源网,功能非常的齐全无任何加密也无任何后门!响应式高端网站模板源码图库素材 资源下载平台源码(可运营) 页面很美观,堪比大型网站的美工,而且页面做的也很…

Python将字符串用特定字符分割并前面加序号

Python将字符串用特定字符分割并前面加序号 Python将字符串用特定字符分割并前面加序号,今天项目中就遇到,看着不难,得花点时间搞出来急用啊,在网上找了一圈,没发现有完整流程的文章。所以就搞出来并写了这个文章。仅…

Mybatis 笔记 (一) V- 3.5.16

文章目录 Mybatis 笔记(3.5.16)1、基础数据2、基础依赖3、魔改点标记 A、试试SqlSessionFactoryB、建立连接的三种方式1、执行方法2、实现方式 C、“复杂”的 Configuration 模式实现1、直接构建Configuration2、补充environment 要素2.1、填充id2.2、填…

文生视频开源产品的一些调研(一)

笔者尝试AI视频生成的几个特点: 玄学prompt,每个视频的prompt可能也需要微调很多次,需要找到使用模型的最佳prompt词组合,不恰当的比喻,骑自行车,座位高度等都是人与车彼此熟悉玄学生成,因为需…

Java | Leetcode Java题解之第162题寻找峰值

题目&#xff1a; 题解&#xff1a; class Solution {public int findPeakElement(int[] nums) {int n nums.length;int left 0, right n - 1, ans -1;while (left < right) {int mid (left right) / 2;if (compare(nums, mid - 1, mid) < 0 && compare(n…

vue:对三种获取更新后的dom的方式进行分析

一、问题分析 由于vue的异步更新机制&#xff0c;我们在同步代码中是无法获取到更新后的dom的信息的 针对这个问题&#xff0c;我们有三种解决方案获取更新后的dom: 1.nextTick() 2.setTimeout() 3.在微任务中获取 因为更新是在同步任务结束后&#xff0c;执行微任务之前…

【网络安全】网络安全威胁及途径

1、网络安全威胁的种类及途径 &#xff08;1&#xff09;网络安全威胁的主要类型 网络安全面临的威胁和隐患种类繁多&#xff0c;主要包括人为因素、网络系统及数据资源和运行环境等影响。网络安全威胁主要表现为&#xff1a;黑客入侵、非授权访问、窃听、假冒合法用户、病毒…

C++日志库spdlog使用方法

对于线上服务&#xff0c;打日志至关重要&#xff0c;通过日志可以进行事件定位、debug&#xff0c;有时也会通过收集日志实现追溯、监控、特征采集等工作。 1. spdlog简介 spdlog github 一个开源的C日志库&#xff0c;快速便捷&#xff0c;使用了fmt作为格式化工具。 2. s…

02 - matlab m_map地学绘图工具基础函数 - m_proj

02 - matlab m_map地学绘图工具基础函数 - m_proj 0. 引言1. 查看所有投影方式3. 各投影方式绘图示例3.1 极射赤面投影法&#xff08;Stereographic &#xff09;3.2 Orthographic 正射投影示例3.3 Azimuthal Equal-area 方位等面积投影3.4 Azimuthal Equidistant 等距方位投影…

函数模板的注意事项

1.可以为类的成员函数创建模板&#xff0c;但不可以是虚函数和析构函数。 #include <iostream> using namespace std;class CGirl {public:template <typename T>CGirl(T a) {//构造函数中cout << "a" << a << endl;}template <ty…

Mysqld数据库管理

一.Mysqld数据库类型 常用的数据类型 int 整型 无符号[0-4294967296&#xff08;2的32次方&#xff09;-1]&#xff0c;有符号[-2147483648&#xff08;2的31次方&#xff09;-2147483647]float单精度浮点 4字节32位double双精度浮点 8字节64位char固定长度的字符类型…

如何利用TikTok矩阵源码实现自动定时发布和高效多账号管理

在如今社交媒体的盛行下&#xff0c;TikTok已成为全球范围内最受欢迎的短视频平台之一。对于那些希望提高效率的内容创作者而言&#xff0c;手动发布和管理多个TikTok账号可能会是一项繁琐且耗时的任务。幸运的是&#xff0c;通过利用TikTok矩阵源码&#xff0c;我们可以实现自…

【vue3|第9期】Vue3中watch监视的深度解读

日期&#xff1a;2024年6月10日 作者&#xff1a;Commas 签名&#xff1a;(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释&#xff1a;如果您觉得有所帮助&#xff0c;帮忙点个赞&#xff0c;也可以关注我&#xff0c;我们一起成长&#xff1b;如果有不对的地方&#xf…

element-plus的Tour 漫游式引导怎么去绑定Cascader 级联选择器

首先官方例子是用的button 官方.$el这个log出来是&#xff1a; 知道是以元素为准就拿对应的元素就行 级联选择器.$el是这样的&#xff1a; 你可以移入这个元素部分去看看是哪个要用的&#xff08;好像火狐直接放上去就可以看到元素表示&#xff0c;谷歌要双击或者右键选择去看…

英语恶补ing

ing的词组都有停下来做某事的感觉了。 second hand是形容词了。 wouldnt buy这里的would是情态动词&#xff0c;也是助动词 助动词不能单独使用&#xff0c;要搭配实义动词&#xff0c;这样才能构成谓语 情态动词&#xff08;modals&#xff09;在英语中有多种作用&#xff…

Fedora40的#!bash #!/bin/bash #!/bin/env bash #!/usr/bin/bash #!/usr/bin/env bash

bash脚本开头可写成 #!/bin/bash , #!/bin/env bash , #!/usr/bin/bash , #!/usr/bin/env bash #!/bin/bash , #!/usr/bin/bash#!/bin/env bash , #!/usr/bin/env bash Fedora40Workstation版的 /bin 是 /usr/bin 的软链接, /sbin 是 /usr/sbin 的软链接, rootfedora:~# ll …

java8实战1(让方法参数具备行为能力)

客户需求是查出颜色为green的苹果 客户需求变成查出颜色为red的苹果 假设现在客户需求又变了,找出黄色的呢?你想查什么颜色直接做为参数输入 让调用者输入颜色参数 问题是现在客户想把重量做为条件,来筛选苹果集合 这就为难了,客户需求随时会变 观察以上例子,发现有个共同…

Android Studio无法连接夜神模拟器的解决方案

一、AS检测不到夜神模拟器 1、问题描述 在按照教程【如何安装和使用Android夜神模拟器】进入夜神的bin目录&#xff0c;输入连接命令回车后&#xff0c;终端显示的already connected to 127.0.0.1:62001&#xff0c;但是AS的Running Devices并没有显示夜神模拟器。 2、解决方…