5 changed files with 114 additions and 12 deletions
@ -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 @@ |
|||||||
|
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