- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 GraphQL 查询类中有一个非常简单的 IQueryable。我想要完成的是获得请求聊天信息的授权用户。将 context.Chats 更改为 context.Chats.Where(i => i.UserId == RequestingId)。所以你不能从我的 API 获得私有(private)聊天。如果您未获得授权,那么您将始终收到一个空列表。我已经了解了如何使用 MVC Controller 执行此操作,但这不是所需的结果。
public class Query
{
[UseDbContext(typeof(AppDbContext))]
[UseFiltering]
[UseSorting]
public IQueryable<Chat> GetChats([ScopedService] AppDbContext context)
{
return context.Chats
.Include(m => m.Messages)
.Include(r => r.Recipients);
}
}
最佳答案
您可以像下面这样注入(inject)用户的 ClaimsPrincipal
:
public IQueryable<Chat> GetChats([ScopedService] AppDbContext context,
[GlobalState(nameof(ClaimsPrincipal))] ClaimsPrincipal claimsPrincipal)
{
// ...
}
在即将发布的 v11.3.1 中,您还可以简单地编写:
public IQueryable<Chat> GetChats([ScopedService] AppDbContext context,
ClaimsPrincipal claimsPrincipal)
{
// ...
}
您可以像这样访问经过身份验证的用户的 Id:
var userId = claimsPrincipal.FindFirstValue(ClaimTypes.NameIdentifier);
注意:根据您设置身份验证/授权机制的方式,声明可能会有所不同。
关于c# - 热巧克力认证连接用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68139292/
我想要类似于以下伪代码的东西: while input is not None and timer = 5: print "took too long" else: print inp
如何将 MainEngine Observable 转换为 Cold?来自这个例子: public IObservable MainEngine { get
自从手表被发明以来,表盘的方圆之争就始终没有停下来过,在漫长的岁月中,无论是方形还是圆形表盘,人们都为其寻找到足够多的设计元素,让其肆意成长,这种生机与活力后来也延续到了智能手表上,在2014年,这
我正在学习 CUDA,试图解决一些标准问题。例如,我正在使用以下代码求解二维扩散方程。但我的结果与标准结果不同,我无法弄清楚。 //kernel definition __global__ void
我的 Web 应用程序使用 native dll 来实现其部分功能(其位置在 PATH 中提供)。一切正常,直到我对 WAR 进行更改并且 JBoss 热部署此 WAR。此时dll已经找不到了,需要手
我看到这个问题here 。这是关于实现每个发出的项目的延迟。这是根据accepted answer如何实现的: Observable.zip(Observable.range(1, 5) .g
我最近一直在进行冷迁移...这意味着我无法在进行迁移时从应用程序级别读取/写入数据库(维护页面)。 这样就不会因为更改结构而发生错误,而且如果负载很大,我也不希望 mysql 在迁移过程中崩溃。 我的
我是一名优秀的程序员,十分优秀!