To me, Java feels nice and homely. Like coming home to your family over Christmas. Of course your parents aren't quite with the times any more and a bit racist, which always makes for a nice discussion with your sister's Hispanic husband. And there's always uncle bob, who gets way too drunk and starts hitting on your wife. Your sister usually tries to get you to invest in her latest MLM scheme and the food tastes like seasoned cardboard. But it's always warm and welcoming. Luckily it's only for the holidays.
I write Java for a paycheck, but I really hate it.
It feels like everything is layers and layers of overengineered cruft, each added to the precarious tower for something extremely minor. But every subsequent card in the house of cards makes it more precarious. "But look, I don't have to write accessors." "But look, I eliminated the need for the web.xml file." "But look, I don't have to understand SQL now." But look, the codebase depends on a shit-ton of completely opaque Automagic(tm) that you have no hope of understanding the moment something goes wrong -- which it will if you even think of changing your Java version. And since it's practically impossible to understand what's going on under-the-hood of whichever dependency is fubar'd this week, you have to resort to a mixture of trial-and-error and copy-pasting shit (that you also don't understand) from StackOverflow and praying to Cthulhu something works -- which is also trial-and-error because Java questions in particular have tons of just straight up wrong answers.
To be fair, I'm the guy on my team who people come to when they run into those sorts of "I bumped up one subminor version of Mockito to fix a bug that was preventing my unit test from working but now literally half of our unit tests won't build" or "I added the war plugin to the build.gradle and now SwaggerUI is broken." So maybe I see more than my fair share of "well shit, I guess I'll just spend the next three hours hunting down which magical combination of Jar version numbers will fix things" kind of problems. But damn. This shit didn't ever happen back when I was doing Python for a paycheck.
I don't use Java if I don't have to. If I have to use Java, I prefer to just use Servlets (mostly I do web development) and absolutely as few dependencies as I can possibly get away with. Fewer moving parts mean less that can break.
You're talking about Java(Jakarta) EE, my comment is primarily targeted at Java SE. I find that the Java standard library on its own and core language is pretty nice if you use modern versions like Java 21. If I had to complain it'd be about checked exceptions, they annoy me but otherwise the language is fine. I've never worked with the full enterprise web stack, I use servelts for web and do a large amount of Java SE desktop development, not with swing, fuck swing. Primarily LWJGL and JavaFX. I love that language, more than most. At work I use a lot of C# and I hate it, I miss Java when I have to write C#. I just don't love it, mostly due to all the little annoyances and missing things(no labeled breaks, no diamond operator for generics, etc). I try to use Java for projects where I can but it's not always an option.
I first learned about Java in the late 90s and it sounded fantastic. "Write once, run anywhere!" Great!
After I got past "Hello world!" and other simple text output tutorials, things took a turn for the worse. It seemed like if you wanted to do just about anything beyond producing text output with compile-time data (e.g. graphics, sound, file access), you needed to figure out what platform and which edition/version of Java your program was being run on, so you could import the right libraries and call the right functions with the right parameters. I guess that technically this was still "write once, run anywhere".
After that, I learned just enough Java to squeak past a university project that required it, then promptly forgot all of it.
I feel like Sun was trying to hit multiple moving targets at the same time, and failing to land a solid hit on any of them. They were laser-focused on portable binaries, but without standardized storage or multimedia APIs at a time when even low-powered devices were starting to come with those capabilities. I presume that things are better now, but I've never been tempted to have another look. Even just trying to get my machines set up to run other people's Java programs has been enough to keep me away.