繁体   English   中英

C# Blazor 客户端从 url 读取哈希参数

[英]C# Blazor client-side read hash parameters from url

我在Blazor有一个项目

在客户端,我想读取哈希参数

我知道如何在 JavaScript 中做到这一点 - 但我的问题是如何在 Blazor 项目的 c# 客户端中做到这一点

例如,我有一个 URL http://localhost:5060/#token=12345678

如何拿token

我在 index.cshtml 中的代码

@page "/"
@inject Microsoft.AspNetCore.Blazor.Services.IUriHelper UriHelper

<h1>Hello, world!</h1>

url is @Url

@functions {
protected override void OnInit() {
    Url = GetUrl();
}

public string Url { get; set; }

public string GetUrl() {
    return ?;
}
}

如果您可以在 JavaScript 中完成,那么使用 JavaScript Interop: 1. 定义一个提取令牌的 JavaScript 函数。 2.定义一个调用函数的C#方法

但是使用本身使用 JavaScript 的 Blazor 来做到这一点会更好......你需要的是查看 Microsoft.AspNetCore.Blazor.Services.UriHelperBase 和/或 Microsoft.AspNetCore.Blazor.Browser.Services 中定义的方法.BrowserUriHelper

希望这可以帮助...

注意: <base>元素在位于 wwwroot 文件夹的 Index.Html 文件中设置。

HTML <base>元素指定用于包含在文档中的所有相对 URL 的基本 URL。文档中只能有一个元素。

可以使用 document.baseURI 从脚本中查询文档的基本 URL。”

尝试这个:

var absoluteUrl = UriHelper.GetAbsoluteUri();
var token = absoluteUrl.Substring(absoluteUrl.IndexOf("=") + 1);

为了在没有 JavaScript 或其他客户端解决方案的情况下读取 C# Blazor 中的哈希参数,我需要更改函数,如下面的代码所示:

@functions {
  private string url = string.Empty;

  protected override void OnInit() {
    string url = UriHelper.GetAbsoluteUri();
    string[] parameters = url.Replace(UriHelper.GetBaseUri(), "").Replace("#", "").Split('&');

    string token = string.Empty;

    foreach (string prm in parameters) {
      if (prm.IndexOf("token=") >= 0) {
        token = prm.Replace("token=", "");
      }
    }

    UriHelper.OnLocationChanged += OnLocationChanged;
  }

  private void OnLocationChanged(object sender, string newUriAbsolute) {
    url = newUriAbsolute;
  }

  public void Dispose() {
    UriHelper.OnLocationChanged -= OnLocationChanged;
  }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM