Java EE - Aproveite toda a plataforma para construir aplicações

Olá, Gracyane,

Baixei o devstudio 8.1.0 e tentei rodar o projeto a partir dessa IDE. Os erros diminuíram bastante, mas ainda estou recebendo um erro ao fazer o deploy:

11:18:37,374 ERROR [org.jboss.as.controller.management-operation] (Controller Boot Thread) JBAS014613: Operation (“deploy”) failed - address: ([(“deployment” => “casadocodigo.jar”)]) - failure description: {“JBAS014771: Services with missing/unavailable dependencies” => [“jboss.persistenceunit.“casadocodigo.jar#casadocodigo-dev”.FIRST_PHASE is missing [jboss.naming.context.java.”\n\t\t\t\tjava:jboss".datasources.“casadocodigoDS\n\t\t\t”]"]}

O erro parece fazer referências às configurações contidas no persistence.xml

Se você puder passar o persistence,xml que está usando eu agradeço antecipadamente

Olá. É o mesmo erro que você estava tendo.
O print do persistente.xml que coloquei logo acima é do meu projeto.

Você tentou apagar o arquivo de deploy que o wildfly faz conforme lhe expliquei acima em uma resposta? Ele fica em
\wildfly-8.2.0.Final\standalone\deployments\

Dentro deste diretório tem o arquivo com o nome do seu projeto, pode apagar tudo.
Alguns problemas que eu estava tendo só se resolveu quando apaguei manualmente o arquivo de deploy.

Faz isso é testa de novo.

Não tem jeito Gracyane,

Tentei de tudo que me sugeriu, mas continuo não conseguindo fazer o deploy da aplicação. Ocorre o seguinte erro:

18:39:24,040 ERROR [org.jboss.as.controller.management-operation] (Controller Boot Thread) JBAS014613: Operation (“deploy”) failed - address: ([(“deployment” => “casadocodigo.jar”)]) - failure description: {“JBAS014771: Services with missing/unavailable dependencies” => [“jboss.persistenceunit.“casadocodigo.jar#casadocodigo-dev”.FIRST_PHASE is missing [jboss.naming.context.java.”\n\t\t\t\tjava:jboss".datasources.“casadocodigoDS\n\t\t\t”]"]}

Ele diz que há uma dependência na persistenceunit _FIRST_PHASE está faltando, fazendo referência à tag java:jboss/datasources/casadocodigoDS

Eu configurei o standalone-full.xml da maneira que o livro sugere, mas não consigo rodar o projeto e avançar na leitura do livro.

Uma pena!

Segue como está parte do arquivo standalone-full:

Persistence.xml
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>

	<persistence-unit name="casadocodigo-dev" transaction-type="JTA">
	
		<description>Dev persistence unit</description>
		<provider>org.hibernate.ejb.HibernatePersistence</provider>
		<jta-data-source>java:jboss/datasources/casadocodigoDS</jta-data-source>
	
		<properties>
			<property name="hibernate.hbm2ddl.auto" value="update" />
			<property name="hibernate.show_sql" value="true" />
			<property name="hibernate.format_sql" value="true" />
			<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" />
		</properties>
		
	</persistence-unit>
</persistence>

Algumas sugestões:
Retire o projeto do Wildfly. Após isso dê um clean no Wildfly. Faça o mesmo procedimento de pagar os arquivo de deploy.

Você pode tentar também criar um novo server Wildfly. Apaga esse aí que você tem na IDE e cria outro.

Continue tentando até conseguir executar seu projeto e prosseguir com a leitura do livro.
Não desista.

Olá, Gracyane.

Consegui gravar o produto (livro) com a seguinte alteração no persistence.xml e no standalone-full.xml

Substituí

java:jboss/datasources/casadocodigoDS

por

java:/datasources/casadocodigoDS

Fica aí a dica se surgir alguém com problema parecido.

No mais, agradeço a sua ajuda.

João.

Fico feliz que tenha conseguido.
É estranho que só funcionou com essa alteração porque seu projeto no meu ambiente funcionou normalmente.
Bons estudos.

Olá,

Passei a ter problemas no cadastro de livros (webapp.admin.livros.form.xhtml), quando inseri a relação de muitos para muitos com os autores. O sistema tentar salvar, mas ocorre um erro de conversão de tipos. A causa chega ser dantesca, pois a mensagem de erro que recebo é totalmente nonsense:

Can not set java.lang.Integer field br.com.casadocodigo.loja.models.Author.id to java.lang.Integer

Eles diz que não posso “setar” um Integer para um Integer.

Eu copiei as configurações do form.xhtml do código do sistema completo disponibilizado pela Casadocódigo.

Esse é o codigo de vocês:

		<h:outputLabel>Autores</h:outputLabel>
		<h:selectManyListbox value="#{adminBooksBean.product.authors}"
			converter="entityConverter">
			<f:selectItems value="#{authorsList.get()}" var="author"
				itemLabel="#{author.name}" itemValue="#{author}" />
		</h:selectManyListbox>

Tentei executar dessa maneira, mas o sistema não reconhece a expressão “entityConverter”.

Então alterei para o seguinte código:

		<h:outputLabel>Autores</h:outputLabel>
                    <h:selectManyListbox value="#{adminBooksBean.product.authors}"
			converter="javax.faces.Integer">
                         <f:selectItems value="#{adminBooksBean.authors}" var="author"
                           itemLabel="#{author.name}" itemValue="#{author.id}"/>
		</h:selectManyListbox>

Quando eu não havia colocado a tag converter o erro pelo menos tinha lógica: dizia que não poderia converter um Integer para um String

Espero que possam me ajudar porque é um erro difícil de rastrear, pois ocorre na camada do servidor de aplicação que fica oculta para mim. Não é um erro no meu código, mas no container.

Grato,

João

Faltou você adicionar a classe EntityConverter que tem na explicação da página 102 a 104 do livro.

@FacesConverter("entityConverter")
public class EntityConverter implements Converter {

Funcionou,

Grato, Gracyane.

Até o próximo erro rs.

Olá, Gracyane,

Cheguei na parte do livro onde o autor descreve como direcionar mensagens aos usuários. Eu preferi usar a classe MessagesHelper do código fonte da Casa do Código. Estou tendo problemas no @Inject na propriedade FacesContext facesContext com a seguinte descrição de erro:

“{
“WFLYCTL0080: Failed services” => {“jboss.deployment.unit.\“casadocodigo.war\”.WeldStartService” => “org.jboss.msc.service.StartException in service jboss.deployment.unit.\“casadocodigo.war\”.WeldStartService: Failed to start service
Caused by: org.jboss.weld.exceptions.DeploymentException: WELD-001408: Unsatisfied dependencies for type FacesContext with qualifiers @Default
at injection point [BackedAnnotatedField] @Inject private br.com.casadocodigo.loja.infra.MessagesHelper.facesContext
at br.com.casadocodigo.loja.infra.MessagesHelper.facesContext(MessagesHelper.java:0)
”},
“WFLYCTL0412: Required services that are not installed:” => [“jboss.deployment.unit.\“casadocodigo.war\”.WeldStartService”],
“WFLYCTL0180: Services with missing/unavailable dependencies” => undefined
}”

Na IDE do Netbeans há uma advertência justamente no ponto de injeção “No enabled elegible for injection beans are found”

Grato pela atenção,

João Carlos Vidoto

Olá João,
Na página 77 e 78 do livro, o autor menciona esse erro que você colocou acima. O que acontece é que o FaceContext não é gerenciado pelo container de injeção do CDI, desta forma você tem que criar uma classe Producer para ensinar ao CDI como ele deve instanciar uma classe do tipo FacesContext. Na página 78 tem o código de exemplo.

package br.com.casadocodigo.loja.infra;
import javax.enterprise.context.ApplicationScoped;
import javax.enterprise.context.RequestScoped;
import javax.enterprise.inject.Produces;
import javax.faces.context.FacesContext;

@ApplicationScoped
public class FacesContextProducer {

  @Produces
  @RequestScoped
  public FacesContext get(){
       return FacesContext.getCurrentInstance();
  }
}

Funcionou,

Muito obrigado Gracyane, qualquer problema eu entro em contato. Desde já agradeço antecipadamente a sua ajuda.

João

Olá, Gracyane,

O problema que estou tendo agora é com a conversão do tipo Date para o tipo Calendar. Eu copiei a classe CalendarConverter do código de vocês, mas mesmo assim ocorre o seguinte erro com problemas de conversão:

17:26:00,628 ERROR [io.undertow.request] (default task-2) UT005023: Exception handling request to /casadocodigo/admin/livros/form.xhtml;jsessionid=s1lQQysAFtc0kMJyJpYiWUZnOf7qj1Ytwl6xBxtd.desktop-cd2vrou: javax.servlet.ServletException: java.lang.IllegalArgumentException: Cannot convert 11/05/76 00:00 of type class java.util.Date to class java.util.Calendar

Caused by: javax.faces.component.UpdateModelException: java.lang.IllegalArgumentException: Cannot convert 11/05/76 00:00 of type class java.util.Date to class java.util.Calendar

A declaração da parte do formulário (form.xhtml) relativa à data está assim:

**<h:outputLabel>Data de lançamento</h:outputLabel>
<h:inputText value="#{adminBooksBean.product.releaseDate}" label=“Data de Lançamento” pt:type=“date”>
<f:convertDateTime pattern=“dd/MM/yyyy”/>
</h:inputText>
**
Eu coloquei a tag f:convertDateTime, porque, do contrário, ele não aceitava como data qualquer formato de data que eu informava 11/10/2017, 2017/10/11, etc. Ele também está ignorando a anotação @future e aceitando datas passadas

Grato pela atenção,

João Carlos Vidoto

O <h:inputText> do seu código tem um atributo pt:type=“date”. Depois que o autor colocou o converter ele retirou do <h:inputText> o type.

Deixa essa parte que nem está no livro:

<h:outputLabel>Data de lançamento</h:outputLabel>
<h:inputText
value="#{adminBooksBean.product.releaseDate}">
<f:convertDateTime pattern="yyyy-MM-dd"/>
</h:inputText>

A classe public class CalendarHtml5Converter implements Converter utiliza o pattern "yyyy-MM-dd".
Veja se dá certo com o exemplo do livro.

Não funcionou, Gracyane,

Defini o código da forma que você instruiu, mas continua dando o erro de conversão.

no @facesconverter substituí o forClass=Calentar.class pela string “calendarConverter”, depois para “calendarHtml5Converter” e defini no inputText a variável converter=“texto facesconverter”, semelhante ao “entityConverter”, mas não funcionou. Continuou dando erro de conversão.

Se defino a variável data como Date nas classes em que ela aparece, o código funciona. Pelo que sei o tipo Date está deprecated, mas é a única maneira para eu conseguir avançar…

Olá, Gracyane

Consegui passar essa etapa, mas não conforme está no livro. No código fonte de vocês, o inputText da data está apenas com o pt:type=“date”, sem nenhuma variável converter. Também no código fonte da casa do código, tem apenas uma classe converter chamada CalendarioConverter e não a classe CalendarHtml5Converter que está no livro. Na classe CalendarConverter eu alterei a anotação @facesconveter de (forClass=Calendar.class) para a string “calendarConverter”. Por último coloque na tag <h:inputText> a variável converter=“calendarConverter”. Funcionou, mas não conforme as instruções do livro.

Vou seguir os próximos passos do livro confiante em ter menos problemas e te dar menos trabalho.

Grato,

João

Olá João,

Eu li essa parte do livro melhor, segue algumas observações.

Quando se coloca o pt:type:"date", devemos criar um converter que no caso o autor criou o CalendarHtml5Converter. Neste caso não necessita colocar o atributo "converter=".

Perceba que quando o autor cria o CalendarHtml5Converter ele retira do código a expressão:

<f:convertDateTime pattern="yyyy-MM-dd"/>

Quando você submete o formulário o framework identifica esse Converter e utiliza-o nos campos que necessitam dele.

No código do livro tem-se um pattern yyyy-MM-dd. Neste caso devemos digitar no formulário por exemplo: “2017-08-01”, se você estiver utilizando o Navegador Mozilla. Se você digitar uma data anterior a de hoje ele faz essa validação e não deixa você salvar. Quando se usa o Navegador Chrome ele mostra o componente de data do html5 de forma mais estilizada, permitindo que agente selecione uma data no padrão dd/MM/yyyy.

Segue como ficou meu código:

Navegador Mozilla


Olá, Gracyane,

Como a forma que fiz de certo, vou manter dessa forma para seguir nos próximos passos do livro.

Uma dúvida: como sei se estou utilizando Html5, ou como faço para usá-lo.

Obrigado pela atenção,

João

Para saber se está utilizando html5 só estudando mesmo sobre o assunto. Tem muitos livros sobre html5 que abordam as “novas” marcações.

Ola pessoas, estava tentando publicar o projeto e nos log do servidor me apresentava o seguinte erro:
[org.jboss.msc.service.fail] (MSC service thread 1-4) MSC000001: Failed to start service jboss.deployment.unit.“casadocodigo.war”.FIRST_MODULE_USE: org.jboss.msc.service.StartException in service jboss.deployment.unit.“casadocodigo.war”.FIRST_MODULE_USE: JBAS018733: Failed to process phase FIRST_MODULE_USE of deployment “casadocodigo.war” (Erro ja foi citado em outro comentário).
Como segui a explicação do livro para configurar o projeto minha persistence unit estava com o caminho da jta o seguinte: java:jboss/datasources/casadocodigoDS
Consegui corrigir alterando-a para: jboss/datasources/casadocodigoDS