Como iniciar em Java para WEB sem medo!
Introdução
Minha intenção com este post é tentar de alguma forma ajudar aqueles profissionais que estão iniciando em Java Web, profissionais que com tantas opções que a plataforma Java nos oferece, as vezes não sabem por onde iniciar, então quero tentar dar um norte inicial para começar bem.
Não vamos aqui discutir sobre qual IDE, ferramenta, infra em geral, pois já temos vários artigos na web que tratam deste assunto. Quero focar na parte conceitual da coisa.
Quero com este post responder algumas perguntas como:
1. Sou iniciante em Java para Web, o que devo aprender primeiro?
2. Devo começar pela especificação JEEx e seguir somente ela?
3. Qual framework devo começar?
4. Por que não devo começar com JSF/Seam e afins?
Não quero aqui entrar no mérito de quem é melhor, framework X ou Y, linguagem X ou Y. Como já falei em uma lista: Amadureci para não perder meu tempo discutindo sobre isso.
Vou escrever aqui a minha opinião, a minha visão, baseado nos anos de experiência que tenho com desenvolvimento Web e Java, baseado nas conversas que tenho com outros profissionais com a mesma e maior experiência do que eu, nas experiências de inúmeros projetos que já participei durante toda a minha carreira.
Então vamos iniciar as argumentações, lembrando que isso é voltado para aqueles que estão ainda iniciando no desenvolvimento Web na plataforma Java ou para aqueles que não tem uma base sólida em Web.
Iniciando no mundo Java Web
1. Sou iniciante em Java para Web, o que devo aprender primeiro?
Bem, se você está entrando agora no mundo Web, você precisa primeiro aprender WEB, aprender como funciona uma página WEB e aprender a linguagem da WEB, seus protocolos e comportamentos. Isso parece ser óbvio, mas muitos se perdem neste momento e simplesmente não ligam para isso, achando que já devem aprender frameworks X ou Z.
Vamos citar aqui os principais conceitos que um bom desenvolvedor web TEM que saber ou pelo menos conhecer:
Entenda como funciona e para que serve todos os verbos HTTP (HTTP verbs) que existem. Tenha um entendimento pelo menos de POST, GET, DELETE e PUT.
Você como desenvolvedor web é OBRIGADO a saber HTML, pelo menos as suas tags mais comuns, como utilizá-las e para que servem cada uma e como funcionam. Não saber isso é como querer tirar a carteira de motorista sem saber o que é um carro. Acesse: w3schoolsHTML
Entenda, como e o que é CSS, você não precisa ser um expert em CSS, mas saber o básico ajuda e muito, e você um dia irá precisar, acredite. A não ser que você não esteja desenvolvendo para WEB. Uma boa dica, é começar pelo site da w3schoolsCSS e o site do maujor.
Estude também o que é e como funciona um Web Container e sua estrutura básica de funcionamento.
APRENDA Servlet, JSP, por mais que você ache “antigo” eles são muito importantes para você complementar seu conhecimento em desenvolvimento web na plataforma java e acredite seu framework UTILIZA eles por baixo. Então é FUNDAMENTAL saber o que é e como funciona um Servlet e JSP.
“Brinque” um pouco com TAGsLib, EL (Expression Language), são ferramentas simples de se utilizar (principalmente EL), e deixam seu código bem mais legível. Você verá mais a frente.
JavaScript, ele é importante. Se você deseja ser um bom profissional web, você PRECISA saber javaScript. Por muitos anos o JavaScript foi considerado uma linguagem fraca, que só servia para enviar alerts para os usuários ou somente para validação de formulários. Grande engano.
O JS já provou por A + B que é uma poderosa linguagem em diversos segmentos de server-side desde Frameworks MVC (Express/Node.js | Helma/Rhino) a bancos de dados não relacionais (CouchDB, MongoDB), além do tradicional client-side com Frameworks populares (jQuery/ExtJS).
E o mito de que JS é ruim de manter, código desorganizado etc, é simplesmente somente um MITO, e é simplesmente falta de conhecimento de quem não sabe desenvolver com JS. JS hoje, está muito maduro e robusto, existem vários frameworks para facilitar a sua vida, é testável e é um código limpo, quando se usa da maneira certa. E isso claro, serve para qualquer linguagem.
Mas, assim como qualquer outra linguagem, não aconselho você já começar usando jQuery (ou qualquer outro), aliás, até pode sim, mas antes dê uma lida na documentação para entender o que é o DOM e BOM, apenas leia, você não precisa ser um expert, o que não seria ruim, pois iria te ajudar muito, mas apenas o conhecimento básico já é suficiente. Conhecer e saber usar uma ferramenta (framework) é uma coisa, ENTENDER o que ele faz é outra.
Depois disso, parta para um framework como o jQuery, MooTools, ExtJS etc.
[UPDATE-13/07/2011]
Alguns me perguntaram sobre quais livros ou fontes de estudos indico para iniciar com JavaScript, então resolvi atualizar aqui, essas dicas e para não replicá-las, vou pegar as mesmas que um amigo já fez :).
Dicas do site do Christiano Milfont:
Existem alguns bons materias gratuitos que recomendo, como: Como criar um Framework javascript, Eloquent Javascript, JavaScript Garden, jQuery Fundamentals (que apesar de ser sobre jQuery, cobre muito sobre javascript em si), Essential Javascript & jQuery Design Patterns for Beginners e o Guia e a documentação de Referência da Mozilla.
Os melhores livros de Javascript:
Existem vários bons livros, inclusive já os indiquei em posts passados, veja indicações: recente e antiga.
2. Devo começar pela especificação JEEx e seguir somente ela ?
Bem, o certo seria sim, você deve começar pela especificação, mas infelizmente não é tão simples assim.
Se alguém falar isso para você, corra, corra dele e procure um profissional o quanto antes para te descontaminar, esse papinho de que é Deus no céu e especificação na terra é pura besteira. Quer exemplos ? Vamos lá.
Se você depender e seguir como um religioso fanático somente a especificação, você como profissional, estará no mínimo 5 anos ATRASADO.
Sim, para se ter uma ideia, o Ajax foi implementado no JSF, somente em 2010, ou seja, você que é bitolado, só foi poder utilizar-se de Ajax ano passado, enquanto eu e outros profissionais já o utilizavam desde 2004. Vergonha ? Também sentiria.
E não caia na conversa de que é o que o mercado pede, a não ser que você queira ser SÓ MAIS UM no mercado, depois não reclame do seu salário. Destaque-se, se sobressaia, não seguindo essa conversa fiada você já terá boas chances de ser um profissional bem qualificado e consequentemente, bem remunerado no mercado.
Mais um exemplo simples, é seguindo somente a especificação, você não vai usar o Hibernate ou Spring, pois eles não estão na especificação, a especificação “recomenda” usar o JDBC, CMP, JPA e outros Patterns. Para quem sabe o que é o Hibernate e Spring saberá o quanto será péssimo desenvolver um sistema web java sem eles, principalmente sem o Spring.
Na minha visão a especificação é somente para te dar uma ideia de como as coisas funcionam, e não como devem ser feitas, ela não é a lei, ela nem sempre é a melhor solução para o seu problema. Por isso não seja bitolado por ela.
3. Qual framework devo começar ?
Supondo que você já tem conhecimento em HTML, CSS, JavaScript, Servlets, JSP, TagLibs ou EL, Container WEB, qual framework você poderia iniciar?
Bem, qualquer frameworks Action-like. Por que?
Quanto menos abstração no lado web o framework possuir (componentes para tudo), mais você vai exercitar e aprender tudo aquilo que você estudou, sem falar na liberdade no desenvolvimento.
Atentem, que não estou aqui entrando no mérito de quem é mais produtivo, rápido, simples ou qualquer outra coisa do tipo. Meu foco é puramente e simplesmente que você aprenda desenvolvimento Web e só isso.
Framework como eu disse é apenas uma ferramenta para se desenvolver, como um martelo para um marceneiro, ou uma chave de fenda para o mecânico.
Seguindo esses passos, você pode evitar o erro (que infelizmente é comum) de querer usar a ferramenta para tudo.
Imagine que o marceneiro ame seu martelo e só queira utilizar ele, então para pregar pregos ele utiliza ele, para parafusar ele também utilize ele, para colar a maneira, ele também utilize o martelo, já imaginou ?
Pois bem, a analogia funciona da mesma forma para frameworks.
Quando você entende web, entende a necessidade do cliente, entende o problema, fica fácil escolher a ferramenta e mesmo assim você pode correr o risco de errar, imagine agora na situação de saber utilizar somente um martelo e pior, achar que ele pode fazer o trabalho de uma chave de fenda. Pense nisso.
Agora, suponha que você é realmente um iniciante, não tem noção de HTML e tudo aquilo que falei, qual framework você deve iniciar ?
NENHUM. Estude aqueles tópicos primeiro.
Aprenda a engatinhar antes de querer correr, para não cair e quebrar as pernas.
4. Porque NÃO devo começar com JSF/Seam?
Porque EU, Handerson Frota, NÃO concordo que um iniciante, que ainda NÃO tem nenhuma noção SÓLIDA de WEB já inicie com JSF?
Porque ? Vamos tentar colocar por tópicos:
a . Abstração do Servlet
Esse não é um problema, não é um defeito, pelo contrário, é até bom, deixa o teu controller desacoplado do objeto HTTPServlet. O VRaptor faz isso e claro o JSF faz isso. Mas ao contrário do VRaptor, que possui um design que facilita os testes, é muito ruim escrever testes de unidade para os managed beans.
Não estou dizendo que não é possível escrever testes de unidade, mas sim que não é tão simples assim quando o código foge do trivial. E ai pergunto, onde está a produtividade? Ah tá, vocês não usam testes?
Agora pergunto para quem nunca viu ou sabe o que é um Servlet, como você vai entender o que é um, saber como funciona se você não vê e ainda acha que não esta usando?
Você não sabe como funciona, o que é, e diz que desenvolve para Web? Acho que não.
Acreditem, existem MUITOS profissionais que começaram assim, que NÃO SABEM QUE JSF, VRAPTOR OU STRUTS, TEM SERVLETS 🙂 não é legal? Você contrataria ele? Eu não.
b. Malditos componentes
Você está iniciando, não sabe o que é Servlet, mas também não vai aprender HTML, CSS, JS, ou qualquer LINGUAGEM DA WEB, pois você vai ter que aprender COMPONENTES. Componente para input (que muitas vezes o cara não sabe o que é, e acha que isso é do JSF), componentes para tudo.
Você já viu o código gerado do seu componente? Veja e se assuste.
Com o VRaptor ou Struts por exemplo, você usa o simples e eficaz HTML e EL. Simples assim. Resolve o problema e ainda deixa teu código mais limpo.
Veja um exemplo:
Formulario JSF com 2 campos.
[sourcecode language=”java”]
<h:form id="UserEntryForm">
<h:outputText value="Enter Your Name:"/>
<h:inputText value="#{UserBean.userName}" />
<h:outputText value="Enter Your age:"/>
<h:inputText value="#{UserBean.age}" />
<h:commandButton action="welcome" value="OK" />
</h:form>
[/sourcecode]
Agora com o simples HTML e EL
[sourcecode language=”java”]
<form id="form" action="" method="GET/POST" >
Nome: <input type="text" id="nome" value="${objeto.nome}" />
Idade: <input type="text" id="idade" value="${objeto.idade}" />
<input type="submit" value="OK" />
</form>
[/sourcecode]
Agora também compare o código gerado de cada um, e tire suas conclusões.
c. Conflitos de libs
Algo que eu via com muita recorrência em projetos com JSF, eram os famosos conflitos entre conjunto de componentes. Se você queria utilizar uma funcionalidade Ajax por exemplo, teria que utilizar o Richfaces/Ajax4jsf por exemplo, mas ele não se integra bem com o MyFaces Trinidad, por exemplo. Então você fica preso e obrigado a utilizar um componente do início ao fim de um projeto (praticamente).
Isso é prejudicial ao meu ver, pois aprendemos que durante o desenvolvimento de um software, ao contrário de construir um prédio, podemos mudar, podemos alterá-lo.
Você aprende mais sobre o negócio, você aprende mais sobre o próprio software, só que você não vai mais poder mudar, pois está preso naquele conjunto de componentes que você escolheu no inicio do projeto. A não ser que você queira alterar todas as páginas geradas e seus comportamentos. Isso inclui seus controles (ManegedBean e JSP), pois o JSF nos faz o favor de -colar- o JSP com o controller.
Você, ao invés de se preocupar em aprender como funciona a web, tem que se preocupar qual plugin/lib/componente utilizar e que não vá dar conflito com outro. Ok, alguns podem dizer que esses conflitos podem acontecer também com outros “componentes”, APIs/Plugins JavaScript etc. Mas posso afirmar com certeza, que é bem mais simples resolver esses conflitos.
d. Ciclo de Vida
Você ainda não sabe o que é um Servlet, como ele funciona e terá que primeiro entender o ciclo de vida do JSF? Que é completamente diferente do ciclo de vida de um Servlet, que o managed bean utiliza por baixo?
Preciso nem comentar sobre isso.
e. View é fortemente acoplada ao controller (managed bean)
Bem, na minha humilde opinião, não acho isso legal. O teu JSP, fica totalmente dependente do controller e claro dependente de libs do JSF. Diferentemente de uma página JSP com EL, cujo o Struts, VRaptor e outros usam.
Recentemente fizemos uma migração de um sistema em JSF para VRaptor, foi simplesmente APAGAR TUDO e refazer do zero, pois não tinha como reaproveitar nem as telas, pois eram todas feitas com componentes do JSF.
Não deu para aproveitar nada do layout, pois o CSS foi alterado por causado dos benditos componentes do RichFaces, nem as funcionalidades em JavaScript, pois quem fazia isso eram os componentes do JSF.
Ao contrário por exemplo, se fosse um Struts ou um sistema feito com outro tipo de controller que usa-se JSP e EL, e fossemos migrar para VRaptor, poderíamos aproveitar muita coisa, até 100% das telas e uma boa parte do controller.
Conclusão
Eu então, NÃO RECOMENDO que qualquer futuro aspirante a desenvolvedor web, INICIE seus estudos web em cima de um JSF e/ou SOMENTE com JEEx.
A pouco tempo, fizemos algumas entrevistas com alguns profissionais web, e foi um pouco decepcionante. Muitos estavam a anos estagnados em projetos JSF ou JEE “puro”. Ou seja, só sabiam JSF e JEE e não desenvolvimento WEB, não sabiam HTML, não sabiam CSS, não sabiam o que era um Servlet, e quando sabiam não sabiam dizer para que servia e como funcionava, não sabiam o que era um PUT ou um DELETE no verbo HTTP e muitas vezes nem o que era um verbo HTTP, não tinham ideia do que era Restfulie, não sabiam JS, logo não sabiam jQuery ou qualquer outro framework JS.
Sou pago para desenvolver soluções para vários tipos de problemas, e não posso ter somente um martelo como ferramenta.
Bem, finalizo aqui, com esses argumentos que vivenciei em vários projetos e por essa longa experiência que tive e tenho em desenvolvimento web, eu aconselho antes de tentar aprender qualquer framework, entenda o básico dele, ou seja, se é desenvolvimento web na plataforma Java:
NÃO COMECE com JSF!
You ought to take part in a contest for one of the greatest blogs on the net. I will recommend this blog!
order tadalafil 5mg online cheap cialis 40mg canada male erection pills
tadalafil 10mg over the counter canadian cialis men’s ed pills
buy cheap generic ramipril brand etoricoxib 120mg purchase arcoxia
order generic ramipril generic etoricoxib 120mg where can i buy arcoxia
buy vardenafil pills for sale order tizanidine online cheap plaquenil 400mg brand
buy vardenafil 20mg online plaquenil 200mg canada plaquenil 200mg ca
There is definately a lot to learn about this topic. I like all the points you made.
Hi, Neat post. There is a problem together with your site in internet explorer, might check this? IE still is the marketplace leader and a large portion of other folks will miss your magnificent writing due to this problem.
asacol medication azelastine 10ml for sale irbesartan online order
buy generic asacol brand asacol 400mg buy irbesartan 150mg without prescription
buy levitra 20mg generic hydroxychloroquine 200mg generic plaquenil pills
cost levitra 10mg hydroxychloroquine 200mg uk plaquenil for sale online
clobetasol tablet buy cordarone 200mg amiodarone 200mg pills
buy clobetasol sale clobetasol online order buy generic cordarone
order olmesartan 10mg online cheap depakote 250mg usa purchase depakote online cheap
buy benicar 10mg pills depakote 250mg ca buy cheap generic divalproex
buy clobetasol generic buy amiodarone online order cordarone 200mg pills
clobetasol uk purchase buspar generic cheap cordarone 200mg
buy acetazolamide pill azathioprine price order imuran 50mg pills
diamox 250mg usa buy azathioprine 50mg pill cost azathioprine 50mg
buy lanoxin 250mg for sale telmisartan online molnunat 200 mg usa
It’s appropriate time to make a few plans for the longer term and it is time to be happy.
I have learn this post and if I may I wish to suggest
you some attention-grabbing issues or tips. Maybe you could write next
articles regarding this article. I desire to
read more things about it!
naproxen 250mg price buy omnicef 300 mg generic cost prevacid 30mg
naproxen 250mg canada cefdinir price lansoprazole 15mg sale
Hi there just wanted to give you a quick heads up. The text in your content seem to be running off the screen in Chrome. I’m not sure if this is a format issue or something to do with web browser compatibility but I thought I’d post to let you know. The style and design look great though! Hope you get the problem solved soon. Kudos
carvedilol over the counter coreg online order chloroquine 250mg pills
coreg 25mg generic purchase cenforce online buy cheap generic chloroquine
buy proventil 100 mcg pill buy proventil generic buy phenazopyridine 200mg online cheap
purchase albuterol sale proventil over the counter generic pyridium 200 mg
singulair online order purchase avlosulfon for sale avlosulfon 100mg sale
order singulair 5mg generic order dapsone 100mg buy avlosulfon 100 mg online
olumiant cheap order glycomet 1000mg without prescription buy lipitor 10mg generic
baricitinib 2mg pill brand baricitinib order lipitor pills
I am really pleased to glance at this web site
posts which contains lots of helpful information, thanks for providing such data.
nifedipine online buy nifedipine paypal order fexofenadine 120mg generic
oral adalat 30mg order perindopril 4mg sale buy fexofenadine 180mg online cheap
buy generic dapoxetine misoprostol 200mcg ca buy generic xenical
norvasc 10mg usa buy generic amlodipine online where to buy prilosec without a prescription
order amlodipine 5mg sale omeprazole 20mg for sale order prilosec 20mg generic
purchase priligy pill order misoprostol 200mcg without prescription orlistat 60mg tablet
https://whyride.info/ – whyride
buy diltiazem 180mg for sale buy zyloprim 300mg for sale allopurinol 300mg us
metoprolol 100mg canada atenolol over the counter oral methylprednisolone
order metoprolol purchase medrol pills buy methylprednisolone 8 mg online
Temukan pendidikan kelas atas di SISTEM BANDAR MANAGEMENT, di mana kami mengembangkan kepemimpinan dan keahlian manajemen untuk karier yang sukses.
SISTEM BANDAR MANAGEMENT
“Yes, sir.” He says as he straightens up, standing erect as his member pulses to life between his legs, and in his father’s right hand, which are firmly locked on his balls. “Yes, sir, I do.” “What happened at today’s practice today that was so different from any other day, son?” His dad asks.