Java 如何阻止Proguard删除类型参数?

Java 如何阻止Proguard删除类型参数?,java,android,maven,proguard,Java,Android,Maven,Proguard,我目前正试图混淆一系列库。My base library包含几个使用类型参数的类和方法,其他代码无法使用它,因为Proguard模糊处理删除了类型参数。消除混淆可以消除这些问题。我已经阅读了所有的ProGuard使用文档、示例和疑难解答,但找不到任何关于如何处理类型参数或ProGuard的哪个方面剥离了类型参数的文档 构造函数类型参数问题: 库1包含以下类: public abstract class AbstractFactoryFactory<T> 返回类型参数问题: 库1具有

我目前正试图混淆一系列库。My base library包含几个使用类型参数的类和方法,其他代码无法使用它,因为Proguard模糊处理删除了类型参数。消除混淆可以消除这些问题。我已经阅读了所有的ProGuard使用文档、示例和疑难解答,但找不到任何关于如何处理类型参数或ProGuard的哪个方面剥离了类型参数的文档

构造函数类型参数问题:

库1包含以下类:

public abstract class AbstractFactoryFactory<T>
返回类型参数问题:

库1具有具有以下方法的Foo类:

public List<String> doSomething()
Proguard.cfg

-dontoptimize

-renamesourcefileattribute SourceFile
-keepparameternames
-keepattributes Exceptions,*Annotation*,InnerClasses,SourceFile,LineNumberTable,Deprecated

-keep public class * {
    public protected *;
}

-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

-keepclassmembernames class * {
    java.lang.Class class$(java.lang.String);
    java.lang.Class class$(java.lang.String, boolean);
}

-keepclasseswithmembernames class * {
    native <methods>;
}

-keepclassmembers class * implements java.io.Serializable {
    static final long serialVersionUID;
    private static final java.io.ObjectStreamField[] serialPersistentFields;
    private void writeObject(java.io.ObjectOutputStream);
    private void readObject(java.io.ObjectInputStream);
    java.lang.Object writeReplace();
    java.lang.Object readResolve();
}
-不要优化
-重命名SourceFileAttribute源文件
-基帕参数
-keepattributes异常、*注释*、内部类、源文件、LineNumberTable、已弃用
-保持公开课*{
受公众保护*;
}
-keepclassmembers枚举*{
公共静态**[]值();
公共静态**valueOf(java.lang.String);
}
-keepclassmembernames类*{
java.lang.Class类$(java.lang.String);
java.lang.Class类$(java.lang.String,布尔值);
}
-KeepClassSwithMemberNames类*{
本地人;
}
-keepclassmembers类*实现java.io.Serializable{
静态最终长SerialVersionId;
私有静态final java.io.ObjectStreamField[]serialPersistentFields;
私有void writeObject(java.io.ObjectOutputStream);
私有void readObject(java.io.ObjectInputStream);
java.lang.Object WriterReplace();
java.lang.Object readResolve();
}
根据ProGuard:

在JDK 5.0及更高版本中编译时,需要“Signature”属性才能访问泛型类型

添加以下行修复了我缺少类型参数的问题:

-keepattributes Signature

谢谢这也是Netty 4库混淆所必需的。Netty 4中的TypeParameterMatcher失败,因为它是构造HttpClientCodec、HttpRequestEncoder或MessageToMessageEncoder以及其他类所必需的。我为其他面临类似棘手困惑问题的用户写这篇评论。你如何保留特定类/方法的
签名
?我花了很长时间才找到问题的根源,但一旦我找到了,答案就在谷歌上出现了!
-dontoptimize

-renamesourcefileattribute SourceFile
-keepparameternames
-keepattributes Exceptions,*Annotation*,InnerClasses,SourceFile,LineNumberTable,Deprecated

-keep public class * {
    public protected *;
}

-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

-keepclassmembernames class * {
    java.lang.Class class$(java.lang.String);
    java.lang.Class class$(java.lang.String, boolean);
}

-keepclasseswithmembernames class * {
    native <methods>;
}

-keepclassmembers class * implements java.io.Serializable {
    static final long serialVersionUID;
    private static final java.io.ObjectStreamField[] serialPersistentFields;
    private void writeObject(java.io.ObjectOutputStream);
    private void readObject(java.io.ObjectInputStream);
    java.lang.Object writeReplace();
    java.lang.Object readResolve();
}
-keepattributes Signature