All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ly.doc.utils.JavaClassUtil Maven / Gradle / Ivy

Go to download

Smart-doc is a tool that supports both JAVA RESTFUL API and Apache Dubbo RPC interface document generation.

There is a newer version: 3.0.5
Show newest version
/*
 * smart-doc
 *
 * Copyright (C) 2018-2023 smart-doc
 *
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package com.ly.doc.utils;

import com.ly.doc.constants.*;
import com.ly.doc.model.ApiConfig;
import com.ly.doc.model.ApiDataDictionary;
import com.power.common.model.EnumDictionary;
import com.power.common.util.CollectionUtil;
import com.power.common.util.EnumUtil;
import com.power.common.util.StringUtil;
import com.ly.doc.builder.ProjectDocConfigBuilder;
import com.ly.doc.model.DocJavaField;
import com.ly.doc.model.torna.EnumInfo;
import com.ly.doc.model.torna.Item;
import com.thoughtworks.qdox.JavaProjectBuilder;
import com.thoughtworks.qdox.model.*;
import com.thoughtworks.qdox.model.expression.AnnotationValue;
import com.thoughtworks.qdox.model.expression.AnnotationValueList;
import com.thoughtworks.qdox.model.expression.TypeRef;
import com.thoughtworks.qdox.model.impl.DefaultJavaField;
import com.thoughtworks.qdox.model.impl.DefaultJavaParameterizedType;
import org.apache.commons.lang3.StringUtils;

import java.lang.reflect.*;
import java.util.*;
import java.util.stream.Collectors;

/**
 * Handle JavaClass
 *
 * @author yu 2019/12/21.
 */
public class JavaClassUtil {

    /**
     * Get fields
     *
     * @param cls1        The JavaClass object
     * @param counter     Recursive counter
     * @param addedFields added fields,Field deduplication
     * @return list of JavaField
     */
    public static List getFields(JavaClass cls1, int counter, Map addedFields, ClassLoader classLoader) {
        Map actualJavaTypes = new HashMap<>(10);
        List fields = getFields(cls1, counter, addedFields, actualJavaTypes, classLoader);

        for (DocJavaField field : fields) {
            String genericCanonicalName = field.getGenericCanonicalName();
            if (Objects.isNull(genericCanonicalName)) {
                continue;
            }
            JavaType actualJavaType = actualJavaTypes.get(genericCanonicalName);
            if (Objects.isNull(actualJavaType)) {
                continue;
            }
            field.setGenericCanonicalName(genericCanonicalName.replace(genericCanonicalName, actualJavaType.getGenericCanonicalName()));
            field.setFullyQualifiedName(field.getFullyQualifiedName().replace(genericCanonicalName, actualJavaType.getFullyQualifiedName()));
            field.setActualJavaType(actualJavaType.getFullyQualifiedName());
        }
        return fields;
    }

