当我通过运行 SQL 更新脚本为数据库中的用户显式设置权限时,具有最新授权的特定权限不会反映在系统中。但是,当我回收 IIS 进程或重建解决方案时,它似乎才更新。
看起来框架正在使用某种内存存储来检查权限。
ABP 中是否有“强制刷新”功能,我可以调用它来使用数据库中的最新权限刷新内存存储?
奇怪的是,通过前端设置权限时,权限在没有IIS回收的情况下按预期工作,所以它肯定会调用某种函数来更新它的缓存。
当我通过运行 SQL 更新脚本为数据库中的用户显式设置权限时,具有最新授权的特定权限不会反映在系统中。但是,当我回收 IIS 进程或重建解决方案时,它似乎才更新。
看起来框架正在使用某种内存存储来检查权限。
ABP 中是否有“强制刷新”功能,我可以调用它来使用数据库中的最新权限刷新内存存储?
奇怪的是,通过前端设置权限时,权限在没有IIS回收的情况下按预期工作,所以它肯定会调用某种函数来更新它的缓存。
您可以注入ICacheManager
和清除缓存:
public void ForceRefresh()
{
_cacheManager.GetUserPermissionCache().Clear();
// _cacheManager.GetRolePermissionCache().Clear();
}
设置管理器在服务器端缓存设置,因此您不应使用存储库或数据库更新查询直接更改设置值。
如果您的第 3 方应用程序想要更改设置,它应该通过 WebAPI 方法进行。因此,您需要创建一个应用程序服务并添加一个类似ChangeSettingValue({settingName, settingValue})
.
在此应用程序中,服务注入ISettingManager
、使用ChangeSettingForApplicationAsync
、ChangeSettingForTenantAsync
或ChangeSettingForUserAsync
方法(和同步版本)分别更改应用程序、租户和用户的设置。
请参阅相关文档 > https://aspnetboilerplate.com/Pages/Documents/Setting-Management