5 changed files with 114 additions and 12 deletions
@ -0,0 +1,59 @@
@@ -0,0 +1,59 @@
|
||||
package com.cloud.kicc.common.security.override.jackson2; |
||||
|
||||
import com.cloud.kicc.common.data.entity.KiccUser; |
||||
import com.fasterxml.jackson.core.JsonParser; |
||||
import com.fasterxml.jackson.core.type.TypeReference; |
||||
import com.fasterxml.jackson.databind.DeserializationContext; |
||||
import com.fasterxml.jackson.databind.JsonDeserializer; |
||||
import com.fasterxml.jackson.databind.JsonNode; |
||||
import com.fasterxml.jackson.databind.ObjectMapper; |
||||
import com.fasterxml.jackson.databind.node.MissingNode; |
||||
import org.springframework.security.core.GrantedAuthority; |
||||
import org.springframework.security.core.authority.AuthorityUtils; |
||||
|
||||
import java.io.IOException; |
||||
import java.util.List; |
||||
import java.util.Set; |
||||
|
||||
/** |
||||
*<p> |
||||
* 反序列化扩展用户实现 |
||||
*</p> |
||||
* |
||||
* @Author: wangxiang4 |
||||
* @Since: 2023/8/19 |
||||
*/ |
||||
class ExUserDeserializer extends JsonDeserializer<KiccUser> { |
||||
|
||||
private static final TypeReference<Set<String>> EX_PERMISSIONS_SET = new TypeReference<Set<String>>() {}; |
||||
|
||||
@Override |
||||
public KiccUser deserialize(JsonParser jp, DeserializationContext context) throws IOException { |
||||
ObjectMapper mapper = (ObjectMapper) jp.getCodec(); |
||||
JsonNode jsonNode = mapper.readTree(jp); |
||||
JsonNode passwordNode = readJsonNode(jsonNode, "password"); |
||||
String username = readJsonNode(jsonNode, "username").asText(); |
||||
String password = passwordNode.asText(""); |
||||
String deptId = readJsonNode(jsonNode, "deptId").asText(); |
||||
String userType = readJsonNode(jsonNode, "userType").asText(); |
||||
Set<String> exPermissions = mapper.convertValue(jsonNode.get("exPermissions"), EX_PERMISSIONS_SET); |
||||
List<GrantedAuthority> authorities = AuthorityUtils.createAuthorityList(exPermissions.toArray(new String[0])); |
||||
KiccUser result = new KiccUser( |
||||
username, |
||||
password, |
||||
authorities, |
||||
deptId, |
||||
userType, |
||||
exPermissions |
||||
); |
||||
if (passwordNode.asText(null) == null) { |
||||
result.eraseCredentials(); |
||||
} |
||||
return result; |
||||
} |
||||
|
||||
private JsonNode readJsonNode(JsonNode jsonNode, String field) { |
||||
return jsonNode.has(field) ? jsonNode.get(field) : MissingNode.getInstance(); |
||||
} |
||||
|
||||
} |
@ -0,0 +1,23 @@
@@ -0,0 +1,23 @@
|
||||
package com.cloud.kicc.common.security.override.jackson2; |
||||
|
||||
import com.fasterxml.jackson.annotation.JsonAutoDetect; |
||||
import com.fasterxml.jackson.annotation.JsonIgnoreProperties; |
||||
import com.fasterxml.jackson.annotation.JsonTypeInfo; |
||||
import com.fasterxml.jackson.databind.annotation.JsonDeserialize; |
||||
|
||||
/** |
||||
*<p> |
||||
* 序列化扩展SSO用户信息 |
||||
*</p> |
||||
* |
||||
* @Author: wangxiang4 |
||||
* @Since: 2023/8/19 |
||||
*/ |
||||
@JsonDeserialize(using = ExUserDeserializer.class) |
||||
@JsonAutoDetect(fieldVisibility = JsonAutoDetect.Visibility.ANY, |
||||
getterVisibility = JsonAutoDetect.Visibility.NONE, |
||||
isGetterVisibility = JsonAutoDetect.Visibility.NONE) |
||||
@JsonIgnoreProperties(ignoreUnknown = true) |
||||
public abstract class ExUserMixin { |
||||
|
||||
} |
Loading…
Reference in new issue