gpt4 book ai didi

angular - 如何在 CanActivate 守卫中获取 url 段

转载 作者:行者123 更新时间:2023-12-05 07:43:46 26 4
gpt4 key购买 nike

我正在使用守卫来确保用户在到达他们请求的页面之前进行身份验证。

一个特定的用例预见到用户输入带有一些查询参数的 url,例如 https://myserver.com/the-page-i-want?par1=val1&par2=val2

在守卫中,我需要检索参数和 url 段(即在本例中为 the-page-i-want)。为此,我实现了以下代码

export class AuthGuard implements CanActivate {

constructor(private router: Router) {}

canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
const url = state.url;
const queryParams = route.queryParams;
// some other logic
}

}

我在运行代码时看到的是,queryParams 变量实际上填充了包含查询字符串中传递的参数的对象。另一方面,变量 url 包含整个 url 字符串,包括参数(即它包含 the-page-i-want?par1=val1&par2=val2/strong> 在这种情况下)。

如果我检查 route 参数的值,我可以看到我正在寻找的信息(即只是the-page-i-want) 存储在 _urlSegment 属性的某个深处,但不通过 API 提供。

我正在使用 Angular Router 3.4.9 运行 Angular v2.4.9

任何有关如何获取 url 段的建议将不胜感激。

最佳答案

您应该改用 route.url[0].path。根据ActivatedRouteSnapShot文档,route.url 应该返回 UrlSegment 的数组, 之后你可以访问你的 UrlSegment

path

关于angular - 如何在 CanActivate 守卫中获取 url 段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43409381/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com