keycloak~登录皮肤动态切换的尝试

打印 上一主题 下一主题

主题 891|帖子 891|积分 2673

keycloak的登录皮肤theme,可以设置领域全局的,大概每个客户端进行单独设置,这种设计是没有问题的,但有时,一个客户端大概有多种主题,这时,你只能再加个客户端,对应新的主题,但如许不方便日后的统计,因为很多统计维度都是以client为基础的,所以,我们需要在进入登录页时,让开发人员转具体的皮肤参数,然后动态切换皮肤,这个idea不错。
域全局皮肤


客户端个性皮肤


尝试~自定义ThemeSelectorProvider失败

这个应该是keycloak不支持多种皮肤,因为它默认通过default皮肤渲染的,咱们添加的,虽然在spi中注册成功了,但在实现中,并未应用。
  1. /**
  2. * KC目前这个定义是未生效的,目前框架只支持默认的DefaultThemeSelectorProvider
  3. */
  4. public class MyThemeSelectorProvider implements ThemeSelectorProvider {
  5.   KeycloakSession session;
  6.   public MyThemeSelectorProvider(KeycloakSession session) {
  7.     this.session = session;
  8.   }
  9.   @Override
  10.   public String getThemeName(Theme.Type type) {
  11.     return type.name();
  12.   }
  13.   @Override
  14.   public void close() {
  15.   }
  16. }
  17. public class MyThemeSelectorProviderFactory implements ThemeSelectorProviderFactory {
  18.   @Override
  19.   public ThemeSelectorProvider create(KeycloakSession session) {
  20.     return new MyThemeSelectorProvider(session);
  21.   }
  22.   @Override
  23.   public void init(Config.Scope config) {
  24.   }
  25.   @Override
  26.   public void postInit(KeycloakSessionFactory factory) {
  27.   }
  28.   @Override
  29.   public void close() {
  30.   }
  31.   @Override
  32.   public String getId() {
  33.     return "MyThemeSelectorProvider";
  34.   }
  35. }
复制代码

  • org.keycloak.theme.ThemeSelectorProviderFactory文件中注册MyThemeSelectorProviderFactory
终极~还是修改了keycloak源码


  • 修改org.keycloak.theme.DefaultThemeSelectorProvider文件getThemeName()方法,添加请求参数即可

终极的利用


  • https://{keycloak}/auth/realms/{realm}/protocol/openid-connect/auth?theme=你的皮肤名&client_id=account&redirect_uri=&response_type=code&scope=openid
  • keycloak会根据路径参数中theme的值,动态渲染登录皮肤

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

愛在花開的季節

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表