By creativz

2009-12-25 02:18:17 8 Comments

My goal is to make web applications!

I finished reading the Books "Headfirst - Java" and "Headfirst - Servlets and JSP".

Because this topic (web applications) is so big and complicated, I would like to ask what I should learn next. I feel overstrained when I read catchwords like Java EE, EJB, JSF, JPA, Glassfish ... but I won't give up.

Can anyone please tell me how I should proceed with learning? Should I grab a book like this: Beginning Java EE 6 Platform with GlassFish 3: From Novice to Professional or should I just make some Online tutorials?



@Pascal Thivent 2009-12-25 04:07:44

Even if I know that this will be controversial, my advice would be to start with Java EE 6 only. So, grab GlassFish v3 and either get the book Beginning Java EE 6 Platform with GlassFish 3: From Novice to Professional or follow the Java EE 6 tutorial. In my opinion, the book (that I've started to read so I know what I'm talking about) provides more guidance which might be preferable if "everything" is new for you (it covers both the Java EE platform and its APIs and the environment to build, deploy your applications).

Now, as I said, I can already hear voices saying things like "Java EE is heavy, use Spring instead, learn Struts or Wicket or Stripes for the presentation layer, learn Hibernate for persistence, or not because I don't like ORM, use iBatis or straight JDBC instead (you'll see, it's cool with Spring, Spring is so cooool), and use Tomcat (and why not Jetty), or JBoss, or just forget all this and go for Grails, and bla bla bla...".

But I don't think that this is really helping you and, without mentoring or guidance (and you won't find a non outdated unique resource covering all combinations), this must sound very confusing for a beginner.

So, because I think that Java EE 6 is a big improvement over previous versions of Java EE, because it provides really nice standard APIs for all your needs (Servlet 3.0, JSF 2.0, JPA 2.0, EJB 3.1 lite, Bean Validation 1.0, CDI, etc), because these APIs are all more than decent, because there is nothing really wrong in learning them, because this is already a big task, because you have to start somewhere, I'd focus on Java EE 6 only and forget the other frameworks for now. More precisely, I'd start with the Java EE 6 Web Profile (and then add things if you want to go further).

By doing this, 1) you'll get started and you'll learn brand new things and 2) you'll give some time to all other frameworks and/or tools to adapt and prove that there is still a need for them. And if there is, it will still be time to experiment the survivors and you'll be able to understand much better why they exist.

@Pascal Thivent 2009-12-25 07:17:01

Thanks. Regarding the book, I've not read it entirely but I'd definitely recommend it for both novice and experimented developers that want to get a good overview of Java EE 6. The book is well constructed, it really covers many APIs (not much are missing), it has code samples demonstrating everything presented, they are really didactic and allow to go as deep as you want. There might be more focused books in the future but this is a good one.

@ChssPly76 2009-12-25 07:39:30

+1, but Spring is so cooool :-)

@Pascal Thivent 2009-12-25 08:20:34

Don't misinterpret me, Stripes, Spring, Hibernate,... are great. But too much choice can be confusing when discovering something new and I believe that Java EE 6 allows you to start without them.

@Esko 2009-12-25 09:34:40

I agree with you, it's very important to learn the JEE stack even if you wouldn't use any of it, after all that stack is the baseline for all the fabulous frameworks which make things truly great, for example Wicket is built on top of the concept of Front Controller which in Java world means Servlets and Filters - if you don't know how those work, you won't really understand what Wicket is doing either! Unless you accept "magic!" as answer, of course.

@Ondra Žižka 2010-06-21 03:11:24

You're putting JBoss amongst Tomcat, Jetty etc? JBoss is Java EE company, right? The one most established in enterprise business AFAIK.

@Pascal Thivent 2010-06-21 12:08:13

@Ondra No I'm not, I was just listing alternatives to illustrate the possible confusion.

@Thorbjørn Ravn Andersen 2010-10-07 10:29:58

+1 for "start with Web Profile"

@jlars62 2014-06-06 17:10:44

4 plus years later.... would you change anything about your answer?

@gfan 2016-10-30 09:49:42

without mentoring or guidance is so painful +1; (and you won't find a non outdated unique resource covering all combinations +1, it's not like .net -- For just only install vs, and get a very thick book, everything you got!)

@Stephen C 2009-12-25 07:44:13

My advice1 is to stop reading books and start implementing stuff. In my experience, book learning is poor a substitute for the knowledge you get by actually doing things.

1 - Context: this is advice to someone who has just finished reading two books on the topic, and is looking for more books to read. In practice you need to balance reading and doing. Especially if you have a specific problem you are trying to solve.

@Muhammad Gelbana 2013-03-15 19:29:24

But it could save you days of searching. Could also give you enough knowledge to answer question instead of asking them and eventually having high reputation in here, don't you agree ?

@Stephen C 2013-05-21 10:28:06

No I don't agree. The OP has already read two Java / Java EE books. It is time for him to do some programming. FWIW, I didn't get most of my knowledge from reading books. Rather I got it PRIMARILY by implementing things, and referring to the documentation when I needed to. You don't learn to ride a bicycle by reading books ... and you don't learn programming skills that way either.

@smwikipedia 2015-01-21 12:38:36

It's important to balance reading and practice.

@jacktrades 2012-11-12 20:17:42

