我正在客户端进行测试,目标是Blazor 3.0.0-预览4-19216-03
剃须刀页:
@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();
}
}依赖注入:
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");
}
}
}该处:
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,就会发出他的请求

但是响应部分是空的:

发布于 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应用程序中尝试这样的方法:
@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");
}
}发布于 2019-05-02 14:11:00
我怀疑这与async void有关。
您需要让处理程序返回一个Task,而不是void
例如
@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();
}
}框架中提供了对异步事件处理程序的支持。
发布于 2019-05-02 16:12:31
这可能是由于您无法控制的服务器上的CORS配置问题所致。我相信这个问题与布拉泽无关。要验证这一点,请在应用程序中定义一个本地json文件,并使用应用程序中使用的相同代码访问它。
希望这能成功..。
更新
我不完全确定请求是否由于CORS配置问题而失败,至少不完全是这样。在我看来,它也与SSL/TLS有关。Fiddler发出了此错误消息:
fiddler.network.https> HTTPS握手失败。System.IO.IOException无法从传输连接读取数据:现有连接被远程主机强制关闭。<现有连接被远程主机强制关闭
基础连接已关闭,不能为SSL/TLS安全通道建立信任关系。
我想我会在github上发布这个问题,以便更好地理解哪里出了问题。
https://stackoverflow.com/questions/55953929
复制相似问题