Exception no cadastro de Strings - Vraptor/Hibernate

1 resposta
H

estou usando Vraptor+Hibernate para fazer um cadastro simples, quando eu utilizo somente os campos da tabela 'user' ele funciona, mas quando eu utilizo as outras tabelas relacionadas ele me retorna um exception e não entendi como resolver por mais que pareça simples:

java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Integer

Segue o exception completo abaixo:

java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Integer
br.com.caelum.vraptor.http.ognl.ListAccessor.setProperty(ListAccessor.java:68)
ognl.OgnlRuntime.setProperty(OgnlRuntime.java:2225)
ognl.ASTProperty.setValueBody(ASTProperty.java:127)
ognl.SimpleNode.evaluateSetValueBody(SimpleNode.java:220)
ognl.SimpleNode.setValue(SimpleNode.java:279)
ognl.ASTChain.setValueBody(ASTChain.java:227)
ognl.SimpleNode.evaluateSetValueBody(SimpleNode.java:220)
ognl.SimpleNode.setValue(SimpleNode.java:279)
ognl.Ognl.setValue(Ognl.java:737)
ognl.Ognl.setValue(Ognl.java:783)
br.com.caelum.vraptor.http.ognl.OgnlFacade.setValue(OgnlFacade.java:100)
br.com.caelum.vraptor.http.ognl.OgnlParametersProvider.setProperty(OgnlParametersProvider.java:162)
br.com.caelum.vraptor.http.ognl.OgnlParametersProvider.createParameter(OgnlParametersProvider.java:134)
br.com.caelum.vraptor.http.ognl.OgnlParametersProvider.getParametersFor(OgnlParametersProvider.java:86)
br.com.caelum.vraptor.interceptor.ParametersInstantiatorInterceptor.getParametersFor(ParametersInstantiatorInterceptor.java:132)
br.com.caelum.vraptor.interceptor.ParametersInstantiatorInterceptor.intercept(ParametersInstantiatorInterceptor.java:86)
br.com.caelum.vraptor.core.LazyInterceptorHandler.execute(LazyInterceptorHandler.java:59)
br.com.caelum.vraptor.core.DefaultInterceptorStack.next(DefaultInterceptorStack.java:54)
br.com.caelum.vraptor.interceptor.ResourceLookupInterceptor.intercept(ResourceLookupInterceptor.java:69)
br.com.caelum.vraptor.core.ToInstantiateInterceptorHandler.execute(ToInstantiateInterceptorHandler.java:54)
br.com.caelum.vraptor.core.DefaultInterceptorStack.next(DefaultInterceptorStack.java:54)
br.com.caelum.vraptor.core.ToInstantiateInterceptorHandler.execute(ToInstantiateInterceptorHandler.java:56)
br.com.caelum.vraptor.core.DefaultInterceptorStack.next(DefaultInterceptorStack.java:54)
br.com.caelum.vraptor.core.EnhancedRequestExecution.execute(EnhancedRequestExecution.java:44)
br.com.caelum.vraptor.VRaptor$1.insideRequest(VRaptor.java:91)
br.com.caelum.vraptor.ioc.spring.SpringProvider.provideForRequest(SpringProvider.java:58)
br.com.caelum.vraptor.VRaptor.doFilter(VRaptor.java:88)

O relacionamento das tabelas é o seguinte:
User possui uma Collection de telefones
User possui uma Formação academica
Formaçao academica possui duas Collections, Curso e Idioma

Segue algumas classes abaixo para facilitar o entendimento.

User.java
package model;

import java.util.Collection;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import javax.persistence.Table;

import org.hibernate.validator.constraints.Email;

@Entity(name = "user")
@Table(name = "user")
public class User {

    private Long id;    
    private String nome;
    private String numeroRg;
    private String numeroCpf;
    private String cidade;
    private String estado;
    private String email;
    private Collection<Telefones> telefonesList;
    private FormacaoAcademica formacaoAcademica;

    @Id
    @GeneratedValue
    @Column(name="id", nullable=false)
    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    @OneToMany(mappedBy="user", cascade=CascadeType.ALL, fetch=FetchType.LAZY)
    public Collection<Telefones> getTelefones() {
        return telefonesList;
    }

    public void setTelefones(Collection<Telefones> telefonesList) {
        this.telefonesList=telefonesList;
    }

    @Column(name="numeroRg", nullable=false)
    public String getNumeroRg() {
        return numeroRg;
    }

    public void setNumeroRg(String numeroRg) {
        this.numeroRg = numeroRg;
    }

    @Column(name="numeroCpf", nullable=false)
    public String getNumeroCpf() {
        return numeroCpf;
    }

    public void setNumeroCpf(String numeroCpf) {
        this.numeroCpf = numeroCpf;
    }

