首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >HttpClient卡在GetAsync里

HttpClient卡在GetAsync里
EN

Stack Overflow用户
提问于 2019-05-02 13:48:10
回答 3查看 5.4K关注 0票数 4

我正在客户端进行测试,目标是Blazor 3.0.0-预览4-19216-03

剃须刀页:

代码语言:javascript
复制
@page "/counter"
@using BlazorServiceTest
@inject IWebCrawlServiceAsync WebCrawler

<h1>Counter</h1>

<p>Current count: @debug</p>

<button class="btn btn-primary" onclick="@IncrementCount">Click me</button>

@functions {
    string debug = "";

    async void IncrementCount()
    {
        debug = await WebCrawler.GetWeb();
    }
}

依赖注入:

代码语言:javascript
复制
using BlazorServiceTest;
using Microsoft.AspNetCore.Components.Builder;
using Microsoft.Extensions.DependencyInjection;

namespace BlazorServicesTest
{
    public class Startup
    {
        public void ConfigureServices(IServiceCollection services)
        {   
            services.AddSingleton<IWebCrawlServiceAsync, WebCrawlServiceAsync>();            
        }

        public void Configure(IComponentsApplicationBuilder app)
        {
            app.AddComponent<App>("app");
        }
    }
}

该处:

代码语言:javascript
复制
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http;
using System.Threading.Tasks;

namespace BlazorServiceTest
{
    public interface IWebCrawlServiceAsync
    {
        Task<string> GetWeb();
    }

    public class WebCrawlServiceAsync : IWebCrawlServiceAsync
    {
        private HttpClient _client;    

        public WebCrawlServiceAsync(HttpClient client)
        {
            _client = client;
        }

        public async Task<string> GetWeb()
        {
            var response = await _client.GetAsync("https://postman-echo.com/response-headers?foo1=bar1&foo2=bar2");
            var result = await response.Content.ReadAsStringAsync();
            return result;
        }
    }
}

每当我单击Increment时,什么都不会发生,对GetWeb的服务调用将被困在GetAsync调用中。

更新

如果我在Chrome的WASM调试器中调试服务WebCrawler,就会发出他的请求

但是响应部分是空的:

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-05-02 20:33:24

从客户端应用程序,您只能访问您自己的起源或网站,支持CORS。

为了验证这是您的问题,您可以尝试https://postman-echo.com/response-headers?foo1=bar1&access-control-allow-origin=*,这可能有效。

但它只适用于那个网站。您通常无法控制响应头。这不是解决办法。

所以,Blazor客户端对网络爬虫来说不是一个很好的平台。JS或WASM上的任何应用程序也是如此。

Blazor服务器端应该没有问题。或者使用Web服务。

您可以在Wasm应用程序中尝试这样的方法:

代码语言:javascript
复制
@page "/"
@inject HttpClient Http

<h1>Hello, world!</h1>
<div>
    <button class="btn btn-primary" @onclick="GetData1">With CORS</button>
    <button class="btn btn-primary" @onclick="GetData2">No CORS</button>
</div>
<div>@json</div>

@code
{
    string json = ".";

    async Task GetData1()
    {        
        json = await Http.GetStringAsync(
         "https://postman-echo.com/response-headers" + 
         "?foo1=bar1&access-control-allow-origin=*");
    }

    async Task GetData2()
    {
        json = "Getting w/o CORS... ";
        json = await Http.GetStringAsync(
          "https://postman-echo.com/response-headers?foo1=bar1");
    }
}
票数 1
EN

Stack Overflow用户

发布于 2019-05-02 14:11:00

我怀疑这与async void有关。

您需要让处理程序返回一个Task,而不是void

例如

代码语言:javascript
复制
@page "/counter"
@using BlazorServiceTest
@inject IWebCrawlServiceAsync WebCrawler

<h1>Counter</h1>

<p>Current count: @debug</p>

<button class="btn btn-primary" onclick="@IncrementCount">Click me</button>

@functions {
    string debug { get; set; } = "";

    async Task IncrementCount() { //<-- Note Change here
        debug = await WebCrawler.GetWeb();
    }
}

框架中提供了对异步事件处理程序的支持。

参考GitHub问题:通过onclick调用异步函数

票数 1
EN

Stack Overflow用户

发布于 2019-05-02 16:12:31

这可能是由于您无法控制的服务器上的CORS配置问题所致。我相信这个问题与布拉泽无关。要验证这一点,请在应用程序中定义一个本地json文件,并使用应用程序中使用的相同代码访问它。

希望这能成功..。

更新

我不完全确定请求是否由于CORS配置问题而失败,至少不完全是这样。在我看来,它也与SSL/TLS有关。Fiddler发出了此错误消息:

fiddler.network.https> HTTPS握手失败。System.IO.IOException无法从传输连接读取数据:现有连接被远程主机强制关闭。<现有连接被远程主机强制关闭

基础连接已关闭,不能为SSL/TLS安全通道建立信任关系。

我想我会在github上发布这个问题,以便更好地理解哪里出了问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55953929

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档