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:
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
[code]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;
}
}[/code]
Telefones.java
[code]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;
}
}[/code]
UserDao.java
[code]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{
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();
}
}[/code]
UserController.java
[code]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();
}
}[/code]