- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我使用 jax-rs 和 jersey 创建了一个 REST API。我想从我的 REST API 中的外部库返回一个 JSON 格式的对象。但是这个对象没有没有默认构造函数,这会导致以下异常:
Caused by: org.codehaus.jackson.map.JsonMappingException: No suitable constructor found for type [simple type, class ....EncryptionToken]: can not instantiate from JSON object (need to add/enable type information?)
通过 REST API 返回此对象的最佳方式是什么?
这是我的 REST API 实现:
@GET
@Produces(MediaType.APPLICATION_JSON)
public javax.ws.rs.core.Response get( //
@QueryParam("etkIdentifierType") String etkIdentifierType, //
@QueryParam("etkIdentifierValue") String etkIdentifierValue, //
@QueryParam("applicationId") String applicationId) {
LOG.info("GET Request: Lookup encryption token for etkIdentifierType [" + etkIdentifierType + "], etkIdentifierValue [" + etkIdentifierValue + "] and applicationId [" + applicationId + "]");
final EncryptionToken token = etkService.getETK(etkIdentifierType, etkIdentifierValue, applicationId);
return Response.ok(token).build();
}
加密类来 self 无法修改的外部库。我首先尝试用相同的变量构造一个自己的对象并返回它,但并不是所有的 getter 方法都是公共(public)的。
这是 EncryptionToken 类:
package ...;
public class EncryptionToken {
private java.security.cert.X509Certificate encrCert;
private byte[] encoded;
private java.security.cert.X509Certificate authCert;
private java.security.cert.X509Certificate etkRaCert;
private java.util.List<java.security.cert.X509Certificate> caCertChain;
EncryptionToken(byte[] encoded, java.security.cert.X509Certificate encrCert, java.security.cert.X509Certificate authCert, java.util.List<java.security.cert.X509Certificate> caCertChain, java.security.cert.X509Certificate etkRaCert) { /* compiled code */ }
public final byte[] getEncoded() { /* compiled code */ }
public final byte[] getBase64Encoded() { /* compiled code */ }
public final java.security.cert.X509Certificate getCertificate() { /* compiled code */ }
public final java.security.cert.X509Certificate getAuthenticationCertificate() { /* compiled code */ }
java.util.List<java.security.cert.X509Certificate> getCaCertChain() { /* compiled code */ }
java.security.cert.X509Certificate getEtkRaCert() { /* compiled code */ }
}
编辑:我认为对于我的情况我需要一个反序列化器。代码在以下行失败:
final EncryptionToken encryptionToken = response.getEntity(EncryptionToken.class);
但是因为我不能实例化一个 EncryptionToken(没有默认构造函数并且可用的构造函数不是公共(public)的)我不知道如何解决这个问题......
最佳答案
您可以实现自定义 JsonSerializer
对象并将其注册到 Jackson 上下文中。
public class EncryptionTokenSerializer extends JsonSerializer<EncryptionToken> {
@Override
public void serialize(EncryptionToken value, JsonGenerator jgen, SerializerProvider provider)
throws IOException {
jgen.writeStartObject();
jgen.writeBinaryField("encoded", value.getEncoded());
jgen.writeBinaryField("base64Encoded", value.getBase64Encoded());
jgen.writeEndObject();
}
}
如果您想知道如何在上下文中注册序列化程序,请查看 this answer
关于java - Jersey Rest - JsonMappingException : No suitable constructor found for type [simple type, 类],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28582068/
我已阅读 Jersey documentation ,并表示 Jersey 在读取实体后自动关闭连接(例如 response.readEntity(SomeObject.class)) 但是当抛出异常
Jersey vs Jersey (Standalone) vs Jersey with Grizzly vs Jersey with Tomcat - for REST services 有什么区别
如何通过 guice 使用非 Jersey 资源和 Jersey 资源? 我希望“/”由普通 servlet 处理。但我希望 Jersey 处理“/users”。 假设我有一个带@Path("/use
我正在尝试使用 Maven、Apache Tomcat 7.0、Eclipse IDE 创建一个基本的 RESTful 应用程序。我在 google 提供的一些示例代码中遇到了 jersey-serv
我已经从 Jersey 1.7 升级到 2.16,但 Jersey 似乎无法找到我的资源(请参阅下面的堆栈)。任何想法发生了什么?我尝试在扩展 ResourceConfig 的自定义应用程序类中初始化
我正在使用 com.yammer.dropwizard.config.Environment addProvider 方法在 Jersey 中注册提供程序。我也有一个自定义提供程序,它执行类似于 Dr
在 Jersey 1.x 中,您可以使用 ContainerRequest.getFormParameters()对表单数据进行请求过滤,但我在 Jersey 2.x 中看不到明显的等价物。我已经实现
我正在使用Jersey的集成Jackson处理将传入的JSON转换为POJO,例如: @POST @Consumes(MediaType.APPLICATION_JSON) public Respon
我正在尝试以编程方式创建 Jersey 资源(没有注释)。我有一个将 Name 和 id 作为输入参数的方法 raiseAlarm。我想从 JSON 输入中获取名称,并且我希望 id 来自路径参数。代
Dropwizard official documentation Jersey 客户端不可测试,有人有 dropwizard Jersey 客户端样本吗? 最佳答案 我发现在 Dropwizard
我一直在寻找解决这个问题的方法,但没有成功。我发现的最新帖子可以追溯到 2010 年。我正在使用带有嵌入式 grizzly 2.2.1 的 Jersey 1.12。 如果我理解正确,除非我将 Jers
我想开发一个 Web API,它将生成和使用 JSON 和 XML 数据。 我已经使用JAXB来支持XML,并且工作正常。现在我想添加 JSON 类型。我研究了不同的教程,所有教程都使用不同的依赖项,
如此处所述:http://wikis.sun.com/display/Jersey/WADL 我在 Tomcat 6 中使用 Jersey 1.4。 我已经尝试了所有可能的带有“/applicatio
我是jax-rs的新手,并且已经用jersey和glassfish构建了Web服务。 我需要的是一种方法,服务启动后即被称为。在这种方法中,我想加载自定义配置文件,设置一些属性,编写日志等等。 我尝试
当客户端请求 Not Acceptable MIME 类型时,如何防止 Jersey 在客户端发送 HTML 页面?我想使用 ExceptionMapper,但我不确定要捕获什么异常,或者这是否是处理
我试图在它的 JSON 被解码后拦截一个资源调用。通过阅读一些论坛和帖子,我发现我可以通过实现 来做到这一点。 org.glassfish.jersey.server.spi.internal.Res
我的 webapp 包含一个库,其中包含一个用 @javax.ws.rs.ext.Provider 注释的类。 .如果存在此类,我的 web 应用程序(在 EAR 中部署为 WAR)将无法启动并显示以
我想自定义404响应,即服务器(不是我)在找不到请求的资源时抛出(或自己抛出一个自定义的WebApplicationException,如果可以测试一个应用程序中是否存在请求的资源)?资源列表存储在某
我有一个受 Shibboleth(SSO 实现)保护的 Jersey API。 Shibboleth 将登录用户的 ID 放入请求属性中。在后端,我使用 Shiro 进行授权。 Shiro 希望了解登
我目前正在使用 Jersey 返回 JSON。我该如何返回 JSONP?例如我当前的RESTful方法是: @GET @Produces(MediaType.APPLICATION_JSON) pub
我是一名优秀的程序员,十分优秀!