Jpassion provides good videos and material to learn Java EE 6 and other stuff.

You should also see applications examples:

  1. Petstore. Requires Maven, Glassfish recommended. Written by Antonio Goncalves who wrote the mentioned book.
  2. JBoss Ticketmonster. Requires Maven & Jboss Forge. Deploy in Jboss.

@Will Hartung 2009-12-25 06:20:00

Java EE 6 is really amazing. The only problem is that it's about 2 weeks old, and there is only 1 container currently offering it's features -- Glassfish.

I have nothing against Glassfish, I use it all over the place, several production instances, I love the product and the project.

That said, the details of Java EE 6 do not translate back to Java EE 5. Some do, many do, but the Web Profile, Servlet 3.0, the new Bean types, JPA 2, etc. Those aren't there.

So, by learning Java EE 6 first, you're simply constraining yourself to a single container. More are coming, but they're not here yet.

Tomcat, JBoss, OpenEJB, Glassfish, Jetty, Resin, Geronimo, etc. all work well with the Java EE 5 spec (at least those parts of the spec that they support, Tomcat doesn't have EJB for example).

I can't think of anything in Java EE 5 that wasn't carried forward to Java EE 6. Java EE 6 made some very old aspects optional, and those you simply wouldn't learn today anyway. Java EE 6 made some Java EE 5 stuff even easier (packaging notably, EJB Lite for example).

Learn Java EE 5 now so that you can actually apply what you learn in a variety of environments, rather that learning Java EE 6 now and discovering you may not be able to use much of what you learn.

No single book will teach you what you need to know. Servlets, for example, are a nice foundation, but for anything larger than a couple of pages or endpoint, you will want to use one of the many 3rd party frameworks, or JSF, and no book covers the core and then a framework on top of that.

The Java EE 5 tutorial is good at getting the foundations down, my major complaint is that they don't show you the source code. Rather they expect you to just download and run it. It's not discussed in the tutorial. I've found the Head First books to be pretty good.

For web programming, raw Servlets are important enough just to understand the request/response cycle but you don't need a deep understanding to make a leap to a 3rd party framework.

I'm a big fan of Stripes for an Action framework (vs a component framework), and the single Stripes book available is excellent (making choosing that an easy choice).

I can't suggest a Component framework book, and I actually would not recommend one right off. The component frameworks truly bury the HTTP core request/response structures. They bury them for a reason, and they gain value BY burying them, but I believe to be effective you need to have a solid understanding of these concepts early on. That's why I don't suggest learning a Component framework first.

The JAX-RS REST framework, included in Java EE 6, but readily installable in Java EE 5 or any servlet container, is excellent. Arguably it is what Servlet 3.0 should have been. But I don't know any books for that.

@Thorbjørn Ravn Andersen 2010-02-26 14:14:08

Question is what the state of application servers is when you are ready for production. If a given project takes 6 months from now, Oracle and JBoss most likely have JEE6 compliant servers, and Resin most likely have a JEE6 Web Profile server out.

@Thorbjørn Ravn Andersen 2010-10-07 10:31:33

Well, JBoss is due in December. Oracle lies low. Resin has gone quiet regarding their web profile implementation. Geronimo goes for Web Profile with 3.0 (beta). Glassfish is out in 3.0.1 which is really nice.

@Apeirogon Prime 2012-09-28 07:14:02

If you just want to create web applications in Java, check out the Play Framework. It is similar to "Ruby on Rails"

@motiver 2010-11-11 04:39:15

I won't comment on other technologies but if you want to learn Hibernate get "Hibernate Made Easy" by Cameron McKenzie( It is worth every penny. You can finish reading that book in 2 days(literally). it is like a novel and at the end you find yourself dealing with Hibernate like a Semi-Pro.

@danben 2009-12-25 03:24:40

For Tomcat, read the manual on the website. It is very good. Particularly, the first few chapters on web app organization and deployment, and the chapters on the Servlets API and JSPs.

For Spring, the Manning book Spring in Action is very good. Similarly for Hibernate (the Manning book) but I think Hibernate is mostly outside the scope of webapps. Your call, though.

Wicket - Manning book also. But really, just write your front-end code in Javascript. It will be less painful, IMO.

Related Questions

Sponsored Content

26 Answered Questions

[SOLVED] What is a serialVersionUID and why should I use it?

87 Answered Questions

[SOLVED] Is Java "pass-by-reference" or "pass-by-value"?

43 Answered Questions

[SOLVED] How do I efficiently iterate over each entry in a Java Map?

33 Answered Questions

[SOLVED] When to use LinkedList over ArrayList in Java?

58 Answered Questions

[SOLVED] How to create a memory leak in Java?

28 Answered Questions

66 Answered Questions

[SOLVED] How do I generate random integers within a specific range in Java?

  • 2008-12-12 18:20:57
  • user42155
  • 4093375 View
  • 3530 Score
  • 66 Answer
  • Tags:   java random integer

44 Answered Questions

[SOLVED] How do I convert a String to an int in Java?

59 Answered Questions

[SOLVED] How do I read / convert an InputStream into a String in Java?

2 Answered Questions

Java EE6 My goal is to make web applications!

  • 2011-02-17 12:47:05
  • Martin
  • 334 View
  • 0 Score
  • 2 Answer
  • Tags:   jakarta-ee

Sponsored Content