dgc*_*ipp 6 java login liferay user-roles
我需要在登录应用程序时为Liferay的用户分配角色.
我已经实现了实现"Authenticator"的自定义类的"authenticateByScreenName"方法中的所有逻辑.
示例代码:
public class ESBAuthenticator implements Authenticator{
public int authenticateByScreenName(long companyId, String screenName, String password,
Map<String, String[]> headerMap, Map<String, String[]> parameterMap)
setProfile(companyId, screenname);
return 1;
}
public static void setProfile(long companyId, long userId){
User user = UserLocalServiceUtil.getUser(userId);
Role liferayRole = RoleLocalServiceUtil.fetchRole(companyId, "Administrator");
RoleLocalServiceUtil.addUserRole(user.getUserId(), liferayRole.getRoleId());
UserLocalServiceUtil.updateUser(user);
}
}
Run Code Online (Sandbox Code Playgroud)
当我登录时,显然它可以工作,我检查了liferay数据库的表并且它们已经更新,我的用户已经分配了"管理员"角色.但是,前端的门户网站不显示"Admin"选项.
但如果我转到"我的帐户",请按"保存"按钮,注销并再次登录我可以使用管理员选项.
有人知道为什么会这样吗?我在分配角色后调用'updateUser()',它与'save'按钮不一样?
可能的解决方案: 我发现如果我清除在群集中缓存的内容,它可以正常工作.我在这篇文章中找到了它:
https://www.liferay.com/es/web/kamesh.sampath1/blog/-/blogs/how-to-clear-liferay-cache
添加以下行:
MultiVMPoolUtil.clear();
Run Code Online (Sandbox Code Playgroud)
任何人都知道这是否是正确的解决方案?,当按下"my_account"页面中的"保存"按钮时,我无法找到liferay的内容.也许它清除这个缓存?我正在寻找与数据库功能同步,但找不到任何东西.似乎是如果一个列被更新,如果它被缓存,liferay不会使用它:(.
我可以给你一个便宜的技巧。
步骤 1:确保您拥有用户凭据。
步骤 2:根据需要更改用户角色等
步骤3:刷新与流相关的各类缓存(客户端或服务器)
步骤 4:将用户重定向到临时视图,其中将自动应用您持有的用户凭据,然后重定向到门户。
让我知道它是否有效