i am using bytecode analysis to get all imported classes of a classfile (with BCEL). Now, when i read the constant pool, not all imported classes are mentioned as CONSTANT_Class (see spec) but only as CONSTANT_Utf8. My question now: Am i not able to rely solely on the CONSTANT_Class-entries in the constant pool to read the imported files? do i really have to look at every entry and guess, if its a class name? This also does not seem to be correct in every situation imo. Or do i have to read through the whole bytecode? regards
missing classes in classfiles constant pool
937 Views Asked by wrm At
2
There are 2 best solutions below
1
Dave Newton
On
See JVMS 4.2, The Internal Form of FQ Class and Interface Names.
Nutshell: the class structures point to UTF8 entries.
(Or are you instead saying that not all referenced classes are represented by a class and name entry?)
FWIW, be wary of relying solely on this information to determine dependencies as classes can be loaded dynamically and may not appear at all.
Related Questions in JAVA
- I need the BIRT.war that is compatible with Java 17 and Tomcat 10
- Creating global Class holder
- No method found for class java.lang.String in Kafka
- Issue edit a jtable with a pictures
- getting error when trying to launch kotlin jar file that use supabase "java.lang.NoClassDefFoundError"
- Does the && (logical AND) operator have a higher precedence than || (logical OR) operator in Java?
- Mixed color rendering in a JTable
- HTTPS configuration in Spring Boot, server returning timeout
- How to use Layout to create textfields which dont increase in size?
- Function for making the code wait in javafx
- How to create beans of the same class for multiple template parameters in Spring
- How could you print a specific String from an array with the values of an array from a double array on the same line, using iteration to print all?
- org.telegram.telegrambots.meta.exceptions.TelegramApiException: Bot token and username can't be empty
- Accessing Secret Variables in Classic Pipelines through Java app in Azure DevOps
- Postgres && statement Error in Mybatis Mapper?
Related Questions in BYTECODE
- Understanding Invokedynamic Instruction in Java Bytecode and Its Impact on the Operand Stack
- decoding of a byte sequence into a Unicode string
- Java Socket sending command to AV receiver over IP
- Inspect Java bytecode using Bytecode Frameworks (Android)
- When Option pattern matching optimizes up to if statements in Scala?
- Is Node Bytecode decompilable because the interpreter is open source?
- Lists construction in Python Bytecode
- Is it possible to check for a given python file whether it's pyc file is valid and up to date?
- Identical Java SerializedLambda returns different result for implMethodKind
- Is platform-independency of java really because of the combination of interpretation and compilation?
- What are all that zeros in python bytecode and how to compute them
- Debugging a Java application without sources
- Confusing behavior of ObjectWeb ASM and dcmpl/ifgt bytecode instructions
- How can I make org.objectweb.asm.util.CheckClassAdapter throw an exception instead of printing errors to stderr?
- data analysis of java bytecode
Related Questions in BCEL
- Tomcat + jackson-databind => org.apache.tomcat.util.bcel.classfile.ClassFormatException
- get Javassist MethodInfo from Apache BCEL JavaClass
- How do I create a class with bcel and bcel-util which passes the verifier?
- Is there a replacement for deprecated options -Xverify:none and -noverify that were deprecated in JDK 13?
- getSuperClass() throws Exception but getSuperclassName() returns the name of the super class
- How to extract relations between classes using java files instead of class files?
- Error trying to calculate CKJM in Java classes
- BCEL bytecode, how to get method source line?
- How to remove/shrink 'import some.clazz.SomeClass;' statement by means of bytecode manipulation library/framework in Java?
- Get annotation name using Apache Bcel
- Read annotations using Apache Bcel library
- Buck installation with brew tries to hit an invalid url and throws 404
- How to obtain generic type of list
- how to get package name from a class file?
- After update to Java8, getting error during JiBX bind - [bind] java.lang.IllegalStateException: Error loading class java.lang.CharSequence
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
No, it is not correct to use CONSTANT_Class_info entries alone to discover dependencies on other classes/interfaces. If you're parsing input files you trust or can tolerate incorrect information, you can get away with parsing the constant pool only except for one corner case. To get precise information on arbitrary input you need to parse the whole class file. (I assume by "dependencies" you mean those classes or interfaces without which loading or linking a class may result in exceptions, as described in JVMS chapter 5. This doesn't include classes obtained via
Class.forNameor other reflective means.)Consider the following class.
javap -p -v Main.classprints:The class
Foo, referenced as a parameter to the methodidentity, does not appear in the constant pool as a CONSTANT_Class_info entry. It does appear in the method descriptor foridentity(entry #12). Field descriptors may also reference classes not appearing as CONSTANT_Class_info entries. Thus to find all the dependencies from the constant pool alone, you need to look at all UTF8 entries.The corner case: Some UTF8 entries may exist to be referenced by CONSTANT_String_info entries. Duplicate UTF8 entries will be merged, so one UTF8 entry might be a method descriptor, a string literal, or both. If you're only parsing the constant pool, you must live with this ambiguity (probably by overapproximating and treating it as a dependency).
If you trust the input to have been produced by a well-behaved Java compiler under your control, you can parse all UTF8 entries, mindful of the string corner case, and stop reading here. If you need to defend against an attacker feeding your tool handcrafted class files (e.g., you're writing a decompiler and the attacker wants to prevent decompilation), you need to parse the entire class file. Here's a few examples of the potential problems.
Main. The JVM may or may not try to resolve this reference (JVMS 5.4 permits both lazy and eager loading). As the class exists, either way, no error will be raised, so this extra entry is harmless, but it will fool tools looking at the constant pool into thinking Thread is a dependency.That's just what I came up with off the top of my head. A clever attacker going through the JVMS with a fine-tooth comb could probably find more places to add entries to the constant pool that look used but aren't. If you need precise information even in the face of an attacker, you need to parse the whole class file and understand how a JVM will use it.