微软交流社区

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 89|回复: 0

"混乱"的 Windows 10 更新系统代理(上)

[复制链接]

1

主题

2

帖子

3

积分

新手上路

Rank: 1

积分
3
发表于 2022-11-30 15:38:47 | 显示全部楼层 |阅读模式
背景

Windows 更新过程对于普通用户基本是无感的,不需要用户参与。系统中的更新服务会自动周期性的检查更新服务器是否有适合本机的更新包,只要连接到互联网并且更新服务器上有适用于客户计算机的更新包,客户计算机就会下载并安装 Windows 更新。
网络代理能够保护用户隐私、提高安全性、访问加速,对于组织单位来说,还能提供网络访问控制、节省带宽,它的使用比较常见。
本来体验丝滑的 Windows Update 更新过程和具有一身优点的网络代理各自安好,但它俩遇到一起想要更进一步的时候,二者合作并不顺畅。给人的感觉就变成了"混乱"的 Windows 10 更新系统代理。
为什么这么说呢?Windows 更新过程涉及扫描、下载、安装过程,每一部分都采用独立的服务。Windows 更新客户端利用 Windows HTTP 服务(WinHTTP)扫描可用更新;利用 Background Intelligent Transfer Service (BITS)服务或者Delivery Optimization (DO)来下载更新。这些服务各自独立,需要针对这些服务进行代理配置,使其能够通过代理完成 Windows 系统更新。再加上不同组策略的影响,当用户为更新系统配置代理的时候,偶尔会出现明明已经开启代理,但更新服务就是没有工作,这不免会产生"混乱"的感觉。
介绍 Windows 10 操作系统在更新过程中使用代理的配置方式之前,本文先从我的理解说明 Windows 更新代理配置实现背后(搞的这么混乱)的原因,如何为 Windows 更新系统配置代理将在《'混乱'的 Windows 10 更新系统代理(下)》中说明。
首先看一下 Windows (无特殊说明,均指 Windows 10)系统中支持哪些代理设置。
Windows 中的代理

Windows 默认支持用户设置代理,包括"用户代理"、"计算机代理"和"系统代理"设置。需要说明一点,三种代理设置方式都不是"全局代理","全局代理"是指 Windows 系统中所有的对外连接都要通过这个代理。Windows 本身没有全局代理的配置,可以借助第三方软件实现。
用户代理

