1

当我通过运行 SQL 更新脚本为数据库中的用户显式设置权限时,具有最新授权的特定权限不会反映在系统中。但是,当我回收 IIS 进程或重建解决方案时,它似乎才更新。

看起来框架正在使用某种内存存储来检查权限。

ABP 中是否有“强制刷新”功能,我可以调用它来使用数据库中的最新权限刷新内存存储?

奇怪的是,通过前端设置权限时,权限在没有IIS回收的情况下按预期工作,所以它肯定会调用某种函数来更新它的缓存。

4

2 回答 2

1

您可以注入ICacheManager和清除缓存:

public void ForceRefresh()
{
    _cacheManager.GetUserPermissionCache().Clear();
 // _cacheManager.GetRolePermissionCache().Clear();
}
于 2018-04-11T09:37:45.813 回答
0

设置管理器在服务器端缓存设置,因此您不应使用存储库或数据库更新查询直接更改设置值。

如果您的第 3 方应用程序想要更改设置,它应该通过 WebAPI 方法进行。因此,您需要创建一个应用程序服务并添加一个类似ChangeSettingValue({settingName, settingValue}).

在此应用程序中,服务注入ISettingManager、使用ChangeSettingForApplicationAsyncChangeSettingForTenantAsyncChangeSettingForUserAsync方法(和同步版本)分别更改应用程序、租户和用户的设置。

请参阅相关文档 > https://aspnetboilerplate.com/Pages/Documents/Setting-Management

于 2018-04-11T10:23:53.277 回答