2014-02-11 3 views
0

Я использую Dozer в проекте, и он работает нормально, но через некоторое время одно и то же сопоставление, которое я выполнил, начинает давать мне следующее исключение :Невозможно определить метод записи для поля: 'id' в классе в dozer

15:13:29,928 ERROR MappingProcessor:295 - Field mapping error --> 
MapId: null 
Type: null 
Source parent class: org.persistencias.PP 
Source field name: id 
Source field type: class java.lang.Long 
Source field value: 1 
Dest parent class: org.dtos.PPDTO 
Dest field name: id 
Dest field type: java.lang.Long 
org.dozer.MappingException: java.lang.NoSuchMethodException: Unable to determine write method for Field: 'id' in Class: class org.dtos.PPDTO 
at org.dozer.util.MappingUtils.throwMappingException(MappingUtils.java:82) 
at org.dozer.propertydescriptor.GetterSetterPropertyDescriptor.invokeWriteMethod(GetterSetterPropertyDescriptor.java:280) 
at org.dozer.propertydescriptor.GetterSetterPropertyDescriptor.setPropertyValue(GetterSetterPropertyDescriptor.java:102) 
at org.dozer.fieldmap.FieldMap.writeDestValue(FieldMap.java:94) 
at org.dozer.MappingProcessor.writeDestinationValue(MappingProcessor.java:895) 
at org.dozer.MappingProcessor.mapFromFieldMap(MappingProcessor.java:349) 
at org.dozer.MappingProcessor.mapField(MappingProcessor.java:288) 
at org.dozer.MappingProcessor.map(MappingProcessor.java:248) 
at org.dozer.MappingProcessor.map(MappingProcessor.java:197) 
at org.dozer.MappingProcessor.map(MappingProcessor.java:187) 
at org.dozer.MappingProcessor.map(MappingProcessor.java:124) 
at org.dozer.MappingProcessor.map(MappingProcessor.java:119) 
at org.dozer.DozerBeanMapper.map(DozerBeanMapper.java:120) 
at org.server.ServiciosP.getTodasPP(ServiciosP.java:86) 
at org.server.ServicioImpl.getTodasPP(ServicioImpl.java:7668) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:606) 
at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:561) 
at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:208) 
at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:248) 
at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487) 
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362) 
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) 
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181) 
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729) 
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405) 
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49) 
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
at org.mortbay.jetty.Server.handle(Server.java:324) 
at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505) 
at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843) 
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647) 
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211) 
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380) 
at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395) 
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488) 
    Caused by: java.lang.NoSuchMethodException: Unable to determine write method for Field: 'id' in Class: class org.dtos.PPDTO 
at org.dozer.propertydescriptor.JavaBeanPropertyDescriptor.getWriteMethod(JavaBeanPropertyDescriptor.java:47) 
at org.dozer.propertydescriptor.GetterSetterPropertyDescriptor.invokeWriteMethod(GetterSetterPropertyDescriptor.java:278) 
... 40 more 
org.dozer.MappingException: java.lang.NoSuchMethodException: Unable to determine write method for Field: 'id' in Class: class org.dtos.PPDTO 

Но у меня есть метод установки идентификатора на моем POJO и на моем DTO.

POJO:

// Property accessors 
@GenericGenerator(name = "generator", strategy = "increment") 
@Id 
@GeneratedValue(generator = "generator") 
@Column(name = "id", unique = true, nullable = false) 
public Long getId() { 
    return this.id; 
} 

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

DTO:

public Long getId() { 
    return this.id; 
} 

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

Наконец мое отображение кода для этого:

<mapping> 
    <class-a>org.persistencias.PP</class-a> 
    <class-b>org.dtos.PPDTO</class-b> 
</mapping> 

Кто-нибудь здесь знает, как это исправить или пункт о проблеме корень ??

Я использую бульдозерный 5.4.0 (Лас-стабильная версия)

ответ

0

Не уверен, что именно поэтому, все выглядит правильно, но исключение:

java.lang.NoSuchMethodException: Unable to determine write method for Field: 'id' in Class: class org.dtos.PPDTO 

говорит, что он не может найти метод, используемый для записи значения ID в класс PPDTO.

Это может быть потому, что от источника, это ваш тип:

класс java.lang.Long

от назначения его просто

java.lang.Long

Не почему это происходит, но это может быть фактором. Вы пытались сменить их на примитивный?

1

Как указано в этом вопросе на GitHub, кажется, комбинация ошибок в различных библиотеках: https://github.com/DozerMapper/dozer/issues/118

Есть ошибки в JDK, BeanUtils и бульдозер, которые в комбинации приводят к этому странному поведению.

У меня была та же проблема, когда я определил геттер в интерфейсе и реализовал сеттер в самом классе.

MyInterface.java

public interface MyInterface { 
    String getMe(); 
} 

MyClass.java

public class MyClass implements MyInterface { 

    private String me; 

    @Override 
    public String getMe() { 
     return me; 
    } 

    public void setMe(String me) { 
     this.me = me; 
    } 
} 

Чтобы это исправить, необходимо определить как и присваивателя в одном классе или интерфейсе. Также это не должно происходить при использовании JDK 8.

0

Я бы проверил serialVersionUID для исходного и целевого классов. Они должны иметь такую ​​же версию/значение, которые должны быть правильно сериализованы и десериализованы бульдозером.

 Смежные вопросы

  • Нет связанных вопросов^_^