uneven9434 13 hours ago

More modern choices are JADX (https://github.com/skylot/jadx) or Vineflower (https://github.com/Vineflower/vineflower). If you want a paid, higher-quality option, try JEB (https://www.pnfsoftware.com/).

  • billrobertson42 29 minutes ago

    I wanted to suggest Fernflower. I have a lot of experience with it, because it's what Jetbrains uses in Intellij. I have only seen it generate sensible code.

    I took a quick peek at Vineflower first, and it's a fork of Fernflower. So would recommend that for anyone who might stumble on this in the future who is looking for a decompiler.

  • embedding-shape 8 hours ago

    Any of these modern choices include features using LLMs to further decompile the decompiled code? Seems like an obvious direction, even just to infer variable names.

    • xxs 7 hours ago

      >Seems like an obvious direction, even just to infer variable names.

      when debugging symbols are included (sort of the default) the local variables are already present; LLM would be the last thing I'd consider

      • embedding-shape 7 hours ago

        Yeah, I mean duh, of course? Why infer when you have the proper names? I don't understand what you're trying to point out here...

    • webdevver 6 hours ago

      i have no idea why nobody is doing it - it is such an obvious use case of LLMs. i guess the reveng market is much smaller than most people realized?

      then again, who needs reveng when you can use said LLMs to write new software "just in time" with the same API.

      reveng also was one of those industries that always had a very suspicious crowd of people - i dont mean malicious, i mean... a lot of them drew a disturbing amount of pleasure from doing incredibly labourious work, sort of like someone who enjoys putting together an airfix model over many months with a microscopic brush and tweezers.

      so i wonder if a lot of them perversely enjoy starting at reams of bytes and putting together this 10,000 piece puzzle, and having an llm solve it for them is a deep affront to their tastes.

      • m2f2 2 hours ago

        ... until you realize that the LLM-generated code doesn't even compile, or you need a PhD to write all the prompts needed to have a prototype instead of the real thing.

        • webdevver 2 hours ago

          it doesnt have to be traditional chat interface style.

          why doens't someone train an LLM on predicting source code given a sequence of input machine code tokens? that is so obvious. why does nobody do it?

          • croes an hour ago

            Not worth the effort

  • m2f2 2 hours ago

    How do you rate procyon vs these?

drtse4 12 hours ago

Sadly it's not maintained anymore and even the intellijidea-derived decompilers are better nowadays (used to be horrible until a few years ago).

In addition to the limitation to classfiles built for Java8, it sadly has a hard time decompiling new language features even if compiled for a Java8 target. And then there is the well known bug that decompiling full jars in bulk does not get you the same output you see in the UI but orders of magnitude worse... jd was great until it lasted, helped me solve a lot of issues with verdors over the years.

  • p0w3n3d 10 hours ago

    The most annoying thing in intellij (fernflower is it) is that it does not maintain correct line numbers, so when debugging, there is a divergence. Still you need to download sources but not always they are available

    • khannn 8 hours ago

      I've only seen that with transient dependencies that are instantiated via Reflections

VonGuard 12 hours ago

I think this is popping up in Hacker News because the concept of decompilers has become a bit more acceptable recently. (strokes beard)Time was, decompilation was said to be Impossible (as my wise friend syke said: most things people say are impossible are just tedious). Then, it just became "something you could only do in a targeted, single-application fashion.)

Somewhere in there, Alan Kaye laughed and handed everyone dynamic code.

These days, with AI in tow, decompilation is becoming the sort of thing that could be in the toolchain, replacing IDA and such. Why debug and examine when you can literally decompile?!

So, maybe, that idea being considered to be newly on the table, someone felt the need to post a counter-point, proving once again that everything old is new again.

Hats off for decomiling Java apps that mostly predate generics and annotations... both of which were added in 5.

  • malfist 6 hours ago

    I'm not sure you lived the same history I did. Decompiling for intermediate languages has always been a thing. Hell, back in college as an intern I was looking at the assembly of a decompiled C# binary, and back in highschool using intellij's Java decompiler to poke at some game applets to see if there we hacking opportunities. This was back when ruinscape didn't have a paid version

  • branko_d 11 hours ago

    Is there anything especially hard about decompiling (to) Java?

    .NET/C# decompilers are widespread and generally work well (there is one built into Visual Studio nowdays, JetBrains have their own, there were a bunch of stand-alone tools too back in the the day).

    • leibnitz27 10 hours ago

      < disclaimer - I wrote CFR, which is one of the original set of 'modern' java decompilers >

      Generic erasure is a giant pain in the rear. C# doesn't do this. You don't actually keep any information about generics in the bytecode, however some of the metadata is present. BUT IT COULD BE FULL OF LIES.

      There's also a huge amount of syntactic sugar in later java versions - take for example switch expressions.

      https://www.benf.org/other/cfr/switch_expressions.html

      and OH MY GOD FINALLY

      https://www.benf.org/other/cfr/finally.html

      • xxs 7 hours ago

        >Generic erasure is a giant pain in the rear

        Personally, I don't get the sentiment. Yeah, decompiling might not produce the original source code, which is fair. It's possible to generate code using invokeDynamic and what not - still being valid code if a compiler opts to do so.

        When decomiling bytecode there has to be a reason for, and a good one. There has to be a goal.

        If the code is somewhat humanly understandable that's ok. if it's more readable than just bytecode, that's already an improvement.

        Reading bytecode alone is not hard when it comes to reverse engineering. Java already comes with methods and fields available by design. Having local variable names and line numbers preserved is very common, due to exception stack traces being an excellent debugging tool. Hence debugging info gets to be preserved.

        try/finally shares the same issues, albeit less pronounced.

      • ynik 8 hours ago

        C# doesn't erase all generics; but there's also some type erasure happening: nullable reference types, tuple element names, and the object/dynamic distinction are all not present in .NET bytecode; these are only stored in attributes for public signatures, but are erased for local variable types.

        C# also has huge amounts of syntactic sugar: `yield return` and `await` compile into huge state machines; `fixed` statements come with similar problems as "finally" in java (including the possibility of exponential code growth during decompilation).

      • Brybry 9 hours ago

        You're awesome! I had really good experiences with CFR in the mid 2010s.

        I used it for game modding and documentation (and caught/reported a few game bugs + vulnerabilities along the way). I'd pull game files from Steam depots with steamkit, decompile with CFR, and run the resulting java through doxygen.

    • misiek08 6 hours ago

      My personal experience with both is that decompilers work great for easy code. I still have both Java and C# projects that I wish I decompiled even to worst possible, but almost compilable code. Instead getting just decompiler errors or code where all variables got the same letter/name and of course different types...

      I think I've tried all available free tools and some paid in Java case. Finally I just deducted logic and reverse engineered the most important path.

  • xxs 6 hours ago

    >Hats off for decomiling Java apps that mostly predate generics and annotations... both of which were added in 5.

    the 1st very famous and good decompiler was written in C. Other than that generics and annotation didn't not make the work easier at all decmopilation wise

  • croes an hour ago

    Is AI really useful in decompiling or does it just create similar code that does the same as the original?

  • darkamaul 12 hours ago

    One of the use case of décompilation is bug hunting / vulnerability research. And that’s still one of the use cases where AI isn’t that good because you must be precise.

    I’m not saying that won’t change but I still see a bright future for reversing tools, with or without AI sidekicks (like the BN plugin)

    • hhh 11 hours ago

      I used codex 5.1 yesterday to point at a firmware blob and let it extract and explore it targeting a specific undisclosed vulnerability and it managed (after floundering for a bit) to read the Lua bytecode and identify and exploit the vuln on a device running the firmware.

      • gf000 3 hours ago

        Do you have a write up of what exactly happened, how trivial the vulnerability was?

    • never_inline 10 hours ago

      If anything, vulnerability research should be good target for AI because failure to find an exploit isn't costly (and easily verified) but 1 in N success is very useful.

winrid 15 hours ago

Vineflower is probably what you want nowadays

Igor_Wiwi 11 hours ago

Or you can use https://jar.tools/ - online java decompiler I built some time ago. Runs in your browser

  • ur-whale 11 hours ago

    > Runs in your browser

    You say it like it's a good thing.

    • Igor_Wiwi 11 hours ago

      yes, because you don't need to install anything on your machine

j16sdiz 15 hours ago

This one haven't been updated for 5 years and do not support any newer java features.

  • jbn 10 hours ago

    which new feature are not supported?

mberning 15 hours ago

A great tool for digging into obscure jar and class files. I used it many times to track down very obscure bugs in Java based products. Often you will have a vendor saying that your issue is not real or not reproducible on their end. But with this kind of tool you can peek behind the curtains and figure out how to trigger some condition 100% of the time.

  • ternaryoperator 14 hours ago

    It had better be really old Java code. This decompiler supports only through Java 8. We're on Java 24 now.

    • esafak 14 hours ago

      Java 8 is your everyday corporate code ...

      • tombert 13 hours ago

        Didn't Oracle drop support for Java 8 like six years ago? I'm sure there are plenty of companies still running it, but even Apple (a relatively conservative company in this regard) updated to Java 11 when I was there in ~2019.

        • heelix 4 hours ago

          Oracle is supporting Java 8 till 2030 as a paid binary if you download from them and free source code as part of the OpenJDK. Other OpenJDK vendors, like Adoptium, are providing free binaries till 2030 as well. Other folks may or may not provide free binaries. RHEL builds of the OpenJKD are free till November 2026, part of extended life support till 2030.

          For us, the biggest driver for getting off Java 8 was SpringBoot dropping support for anything older than 17.

        • drtse4 12 hours ago

          > Java SE subscribers will receive JDK 8 updates until at least December 2030

          Not for clients with a commercial license, and there are many.

      • rileymichael 13 hours ago

        this isn't really the case. a lot of legacy code may still be running the version it was developed against, but java 17+ has a sizable share of the ecosystem now that all of the popular libraries require it. spring for example bumped their baseline to jdk 17 in 2022.

        • bzzzt 10 hours ago

          Doesn't really matter if you're using an old Spring version with the old Java version. Spring offers enterprise support for Spring framework 5 which still supports Java 8.

          But organizations still using Java 8 will most likely use some kind of Java Enterprise application server with vendor support. IBM will support Websphere with Java 8 until at least 2030 and maybe longer if customers keep paying. I'd guess Oracle has a similar policy.

      • heisenbit 12 hours ago

        It used to but Oracle‘s licensing and probably more important security guidelines from the very top linking CVE scores to mandatory updates got things moving on the last years.

      • anta40 9 hours ago

        What about Android? Hmm....

      • krzyk 14 hours ago

        Nope, we are on Java 25

almosthere 11 hours ago

next, add a feature that does a pass with an llm that makes local variable names more realistic and adds comments.

raver1975 7 hours ago

I wish I could use it to recompile itself

Sanjay_22_xd 10 hours ago

What is the use of decompiling, is there any real time use case?

  • rho4 4 hours ago

    Or when you're too lazy to hunt down the sources, both for internal and external dependencies. Just Ctrl+click the method and have a quick look at the decompiled implementation, usually good enough.

  • speed_spread 6 hours ago

    Anytime you have to debug closed source libraries. Or even make your own implementation.