基于Servlet API如何实现转向时不在地址栏中显示转向后的地址?

基于Servlet API如何实现转向时不在地址栏中显示转向后的地址?,第1张

其实本题为区分重定向和转发的区别,从结果来看重定向会显示新的url,而转发不会显示新的url。所以本题应回答是forword。

本质:转发是服务器行为,重定向是客户端行为。

流程:

转发过程:客户浏览器发送http请求----> web服务器接受此请求--> 调用内部的一个方法在容器内部完成请求处理和转发动作---->将目标资源 发送给客户;在这里,转发的路径必须是同一个web容器下的url,其不能转向到其他的web路径上去,中间传递的是自己的容器内的request。在客 户浏览器路径栏显示的仍然是其第一次访问的路径,也就是说客户是感觉不到服务器做了转发的。转发行为是浏览器只做了一次访问请求。

重定向过程:客户浏览器发送http请求----> web服务器接受后发送302状态码响应及对应新的location给客户浏览器--> 客户浏览器发现 是302响应,则自动再发送一个新的http请求,请求url是新的location地址----> 服务器根据此请求寻找资源并发送给客户。在这里 location可以重定向到任意URL,既然是浏览器重新发出了请求,则就没有什么request传递的概念了。在客户浏览器路径栏显示的是其重定向的 路径,客户可以观察到地址的变化的。重定向行为是浏览器做了至少两次的访问请求的。

再深入一点,从执行效率上来说,明显转发要优于重定向。因为转发实质上只做了一次请求,而重定向做了两次请求。

而从自由度上来说,重定向优于转发。因为能做转发的前提是,两种url都是写在同一个服务器上。所以可以通过服务器程序的内部逻辑来完成转发。重定向可以在第二次不访问本服务器的url。

本文整理自官方文档: 《Surge 官方中文指引:理解 Surge 原理 - 章节 4 转发,代理和规则系统》

本文旨在介绍清楚概念,所以只描述常用只要功能,更多细节请参考官方文档。

被 Surge 拦截的请求在处理完毕后将被转发。

如果 Surge 的出站模式设置为 直接连接 ,那么该请求将被 直接发往目标服务器

如果出站模式设置为 全局代理 ,那么将 转发给指定的代理服务器

当出站模式设置被设置为 规则判定 时,将 根据配置的规则决定转发策略

规则系统中有两个基本概念: 策略 规则

1、策略:描述了 Surge 进行转发的方式,有三种类别:

2、规则:规则由四个部分组成:类型、条件、策略和参数。当条件满足时,该规则匹配,使用该规则指定的策略。

内置策略由 Surge 提供,不随配置而变化:

由于操作系统对用户空间程序(user-space program)的 socket 并没有提供抛弃的操作,Surge 静默抛弃的实现方式是将该 socket 闲置一段时间后再关闭。

同时,如果发往某主机名的请求短时间内大量触发 REJECT/REJECT-TINYGIF 策略(当前版本的阈值为 30 秒内 10 次),为了避免产生大量资源浪费,Surge 将自动升级策略为 REJECT-DROP 策略。

代理策略由用户自己定义,每个策略描述了一个代理服务,当使用该策略时即为通过该代理服务转发请求。

一个简单的代理策略定义行如下:

其中,ProxyA 为策略名,供规则和策略组所使用。第一个参数为代理协议类型,目前 Surge 支持的代理协议类型有:

另外还有两个特殊类型:

第二个参数为代理服务器主机名,第三个参数为代理服务器端口号,后续为 key=value 的参数表,根据协议类型不同需要提供不同的参数。

这是一个特别的类型,严格来说并不是一个代理,用于强制使用某一个网卡进行请求。

external 类型策略可以让 Surge 与其他代理客户端(如:SSR、Brook)更方便的协同工作。

该功能 目前只能通过直接编辑配置 实现,策略定义行为:

其中 args 和 addresses 参数为选填,其他必填。args 和 addresses 字段可以反复使用进行追加。

当使用到该策略时 Surge 会进行以下工作:

(1)使用 exec 和 args 参数启动该外部程序,之后向 SOCKS5 127001:[local-port] 转发请求。

(2)如果外部进程被终止,当再次使用该策略时会自动进行重启。

(3)Surge 会在启动增强模式时自动将 addresses 参数中的地址排除在 VIF 路由表外。(请在该字段填写使用的代理服务器 IP 地址)

(4)当由 Surge 启动的外部进程的请求被 Surge VIF 处理时,永远使用 DIRECT 策略。(为了应对像 obfs-local 这样的插件请求问题,外部进程的子进程也会被同样处理)

(5)Surge 退出时会自动关闭所有外部进程,增强模式关闭时会自动清理加入的路由表。

上述 3 和 4 的功能是有重叠的,请尽量使用 addresses 声明使用到的地址以排除 TUN 处理,这样可以减少系统开销,4 的功能是一重额外保护。

RULE-SET 规则集可以将 多个子规则 放在 一个单独的文件中 ,便于分享和复用。但是规则集中的规则 不可以指定策略 ,整个规则集指向一个同一个策略。

另外 Surge 自带了 SYSTEM 和 LAN 两个规则集,规则集包含的具体子规则会随 Surge 更新而有所调整。注意 LAN 规则集会触发 DNS 解析。

可通过 AND,OR,NOT 运算对所有规则类型进行组合使用。如

可以拦截 Chrome 发出的 UDP 数据包。

(完)

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » 基于Servlet API如何实现转向时不在地址栏中显示转向后的地址?

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情