- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
在 UWP 下,低级 HttpWebRequest
类及其同类已被弃用,并且 the official recommendation就是使用System.Net.Http.HttpClient
但是,HttpClient
实现中似乎存在明显的疏忽或错误:API 似乎没有提供一种方法来向不会自动发出请求的远程 URI下载整个远程资源(在 GET
请求的情况下)以允许延迟评估响应流。
The documentation for the HttpClient.GetAsync()
method说:
This operation will not block. The returned task object will complete after the whole response (including content) is read.
预先声明在请求完成之前将下载整个远程资源。有一个 HttpCompletionOption
参数,如果指定了 HttpCompletionOption.ResponseHeadersRead
,理论上可以解决此问题,记录如下:
The operation should complete as soon as a response is available and headers are read. The content is not read yet.
但是,无论指定了哪个 HttpCompletionOption
,在所有情况下,HttpClient.GetAsync()
都会分配完整的 ContentLength
字节过程中的响应(在内存中!一次全部!没有任何限制检查!)。自然,这有点疯狂,也是一个真正的问题。
在我的特殊情况下,我只想从不支持 http 范围 header 的服务器读取数 GB 远程资源的前几 kb。这通常是一个“不费吹灰之力”的操作:只需创建 Web 请求,从响应流中读取直到您满意为止,然后关闭响应并开始您的快乐之旅。
这似乎不是默认 HttpClient
API 的选项。是否有一种简单的解决方法,不涉及使用原始套接字制作我自己的 HTTP 请求?
最佳答案
in all cases, HttpClient.GetAsync() appears to allocate the complete ContentLength bytes of the response (in memory! all at once! without any limit checking!)
对于 HttpCompletionOption.ResponseHeadersRead
选项,情况并非如此。
就像使用古老的 HttpWebRequest
类一样,您可以打开响应流并读取几个字节,然后丢弃响应。这是 an example .
这是我的实验:(我改用 Windows.Web.Http.HttpClient,但 System.Net.Http.HttpClient 提供了类似的 API)
private HttpClient httpClient = new HttpClient();
private CancellationTokenSource cts = new CancellationTokenSource();
private async void MainPage_Loaded(object sender, RoutedEventArgs e)
{
Uri resourceAddress = new Uri("http://somewhere/gigabyte.zip");
try
{
HttpRequestMessage request = new HttpRequestMessage(HttpMethod.Get, resourceAddress);
// Do not buffer the response.
HttpResponseMessage response = await httpClient.SendRequestAsync(
request,
HttpCompletionOption.ResponseHeadersRead).AsTask(cts.Token);
using (Stream responseStream = (await response.Content.ReadAsInputStreamAsync()).AsStreamForRead())
{
int read = 0;
byte[] responseBytes = new byte[1000];
do
{
read = await responseStream.ReadAsync(responseBytes, 0, responseBytes.Length);
break;
} while (read != 0);
}
}
catch (TaskCanceledException)
{
}
catch (Exception ex)
{
}
finally
{
}
}
关于http - 使用 HttpClient 阻止下载整个远程资源?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44398702/
当我尝试通过我的 .exe 文件从 url 下载 .pdf 文件时出现以下错误。 The server committed a protocol violation. Section=Response
我是一家非营利组织的 G Suite 管理员,刚刚发现数据导出功能,这似乎是个人帐户的外卖。 导出文件已准备好,现在可以从 Google Cloud Platform Storage 中的存储桶下载。
导航 引言 总体思路 七牛云相关的配置文件 获取七牛云上传token 相关类定义 核心代码实现 获取七牛云图片下载链接 公开空
这不是后端编程问题。我只能修改标记或脚本(或文档本身)。我在这里问的原因是因为我对适当术语的所有搜索都不可避免地导致有关编程此功能的问题和解决方案。我不是试图通过编程来强制它;我必须找出此 PDF 行
您好,我已在 Google AdSense 中注册,我想使用适用于 iOS 的 SDK,但目前我找不到 SDK 下载链接。 我的申请已获批准。 任何人都知道如何下载这个sdk。 我使用这个链接来描述如
我需要为当前在 SourceForge 上的 github 项目提供二进制文件和文档。在那里,我可以为我需要的下载提供一个目录结构,因为我必须为大约 10 个不同的操作系统提供几个版本。 github
我从 Canvas 下载绘图时遇到问题。这是我的代码: function downloadCanvas(link, canvasId, filename) { link.href =
ASP.NET 项目 我将使用 Azure 进行存储。问题(要求): 在我的项目中,我让注册用户下载文件。但我不希望用户将此下载链接分享给未注册的人(例如:我给注册用户的下载链接只能在他们的计算机上下
我编写了一个servlet,用于检查http header ,但我不知道为什么当页面加载时,它会自动开始下载。 /* * To change this template, choose To
我正在尝试将下载添加到我的网络浏览器,但遇到的问题是获取您尝试下载的文件的名称。这是我的下载代码: engine.locationProperty().addListener(new ChangeLi
我正在尝试下载网站的 html: String encoding = "UTF-8"; HttpContext localContext = new BasicHttpContext();
我制作了一个带有“开始下载”按钮的框架,用于从网站下载 JAR。 问题是每当我点击开始下载按钮时,整个框架就会卡住,直到下载完成,然后就正常了。 我该如何解决这个问题? 这是单击按钮时执行的代码 p
我得到这段代码来实现一些东西,它可以帮助我从给定的 URL 下载文件。 -(void)URLSession:(NSURLSession *)session downloadTask:(NSURLSes
我正在尝试创建一个 Controller 来使用流方法下载和上传文件,在我的例子中,所有文件都作为 Blob 保存在数据库中。我阅读了 Jboss Netty 的文档,但我认为这不是我的最佳解决方案。
下载并保存文件 let destination: DownloadRequest.DownloadFileDestination = { _, _ in // var fileURL = sel
使用 htaccess 我基本上试图禁止访问该页面,即 http://example.com , 但它仍然允许人们下载文件,如果他们有直接链接即 http://example.com/hi.zip .
我正在寻求将脚本与我的控制面板集成,并且由于我是新手脚本编写者而遇到问题。我想做的是用 1 个脚本下载一个文件并解压它。 示例: wget http://example.com/example.tar
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
这个问题在这里已经有了答案: Top techniques to avoid 'data scraping' from a website database (14 个答案) 关闭 5 年前。 我有
这个问题在这里已经有了答案: Reading and parsing email from Gmail using C#, C++ or Python (6 个答案) 关闭 7 年前。 我只是想,是
我是一名优秀的程序员,十分优秀!