用户代理是最常用的,尤其早期Internet Explorer(IE浏览器)一统江山的时候(注:2022年6月15微软已经停止对最新版IE 11的支持,并且在2023年2月14不可用[1],上网、IE、代理,连在一起。
Windows 中存在多个入口可以设置用户代理。
在IE浏览器中设置代理:"Internet 选项" -> "连接" -> "局域网设置" -> "代理服务"
在控制面版中设置代理: 控制面板 -> 网络和 Internet -> "连接" -> "局域网设置" -> "代理服务"


后来的 Windows 中可以通过"开始"->"设置"->"网络和Internet"->"代理" 进行手动代理设置



这二者的设置效果是一致的。直接影响都是修改了注册表中的信息,包括以下键值:
计算机\HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet Settings
        - ProxyEnable
        - ProxyServer
        - ProxyOverride非常多的网络访问需求依赖于IE实现,包括Windows自身的APP和大量内部依赖于IE网络库实现的第三方应用。在IE或者"设置"中开启代理后,非常多应用直接就可以通过代理访问网络服务。所以经常听到的一种说法是设置全局代理或者系统代理就是去设置IE代理,其实这是不准确的。
计算机代理

在"用户代理"部分中描述的所有设置都只对当前用户生效,如果设置对于所有登录到当前计算机的用户都生效,需要通过组策略进行配置。
配置方式为执行gpedit.msc命令,选择"本地计算机策略" -> "计算机配置" -> "管理模板" -> "Windows 组件" -> "Internet Explorer" -> "按计算机(而不是按用户)进行代理设置" 。


计算机代理和用户代理的配置关系就像平时安装软件,软件提示用户"此安装软件仅为当前账户使用"还是"此安装软件供所有该计算机上的用户使用"的例子一致。
"系统"代理

一种说法是采用netsh进行WinHttp代理设置对系统范围内通过WinHttp API实现的http会话都有效,所以这种方式设置的代理就成为了"系统"代理。
这里称为"系统"代理总是容易引起误会,它的最准确称呼应该是WinHttp代理,但这个又有些专业拗口了...
强调一点,这个代理并不是全局的。
基本用法
netsh winhttp set proxy myproxy
set proxy myproxy:80 "<local>bar"
set proxy proxy-server="http=myproxy;https=sproxy:88" bypass-list="*.contoso.com"Windows 中代理实现的背后

在开发 Windows 桌面客户端应用时,有几种实现http的方式。开发人员可以自己封装 Winsock 来支持http的实现,这具有灵活性和扩展性,但随之而来的问题是工作量大、开发效率低。可以采用第三方库,如libcurl、boost,它们提供了跨平台的优势,但会引入额外第三方代码,可能带来license风险。还有就是微软提供了非常多的和比较细分的网络服务、库和开发框架供开发人员使用,其中就包括 Windows Internet(WinInet) 和 Microsoft Windows HTTP Services(WinHttp) 服务。
WinNet使应用程序能够与 FTP 和 HTTP 协议交互以访问 Internet 资源。WinHttp提供HTTP客户端应用程序编程接口,以使通过HTTP协议将请求发送到其他HTTP服务器。二者都能够提供对HTTP访问的支持,但它们存在的区别决定了我们使用一些网络服务时候看到的不同现象。
WinINet

WinINet 从 Windows NT 和 Windows 95 开始就存在了,它的主要目的是允许应用程序与FTP和HTTP协议交互来访问网络资源。官方不建议WinINet用在 Windows Service 和服务器应用中[2],它主要被IE和其他一些需要网络连接的应用使用。
通过process explorer工具可以查看使用WinINet.dll的应用程序,IE是其中之一。


查看WinINet的文档,它的许多特性[3]中,有两点与用户直接相关:

  • WinINet支持FTP协议,所以基于WinINet实现的IE支持ftp登录
    一个简单的验证是在IE浏览器中输入ftp服务器地址,IE浏览器能够直接登录;而其他浏览器(firefox、chrome)则会提示"选择用于打开ftp链接的应用程序"


2. WinINet支持凭据管理
这里的凭据管理包括两个部分"凭据缓存"和"凭据提示"。
Credential Cache, Allows all built-in applications in Windows Internet Explorer to get credentials automatically. It also allows an application running outside of Internet Explorer to prompt/specify the credentials for the server only once. From then on the requests are automatic.
Credential Prompting, Provides an API that allows the calling code to prompt the user for credentials.上面是官方给的说法,说白了就是WinINet支持http会话中服务器身份验证和代理身份验证,并且能够以交互的方式要求用户输入身份验证凭据(即用户名和口令)。身份验证分为两种情况:代理服务器对用户连接请求的认证;(真实)服务器对用户登录的认证[4]。
按照HTTP协议文档(RFC2616)建议,当服务器收到需要身份验证的请求时,服务器将返回 401 状态代码消息;当客户端尝试使用需要身份验证的代理时,代理会将 407 状态代码消息返回到客户端。在IE浏览器中访问这两种需要认证的服务的时候,就会弹出对话框,要求输入认证的信息。基本的认证方式就是要求输入用户名和口令。这个过程就是对应"凭据提示"。
在用户输入完成后,这个凭据会被缓存,当下次请求相同的地址需要认证的时候,"凭据缓存"就会发生作用。
被缓存的凭据可以通过系统中的"凭据管理器"中查看。


WinHttp

WinHttp 支持服务器应用程序、Windows 服务和 Windows 应用程序开发。
通过process explorer工具可以查看使用WinHttp.dll的应用程序。



WinHttp应用作为普通用户程序运行的时候,如果代码逻辑中支持对代理的检查,它是可以使用用户代理进行网络访问的,也就是WinHttp应用也支持使用IE代理。
WinHttp应用作为 Windows 服务运行的时候,是以Local System Account运行,此时不能够访问HKEY_CURRENT_USER下面的注册表项。因为这个限制,用户代理中配置的代理信息就无法使用了。需要使用netsh来配置"系统"代理,使其对于系统中所有调用WinHttp API应用都生效。
两种运行环境下,WinHttp都能够支持代理设置。但与WinINet相比,WinHttp不支持凭据管理,当代理或应用服务器要求用户认证的时候,WinHttp无法满足要求
至此,Windows 中的代理分类及基本的配置已经介绍完毕,在下一部分,我们介绍这些代理配置是如何影响 Windows 更新过程的。
参考


  • internet explorer downloads
  • WinInet is not supported in a service or an IIS application
  • WinINet vs. WinHTTP
  • Handling Authentication
参考


  • ^internet explorer downloads https://support.microsoft.com/en-us/windows/internet-explorer-downloads-d49e1f0d-571c-9a7b-d97e-be248806ca70#ID0EBBD=Windows_10
  • ^WinInet is not supported in a service or an IIS application https://learn.microsoft.com/en-US/troubleshoot/developer/browsers/development-website/wininet-not-supported-in-services
  • ^WinINet vs. WinHTTP https://learn.microsoft.com/en-us/windows/win32/wininet/wininet-vs-winhttp
  • ^Handling Authentication https://learn.microsoft.com/en-us/windows/win32/wininet/handling-authentication
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|微软交流社区

GMT+8, 2025-1-8 11:32 , Processed in 0.067944 second(s), 18 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表