    /**
     * Get fields
     *
     * @param cls1            The JavaClass object
     * @param counter         Recursive counter
     * @param addedFields     added fields,Field deduplication
     * @param actualJavaTypes collected actualJavaTypes
     * @return list of JavaField
     */
    private static List getFields(JavaClass cls1, int counter, Map addedFields,
                                                Map actualJavaTypes, ClassLoader classLoader) {
        List fieldList = new ArrayList<>();
        if (Objects.isNull(cls1)) {
            return fieldList;
        }
        // ignore enum class
        if (cls1.isEnum()){
            return fieldList;
        }
        // ignore class in jdk
        String className = cls1.getFullyQualifiedName();
        if (JavaClassValidateUtil.isJdkClass(className)) {
            return fieldList;
        }
        if (cls1.isInterface()) {
            List methods = cls1.getMethods();
            for (JavaMethod javaMethod : methods) {
                String methodName = javaMethod.getName();
                int paramSize = javaMethod.getParameters().size();
                boolean enable = false;
                if (methodName.startsWith("get") && !"get".equals(methodName) && paramSize == 0) {
                    methodName = StringUtil.firstToLowerCase(methodName.substring(3));
                    enable = true;
                } else if (methodName.startsWith("is") && !"is".equals(methodName) && paramSize == 0) {
                    methodName = StringUtil.firstToLowerCase(methodName.substring(2));
                    enable = true;
                }
                if (!enable || addedFields.containsKey(methodName)) {
                    continue;
                }
                String comment = javaMethod.getComment();
                if (StringUtil.isEmpty(comment)) {
                    comment = DocGlobalConstants.NO_COMMENTS_FOUND;
                }
                JavaField javaField = new DefaultJavaField(javaMethod.getReturns(), methodName);
                DocJavaField docJavaField = DocJavaField.builder()
                        .setDeclaringClassName(className)
                        .setFieldName(methodName)
                        .setJavaField(javaField)
                        .setComment(comment)
                        .setDocletTags(javaMethod.getTags())
                        .setAnnotations(javaMethod.getAnnotations())
                        .setFullyQualifiedName(javaField.getType().getFullyQualifiedName())
                        .setGenericCanonicalName(getReturnGenericType(javaMethod, classLoader))
                        .setGenericFullyQualifiedName(javaField.getType().getGenericFullyQualifiedName());

                addedFields.put(methodName, docJavaField);
            }
        }

        JavaClass parentClass = cls1.getSuperJavaClass();
        if (Objects.nonNull(parentClass)) {
            getFields(parentClass, counter, addedFields, actualJavaTypes, classLoader);
        }

        List implClasses = cls1.getImplements();
        for (JavaType type : implClasses) {
            JavaClass javaClass = (JavaClass) type;
            getFields(javaClass, counter, addedFields, actualJavaTypes, classLoader);
        }

        actualJavaTypes.putAll(getActualTypesMap(cls1));
        List javaMethods = cls1.getMethods();
        for (JavaMethod method : javaMethods) {
            String methodName = method.getName();
            if (method.getAnnotations().size() < 1) {
                continue;
            }
            int paramSize = method.getParameters().size();
            if (methodName.startsWith("get") && !"get".equals(methodName) && paramSize == 0) {
                methodName = StringUtil.firstToLowerCase(methodName.substring(3));
            } else if (methodName.startsWith("is") && !"is".equals(methodName) && paramSize == 0) {
                methodName = StringUtil.firstToLowerCase(methodName.substring(2));
            }
            if (addedFields.containsKey(methodName)) {
                String comment = method.getComment();
                if (Objects.isNull(comment)) {
                    comment = addedFields.get(methodName).getComment();
                }
                if (StringUtil.isEmpty(comment)) {
                    comment = DocGlobalConstants.NO_COMMENTS_FOUND;
                }
                DocJavaField docJavaField = addedFields.get(methodName);
                docJavaField.setAnnotations(method.getAnnotations());
                docJavaField.setComment(comment);
                docJavaField.setFieldName(methodName);
                docJavaField.setDeclaringClassName(className);
                addedFields.put(methodName, docJavaField);
            }
        }
        if (!cls1.isInterface()) {
            for (JavaField javaField : cls1.getFields()) {
                String fieldName = javaField.getName();
                String subTypeName = javaField.getType().getFullyQualifiedName();

                if (javaField.isStatic() || "this$0".equals(fieldName) ||
                        JavaClassValidateUtil.isIgnoreFieldTypes(subTypeName)) {
                    continue;
                }
                if (fieldName.startsWith("is") && ("boolean".equals(subTypeName))) {
                    fieldName = StringUtil.firstToLowerCase(fieldName.substring(2));
                }
                long count = javaField.getAnnotations().stream()
                        .filter(annotation -> DocAnnotationConstants.SHORT_JSON_IGNORE.equals(annotation.getType().getSimpleName()))
                        .count();
                if (count > 0) {
                    if (addedFields.containsKey(fieldName)) {
                        addedFields.remove(fieldName);
                    }
                    continue;
                }

                DocJavaField docJavaField = DocJavaField.builder();
                boolean typeChecked = false;
                JavaType fieldType = javaField.getType();
                String gicName = fieldType.getGenericCanonicalName();

                String actualType = null;
                if (JavaClassValidateUtil.isCollection(subTypeName) &&
                        !JavaClassValidateUtil.isCollection(gicName)) {
                    String[] gNameArr = DocClassUtil.getSimpleGicName(gicName);
                    actualType = JavaClassUtil.getClassSimpleName(gNameArr[0]);
                    docJavaField.setArray(true);
                    typeChecked = true;
                }
                if (JavaClassValidateUtil.isPrimitive(subTypeName) && !typeChecked) {
                    docJavaField.setPrimitive(true);
                    typeChecked = true;
                }
                if (JavaClassValidateUtil.isFile(subTypeName) && !typeChecked) {
                    docJavaField.setFile(true);
                    typeChecked = true;
                }
                if (javaField.getType().isEnum() && !typeChecked) {
                    docJavaField.setEnum(true);
                }
                String comment = javaField.getComment();
                if (Objects.isNull(comment)) {
                    comment = DocGlobalConstants.NO_COMMENTS_FOUND;
                }
                // Getting the Original Defined Type of Field
                if (!docJavaField.isFile() || !docJavaField.isEnum() || !docJavaField.isPrimitive()
                        || "java.lang.Object".equals(gicName)) {
                    String genericFieldTypeName = getFieldGenericType(javaField, classLoader);
                    if (StringUtil.isNotEmpty(genericFieldTypeName)) {
                        gicName = genericFieldTypeName;
                    }
                }
                docJavaField.setComment(comment)
                        .setJavaField(javaField)
                        .setFullyQualifiedName(subTypeName)
                        .setGenericCanonicalName(gicName)
                        .setGenericFullyQualifiedName(fieldType.getGenericFullyQualifiedName())
                        .setActualJavaType(actualType)
                        .setAnnotations(javaField.getAnnotations())
                        .setFieldName(fieldName)
                        .setDeclaringClassName(className);
                if (addedFields.containsKey(fieldName)) {
                    addedFields.remove(fieldName);
                    addedFields.put(fieldName, docJavaField);
                    continue;
                }
                addedFields.put(fieldName, docJavaField);
            }
        }
        List parentFieldList = addedFields.values()
                .stream()
                .filter(Objects::nonNull)
                .collect(Collectors.toList());
        fieldList.addAll(parentFieldList);

        return fieldList;
    }