    @Column(name="cidade", nullable=false)
    public String getCidade() {
        return cidade;
    }

    public void setCidade(String cidade) {
        this.cidade = cidade;
    }

    @Column(name="estado", nullable=false)
    public String getEstado() {
        return estado;
    }

    public void setEstado(String estado) {
        this.estado = estado;
    }

    @Column(name="email", nullable=false)
    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }


    @Column(name="nome", nullable=false)
    public String getNome() {
        return nome;
    }

    public void setNome(String nome) {
        this.nome = nome;
    }


    @ManyToOne
    @JoinColumn(name="fk_formacaoAcademica", nullable=false)
    public FormacaoAcademica getFormacaoAcademica() {
        return formacaoAcademica;
    }

    public void setFormacaoAcademica(FormacaoAcademica formacaoAcademica) {
        this.formacaoAcademica = formacaoAcademica;
    }
}
Telefones.java
package model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

@Entity(name = "user_telefones")
@Table(name = "user_telefones")
public class Telefones {

    private Long id;
    private User user;
    private String tipo;
    private String numero;
    private String ddd;

    @Id
    @GeneratedValue
    @Column(name="id", nullable=false)
    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }

    @Column(name="tipo", nullable=false)
    public String getTipo() {
        return tipo;
    }
    public void setTipo(String tipo) {
        this.tipo = tipo;
    }
    @Column(name="numeroTelefone", nullable=false)
    public String getNumero() {
        return numero;
    }
    public void setNumero(String numero) {
        this.numero = numero;
    }

    @Column(name="ddd", nullable=false)
    public String getDdd() {
        return ddd;
    }
    public void setDdd(String ddd) {
        this.ddd = ddd;
    }

    @ManyToOne
    @JoinColumn(name="fk_user", nullable=false)
    public User getUser() {
        return user;
    }
    public void setUser(User user) {
        this.user = user;
    }
}
UserDao.java
package dao;

import generic.Dao;

import java.util.List;

import model.User;

import org.hibernate.Session;
import org.hibernate.Transaction;

import br.com.caelum.vraptor.ioc.Component;

@Component
public class UserDao extends Dao<User>{

    public UserDao(Session session){
        super(session, User.class);
    }

    public void salvar (User user){
        Transaction transaction = this.session.beginTransaction();  
        this.session.save(user);  
        transaction.commit();  
    }

    public void remove(Long id){
        Transaction transaction = this.session.beginTransaction(); 
        this.session.delete((User)this.session.load(User.class, id));
        this.session.flush();
        transaction.commit();  
    }

    public User load(Long id){
        return(User)this.session.load(User.class, id);
    }

    public void update(User user){
        Transaction transaction = this.session.beginTransaction(); 
        this.session.update(user);
        this.session.flush();
        transaction.commit(); 
    }

    public List<User> listaTodos(){
        return session.createCriteria(User.class).list();
    }
}
UserController.java
package controller;

import java.util.List;

import model.User;

import org.hibernate.Session;

import br.com.caelum.vraptor.Get;
import br.com.caelum.vraptor.Path;
import br.com.caelum.vraptor.Post;
import br.com.caelum.vraptor.Put;
import br.com.caelum.vraptor.Resource;
import br.com.caelum.vraptor.Result;
import br.com.caelum.vraptor.Validator;
import br.com.caelum.vraptor.validator.ValidationMessage;
import dao.UserDao;

@Resource
public class UsersController {

    private final UserDao userDao;
    private final Session session;
    private final Result result;
    private final Validator validator;

    public UsersController(UserDao userDao, Result result, Session session, Validator validator){
        this.userDao=userDao;
        this.session=session;
        this.result=result;
        this.validator=validator;
    }

    @Post
    @Path("/users")
    public void add(User user){
        userDao.salvar(user);
        result.include("mensagem", "Usuário adicionado com sucesso!");
        result.redirectTo(UsersController.class).list();
    }

    @Get
    @Path("/users/{id}")
    public User view(Long id){
        return userDao.load(id);
    }

    @Path("/users/delete/{id}")
    public void delete(Long id){
        userDao.remove(id);
        result.include("mensagem", "Usuário excluído com sucesso!");
        result.redirectTo(UsersController.class).list();
    }

    @Put
    @Path("/users")
    public void edit(User user){
        userDao.update(user);
        result.include("mensagem", "Usuário alterado com sucesso!");
        result.redirectTo(UsersController.class).list();
    }

    @Path("/")
    public List<User> list(){
        return userDao.listaTodos();
    }

}

1 Resposta

Lucas_Cavalcanti

Quais são os parâmetros que vc tava passando na requisição?

Criado 25 de março de 2015
Ultima resposta 17 de abr. de 2015
Respostas 1
Participantes 2