8

Jersey JAX-RSの一部であるJAXBを使用しています。出力タイプに JSON を要求すると、すべての属性名が次のようにアスタリスクで始まります。

このオブジェクト。

package com.ups.crd.data.objects;

import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlType;

@XmlType
public class ResponseDetails {
    @XmlAttribute public String ReturnCode = "";
    @XmlAttribute public String StatusMessage = "";
    @XmlAttribute public String TransactionDate ="";
}

となり、

   {"ResponseDetails":{"@transactionDate":"07-12-2010",  
             "@statusMessage":"Successful","@returnCode":"0"}

では、なぜ名前に @ が含まれているのでしょうか。

4

3 に答える 3

9

@XmlAttribute でマップされたすべてのプロパティには、JSON で「@」がプレフィックスとして付けられます。削除したい場合は、プロパティに @XmlElement の注釈を付けるだけです。

おそらく、これは潜在的な名前の競合を避けるためです:

@XmlAttribute(name="foo") public String prop1;  // maps to @foo in JSON
@XmlElement(name="foo") public String prop2;  // maps to foo in JSON
于 2010-07-15T20:40:31.957 に答える
1

XMLとJSONの両方にマーシャリングしていて、XMLバージョンの属性としてそれを必要としない場合は、@XmlElementを使用することを提案するのが最善の方法です。

ただし、XMLバージョンで(要素ではなく)属性である必要がある場合は、かなり簡単な代替手段があります。

JSONConfiguration「@」の挿入をオフにするを簡単に設定できます。

次のようになります。

@Provider
public class JAXBContextResolver implements ContextResolver<JAXBContext> {
private JAXBContext context;

public JAXBContextResolver() throws Exception {
    this.context=   new JSONJAXBContext(
        JSONConfiguration
            .mapped()
            .attributeAsElement("StatusMessage",...)
            .build(), 
            ResponseDetails.class); 
}

@Override
public JAXBContext getContext(Class<?> objectType) {
    return context;
}
}

ここに他のいくつかの代替文書もあります:

http://jersey.java.net/nonav/documentation/latest/json.html

于 2013-03-12T17:33:45.283 に答える
0

デフォルトで次のように設定JSON_ATTRIBUTE_PREFIXするJAXBContext必要があります。"""@"

properties.put(JAXBContextProperties.JSON_ATTRIBUTE_PREFIX, ""); 
于 2016-12-22T14:03:56.780 に答える