    /**
     * Get Common for methods with the same signature from interfaces
     * @param cls cls
     * @param method method
     * @return common
     */
    public static String getSameSignatureMethodCommonFromInterface(JavaClass cls, JavaMethod method) {

        List methodsBySignature = cls.getMethodsBySignature(method.getName(), method.getParameterTypes(), true, method.isVarArgs());

        for (JavaMethod sameSignatureMethod : methodsBySignature) {
            if (sameSignatureMethod == method
                || sameSignatureMethod.getDeclaringClass() == null
                || !sameSignatureMethod.getDeclaringClass().isInterface()) {
                continue;
            }
            if (sameSignatureMethod.getComment() != null){
                return sameSignatureMethod.getComment();
            }
        }
        return null;
    }


    /**
     * get enum value
     *
     * @param javaClass    enum class
     * @param formDataEnum is return method
     * @return Object
     */
    public static Object getEnumValue(JavaClass javaClass, boolean formDataEnum) {
        List javaFields = javaClass.getEnumConstants();
        if (Objects.isNull(javaFields)) {
            throw new RuntimeException(javaClass.getName() + " enum not existed");
        }
        List methodList = javaClass.getMethods();
        String methodName = null;
        for (JavaMethod method : methodList) {
            List annotations = method.getAnnotations();
            for (JavaAnnotation annotation : annotations) {
                String annotationName = annotation.getType().getValue();
                // enum serialize while use JsonValue and JsonCreator annotation
                if (DocAnnotationConstants.JSON_VALUE.equals(annotationName)
                        || DocAnnotationConstants.JSON_CREATOR.equals(annotationName)) {
                    methodName = method.getName();
                    break;
                }
            }
        }
        Object value = null;
        int index = 0;
        for (JavaField javaField : javaFields) {
            String simpleName = javaField.getType().getSimpleName();
            StringBuilder valueBuilder = new StringBuilder();
            valueBuilder.append("\"").append(javaField.getName()).append("\"").toString();
            if (formDataEnum) {
                value = valueBuilder.toString();
                return value;
            }
            if (!JavaClassValidateUtil.isPrimitive(simpleName) && index < 1) {
                if (CollectionUtil.isNotEmpty(javaField.getEnumConstantArguments()) && Objects.nonNull(methodName)) {
                    // enum serialize while use JsonValue
                    value = javaField.getEnumConstantArguments().get(0);
                } else {
                    value = valueBuilder.toString();
                }
            }
            index++;
        }
        return value;
    }

