用户属性集成有三种方式,第一种是在使用iframe集成Smartbi的用户管理模块,直接在iframe中管理用户属性,第二种是直接操作用户属性对应的数据库表,第三种是通过服务器端SDK API管理用户属性。
方式一:在集成的用户管理模块中增加用户扩展属性
根据以上步骤使用iframe在第三方系统中集成了用户管理模块后,可以在第三方系统中增加用户扩展属性,具体步骤如下:
(1)在系统运维 > 系统选项 > 用户管理设置 > 用户扩展属性 > 设置中
(2)添加用户扩展属性
(3)清空缓存,重新进入用户管理,对任意一个用户进行设置,就可以看到刚刚添加的用户扩展属性
方式二:直接通过知识库以对用户扩展属性进行修改
用户扩展属性,定义在知识库的 t_systemconfig 表中,在其中 c_key 为 USER_EXTEND_SETTING 的行中,通过 c_long 列,以JSON形式定义。可通过下面的语句查询到该行数据:
SELECT * FROM t_systemconfig where c_key = "USER_EXTEND_SETTING"; |
如配置了前面的用户扩展属性后,查询结果可能为:
修改 c_long 下的JSON即可对用户扩展属性进行修改。
方式三:通过服务器端SDK API对用户扩展属性进行读取
(1)读取用户扩展属性结构
通过 smartbi.sdk.service.systemconfig.SystemConfigService 可以对用户扩展属性的结构进行读取:
ClientConnector conn = new ClientConnector("http://localhost:18080/smartbi"); conn.open("admin", "manager"); SystemConfigService service = new SystemConfigService(conn); SystemConfig config = service.getSystemConfig("USER_EXTEND_SETTING"); System.out.println(config); conn.close(); |
结果形如:
key=USER_EXTEND_SETTING;value=;longValue=[{"name":"用户扩展属性1","alias":"","typeS":"文本框","valueLength":"100"}] |
(2)修改、读取用户属性值
通过 smartbi.sdk.service.user.UserManagerService 可以对用户属性值进行读取、修改:
ClientConnector conn = new ClientConnector("http://localhost:18080/smartbi"); conn.open("admin", "admin"); UserManagerService service = new UserManagerService(conn); service.updateUserAttribute("ADMIN", "用户扩展属性1", "ExampleValue", ""); // 修改用户属性 IExtensionAttribute attr = service.getUserAttribute("ADMIN", "用户扩展属性1"); // 读取用户属性 System.out.println(attr.getValue()); conn.close(); |
实现步骤