1

私はこの例外を取得しています:

Field mapping error -->
MapId: null
Type: null
Source parent class: com.ParentObject
Source field name: field1
Source field type: class com.OnOff1BitEnum
Source field value: OFF
Dest parent class: com.SubParent
Dest field name: subParent.field2
Dest field type: java.lang.Boolean java.lang.NullPointerException
at org.dozer.util.ReflectionUtils.invoke(ReflectionUtils.java:270)
at org.dozer.propertydescriptor.GetterSetterPropertyDescriptor.getDeepSrcFieldValue(GetterSetterPropertyDescriptor.java:116)
at org.dozer.propertydescriptor.GetterSetterPropertyDescriptor.getPropertyValue(GetterSetterPropertyDescriptor.java:69)
at org.dozer.fieldmap.FieldMap.getDestValue(FieldMap.java:141)

これはマッピング フィールドです。

<mapping>
    <class-a>com.ParentObject</class-a>
    <class-b>com.SubParent</class-b>

    <field custom-converter="com.OnOffEnumToBooleanConverter">
        <a>field1</a> 
        <b get-method="isField2">subParent.field2</b> 
    </field>
</mapping>

私が使用しているドーザーのバージョンは 5.4.0 です

更新: この投稿にコンバーター コードを追加しました。ここにブレークポイントを置くと、これに到達していません

public class OnOffEnumToBooleanConverter implements org.dozer.CustomConverter {
/**
 * {@inheritDoc}
 */
@Override
public Object convert(Object dest, Object src, Class<?> destClass, Class<?> srcClass) {
    if (src == null) {
        return null;
    }
            if (src instanceof com.OnOff1BitEnum) {
        boolean canonicalObject;
        if ((com.OnOff1BitEnum) src == com.OnOff1BitEnum.ON) {
            canonicalObject = true;
        } else if ((com.OnOff1BitEnum) src == com.OnOff1BitEnum.OFF) {
            canonicalObject = false;
        } else { // Unreachable Code To Test
            throw new MappingException("Converter " + this.getClass().getCanonicalName() + " used incorrectly.  Arguments passed in were: "
                    + dest + " and " + src);
        }
        return canonicalObject;
    } 
}
4

1 に答える 1

1

おそらく、「set configuration」がないために発生する可能性があります。明示的に指定してみて、それが解決するか、別のエラーが発生するかを確認してください。

<field custom-converter="com.OnOffEnumToBooleanConverter">
        <a>field1</a> 
        <b get-method="isField2" set-method="field2">subParent.field2</b> 
</field>

アップデート:

Javaコードを読み取れるように適切にフォーマットする必要がありました...これは、ブール値の「if and else」の問題です...3番目の条件はありません...注意深く見てください:

if (src instanceof com.OnOff1BitEnum)
{
  boolean canonicalObject;
  if ((com.OnOff1BitEnum) src == com.OnOff1BitEnum.ON)
  {
    canonicalObject = true;
  }
  else
  {
    if ((com.OnOff1BitEnum) src == com.OnOff1BitEnum.OFF)
    {
      canonicalObject = false;
    }
    else
    { // Unreachable Code To Test
      throw new MappingException("Converter " + this.getClass().getCanonicalName()
          + " used incorrectly.  Arguments passed in were: " + dest + " and " + src);
    }
  }
  return canonicalObject;
}

これは、元のコードに括弧がない「if else コンストラクト」の弊害です。また、「変換」メソッドはオブジェクトを返します...したがって、「 」はプリミティブ型ではなくboolean canonicalObjectブール型のcanonicalObject」でなければなりません。

次のようにする必要があります。

@Override
public Object convert(Object dest, Object src, Class<?> destClass, Class<?> srcClass) 
{    
    if (src instanceof com.OnOff1BitEnum)
    {
      if ((com.OnOff1BitEnum) src == com.OnOff1BitEnum.ON)
      {
        return Boolean.TRUE;
      }
      else
      {
        return Boolean.FALSE;
      }
    }
    return null;
}
于 2013-05-16T18:03:16.570 に答える