    public static String getEnumParams(JavaClass javaClass) {
        List javaFields = javaClass.getEnumConstants();
        StringBuilder stringBuilder = new StringBuilder();
        for (JavaField javaField : javaFields) {
            //string comment
            String exception = javaField.getInitializationExpression();
            stringBuilder.append(javaField.getName());
            stringBuilder.append("(").append(exception).append(")").append("
"); } return stringBuilder.toString(); } public static List getEnumValues(JavaClass javaClass) { List javaFields = javaClass.getEnumConstants(); List enums = new ArrayList<>(); for (JavaField javaField : javaFields) { enums.add(javaField.getName()); } return enums; } public static JavaClass getSeeEnum(JavaField javaField, ProjectDocConfigBuilder builder) { if (Objects.isNull(javaField)) { return null; } JavaClass javaClass = javaField.getType(); if (javaClass.isEnum()) { return javaClass; } DocletTag see = javaField.getTagByName(DocTags.SEE); if (Objects.isNull(see)) { return null; } String value = see.getValue(); if (!JavaClassValidateUtil.isClassName(value)) { return null; } // not FullyQualifiedName if (!StringUtils.contains(value, ".")) { List imports = javaField.getDeclaringClass().getSource().getImports(); String finalValue = value; value = imports.stream().filter(i -> StringUtils.endsWith(i, finalValue)).findFirst().orElse(StringUtils.EMPTY); } JavaClass enumClass = builder.getJavaProjectBuilder().getClassByName(value); if (enumClass.isEnum()) { return enumClass; } return null; } /** * get enum info by java class * * @param javaClass the java class info * @param builder builder * @return EnumInfo * @author chen qi * @since 1.0.0 */ public static EnumInfo getEnumInfo(JavaClass javaClass, ProjectDocConfigBuilder builder) { if (Objects.isNull(javaClass) || !javaClass.isEnum()) { return null; } if (Objects.nonNull(javaClass.getTagByName(DocTags.IGNORE))) { return null; } //todo support the field described by @see ApiConfig apiConfig = builder.getApiConfig(); ClassLoader classLoader = apiConfig.getClassLoader(); ApiDataDictionary dataDictionary = apiConfig.getDataDictionary(javaClass.getFullyQualifiedName()); EnumInfo enumInfo = new EnumInfo(); String comment = javaClass.getComment(); DocletTag apiNoteTag = javaClass.getTagByName(DocTags.API_NOTE); enumInfo.setName(comment); enumInfo.setDescription(DocUtil.getEscapeAndCleanComment(Optional.ofNullable(apiNoteTag).map(DocletTag::getValue).orElse(StringUtil.EMPTY))); List enumConstants = javaClass.getEnumConstants(); // value can use invoke method to get value, desc too if (Objects.nonNull(dataDictionary)) { Class enumClass = dataDictionary.getEnumClass(); if (enumClass.isInterface()) { try { enumClass = classLoader.loadClass(javaClass.getFullyQualifiedName()); } catch (ClassNotFoundException e) { return enumInfo; } } List enumInformation = EnumUtil.getEnumInformation(enumClass, dataDictionary.getCodeField(), dataDictionary.getDescField()); List itemList = enumInformation.stream().map(i -> new Item(i.getName(), i.getType(), i.getValue(), i.getDesc())) .collect(Collectors.toList()); enumInfo.setItems(itemList); if (StringUtils.isNotEmpty(dataDictionary.getTitle())) { enumInfo.setName(dataDictionary.getTitle()); } return enumInfo; } List collect = enumConstants.stream().map(cons -> { Item item = new Item(); String name = cons.getName(); String enumComment = cons.getComment(); item.setName(name); item.setType("string"); item.setValue(name); item.setDescription(enumComment); return item; }).collect(Collectors.toList()); enumInfo.setItems(collect); return enumInfo; } /** * Get annotation simpleName * * @param annotationName annotationName * @return String */ public static String getAnnotationSimpleName(String annotationName) { return getClassSimpleName(annotationName); } /** * Get className * * @param className className * @return String */ public static String getClassSimpleName(String className) { if (className.contains(".")) { if (className.contains("<")) { className = className.substring(0, className.indexOf("<")); } int index = className.lastIndexOf("."); className = className.substring(index + 1); } if (className.contains("[")) { int index = className.indexOf("["); className = className.substring(0, index); } return className; } /** * get Actual type * * @param javaClass JavaClass * @return JavaClass */ public static JavaType getActualType(JavaClass javaClass) { return getActualTypes(javaClass).get(0); } /** * get Actual type list * * @param javaType JavaClass * @return JavaClass */ public static List getActualTypes(JavaType javaType) { if (Objects.isNull(javaType)) { return new ArrayList<>(0); } String typeName = javaType.getGenericFullyQualifiedName(); if (typeName.contains("<")) { return ((JavaParameterizedType) javaType).getActualTypeArguments(); } return new ArrayList<>(0); } /** * get Actual type map * * @param javaClass JavaClass * @return Map */ public static Map getActualTypesMap(JavaClass javaClass) { Map genericMap = new HashMap<>(10); List> variables = javaClass.getTypeParameters(); if (variables.size() < 1) { return genericMap; } List javaTypes = getActualTypes(javaClass); for (int i = 0; i < variables.size(); i++) { if (javaTypes.size() > 0) { genericMap.put(variables.get(i).getName(), javaTypes.get(i)); } } return genericMap; } /** * Obtain Validate Group classes * * @param annotations the annotations of controller method param * @param builder builder * @return the group annotation value */ public static Set getParamGroupJavaClass(List annotations, JavaProjectBuilder builder) { if (CollectionUtil.isEmpty(annotations)) { return new HashSet<>(0); } Set javaClassList = new HashSet<>(); List validates = DocValidatorAnnotationEnum.listValidatorAnnotations(); for (JavaAnnotation javaAnnotation : annotations) { List annotationValueList = getAnnotationValues(validates, javaAnnotation); addGroupClass(annotationValueList, javaClassList, builder); } return javaClassList; } /** * Obtain Validate Group classes * * @param javaAnnotation the annotation of controller method param * @return the group annotation value */ public static Set getParamGroupJavaClass(JavaAnnotation javaAnnotation) { if (Objects.isNull(javaAnnotation)) { return new HashSet<>(0); } Set javaClassList = new HashSet<>(); List validates = DocValidatorAnnotationEnum.listValidatorAnnotations(); List annotationValueList = getAnnotationValues(validates, javaAnnotation); addGroupClass(annotationValueList, javaClassList); String simpleAnnotationName = javaAnnotation.getType().getValue(); // add default group if (javaClassList.size() == 0 && JavaClassValidateUtil.isJSR303Required(simpleAnnotationName)) { javaClassList.add("javax.validation.groups.Default"); } return javaClassList; } public static String getClassTagsValue(final JavaClass cls, final String tagName, boolean checkComments) { if (StringUtil.isNotEmpty(tagName)) { StringBuilder result = new StringBuilder(); List tags = cls.getTags(); for (int i = 0; i < tags.size(); i++) { if (!tagName.equals(tags.get(i).getName())) { continue; } String value = tags.get(i).getValue(); if (StringUtil.isEmpty(value) && checkComments) { throw new RuntimeException("ERROR: #" + cls.getName() + "() - bad @" + tagName + " javadoc from " + cls.getName() + ", must be add comment if you use it."); } if (tagName.equals(tags.get(i).getName())) { if (result.length() > 0) { result.append(","); } result.append(value); } } return result.toString(); } return ""; } /** * Get Map of final field and value * * @param clazz Java class * @return Map * @throws IllegalAccessException IllegalAccessException */ public static Map getFinalFieldValue(Class clazz) throws IllegalAccessException { String className = getClassSimpleName(clazz.getName()); Field[] fields = clazz.getDeclaredFields(); Map constants = new HashMap<>(); for (Field field : fields) { if (Modifier.isPrivate(field.getModifiers())) { continue; } if (Modifier.isFinal(field.getModifiers()) && Modifier.isStatic(field.getModifiers())) { String name = field.getName(); constants.put(className + "." + name, String.valueOf(field.get(null))); } } return constants; } private static void addGroupClass(List annotationValueList, Set javaClassList) { if (CollectionUtil.isEmpty(annotationValueList)) { return; } for (AnnotationValue annotationValue : annotationValueList) { TypeRef typeRef = (TypeRef) annotationValue; DefaultJavaParameterizedType annotationValueType = (DefaultJavaParameterizedType) typeRef.getType(); javaClassList.add(annotationValueType.getGenericFullyQualifiedName()); } } private static void addGroupClass(List annotationValueList, Set javaClassList, JavaProjectBuilder builder) { if (CollectionUtil.isEmpty(annotationValueList)) { return; } for (AnnotationValue annotationValue : annotationValueList) { TypeRef typeRef = (TypeRef) annotationValue; DefaultJavaParameterizedType annotationValueType = (DefaultJavaParameterizedType) typeRef.getType(); String genericCanonicalName = annotationValueType.getGenericFullyQualifiedName(); JavaClass classByName = builder.getClassByName(genericCanonicalName); recursionGetAllValidInterface(classByName, javaClassList, builder); javaClassList.add(genericCanonicalName); } } private static void recursionGetAllValidInterface(JavaClass classByName, Set javaClassSet, JavaProjectBuilder builder) { List anImplements = classByName.getImplements(); if (CollectionUtil.isEmpty(anImplements)) { return; } for (JavaType javaType : anImplements) { String genericFullyQualifiedName = javaType.getGenericFullyQualifiedName(); javaClassSet.add(genericFullyQualifiedName); if (Objects.equals("javax.validation.groups.Default", genericFullyQualifiedName) || Objects.equals("jakarta.validation.groups.Default", genericFullyQualifiedName)) { continue; } JavaClass implementJavaClass = builder.getClassByName(genericFullyQualifiedName); recursionGetAllValidInterface(implementJavaClass, javaClassSet, builder); } } private static List getAnnotationValues(List validates, JavaAnnotation javaAnnotation) { List annotationValueList = new ArrayList<>(); String simpleName = javaAnnotation.getType().getValue(); if (simpleName.equalsIgnoreCase(ValidatorAnnotations.VALIDATED)) { if (Objects.nonNull(javaAnnotation.getProperty(DocAnnotationConstants.VALUE_PROP))) { AnnotationValue v = javaAnnotation.getProperty(DocAnnotationConstants.VALUE_PROP); if (v instanceof AnnotationValueList) { annotationValueList = ((AnnotationValueList) v).getValueList(); } if (v instanceof TypeRef) { annotationValueList.add(v); } } } else if (validates.contains(simpleName)) { if (Objects.nonNull(javaAnnotation.getProperty(DocAnnotationConstants.GROUP_PROP))) { AnnotationValue v = javaAnnotation.getProperty(DocAnnotationConstants.GROUP_PROP); if (v instanceof AnnotationValueList) { annotationValueList = ((AnnotationValueList) v).getValueList(); } if (v instanceof TypeRef) { annotationValueList.add(v); } } } return annotationValueList; } public static void genericParamMap(Map genericMap, JavaClass cls, String[] globGicName) { if (Objects.isNull(cls) || Objects.isNull(cls.getTypeParameters())) { return; } List> variables = cls.getTypeParameters(); if (variables.size() > 0) { for (int i = 0; i < cls.getTypeParameters().size() && i < globGicName.length; i++) { genericMap.put(variables.get(i).getName(), globGicName[i]); } return; } try { Class c = Class.forName(cls.getCanonicalName()); TypeVariable[] tValue = c.getTypeParameters(); for (int i = 0; i < tValue.length && i < globGicName.length; i++) { genericMap.put(tValue[i].getName(), globGicName[i]); } } catch (ClassNotFoundException e) { // skip } } public static String javaTypeFormat(String returnType) { if (returnType.contains("?")) { return returnType.replaceAll("[?\\s]", "").replaceAll("extends", ""); } return returnType; } public static boolean isTargetChildClass(String sourceClass, String targetClass) { try { if (sourceClass.equals(targetClass)) { return true; } Class c = Class.forName(sourceClass); while (c != null) { if (c.getName().equals(targetClass)) { return true; } c = c.getSuperclass(); } } catch (ClassNotFoundException e) { e.getMessage(); return false; } return false; } public static Map getClassJsonIgnoreFields(JavaClass cls) { if (Objects.isNull(cls)) { return Collections.EMPTY_MAP; } List classAnnotation = cls.getAnnotations(); Map ignoreFields = new HashMap<>(); for (JavaAnnotation annotation : classAnnotation) { String simpleAnnotationName = annotation.getType().getValue(); if (DocAnnotationConstants.SHORT_JSON_IGNORE_PROPERTIES.equalsIgnoreCase(simpleAnnotationName)) { return JavaClassUtil.getJsonIgnoresProp(annotation, DocAnnotationConstants.VALUE_PROP); } if (DocAnnotationConstants.SHORT_JSON_TYPE.equals(simpleAnnotationName)) { return JavaClassUtil.getJsonIgnoresProp(annotation, DocAnnotationConstants.IGNORE_PROP); } } return ignoreFields; } public static Map getJsonIgnoresProp(JavaAnnotation annotation, String propName) { Map ignoreFields = new HashMap<>(); Object ignoresObject = annotation.getNamedParameter(propName); if (Objects.isNull(ignoresObject)) { return ignoreFields; } if (ignoresObject instanceof String) { String prop = StringUtil.removeQuotes(ignoresObject.toString()); ignoreFields.put(prop, null); return ignoreFields; } LinkedList ignorePropList = (LinkedList) ignoresObject; for (String str : ignorePropList) { String prop = StringUtil.removeQuotes(str); ignoreFields.put(prop, null); } return ignoreFields; } /** * @param javaField * @return */ private static String getFieldGenericType(JavaField javaField, ClassLoader classLoader) { if (JavaClassValidateUtil.isPrimitive(javaField.getType().getGenericCanonicalName()) || (javaField.isFinal() && javaField.isPrivate())) { return null; } String name = javaField.getName(); try { Class c; if (Objects.nonNull(classLoader)) { c = classLoader.loadClass(javaField.getDeclaringClass().getCanonicalName()); } else { c = Class.forName(javaField.getDeclaringClass().getCanonicalName()); } Field f = c.getDeclaredField(name); f.setAccessible(true); Type t = f.getGenericType(); return StringUtil.trim(t.getTypeName()); } catch (NoSuchFieldException | ClassNotFoundException e) { return null; } } private static String getReturnGenericType(JavaMethod javaMethod, ClassLoader classLoader) { String methodName = javaMethod.getName(); String canonicalClassName = javaMethod.getDeclaringClass().getCanonicalName(); try { Class c; if (Objects.nonNull(classLoader)) { c = classLoader.loadClass(canonicalClassName); } else { c = Class.forName(canonicalClassName); } Method m = c.getDeclaredMethod(methodName); Type t = m.getGenericReturnType(); return StringUtil.trim(t.getTypeName()); } catch (ClassNotFoundException | NoSuchMethodException e) { return null; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy