我有一些REST服务(使用和生成application / json),并且使用@TypeHint生成文档。

现在我有这样的事情:

import javax.ws.rs.core.Response;

...

@Path("/path")

public class MyClass {

@GET

@TypeHint(MyResponse.class)

public Response getIt() {

MyResponse resp = ... ;

return MyBuilder.build(resp);

}

}

但是MyResponse是List的包装。

我来自MyResponse的build方法看起来像这样:

public static Response build(Serializable payload) {

return Response.ok(msr).header(...).build();

}

我想直接使用List而不是MyResponse。在以下代码中使用TypeHint的最佳方法是哪种?

@GET

@TypeHint(/* TODO */)

public Response getIt() {

List myList = ... ;

return MyBuilder.build(myList);

}

我在考虑以下选项:

@TypeHint(List.class)

@TypeHint(MyType.class)

@TypeHint(List.class)->不幸的是,由于Java类型擦除,此方法不起作用。

题:

3号有有效的替代方法吗?

即使类型是List,数字1也没有用,因为我自己的类型必须用@XmlRootElement注释,并且List是不可更改的(来自JDK)。

对于数字2,有一种解决方法,但这不是很完美:

使用数字2(只是为了在生成的HTML文档中提供可用示例-该列表中包含的元素的描述)

在Javadoc中指定它为List(例如:在@return单词之后)(可以通过HTML标记使用粗体,颜色,斜体等进行强调)

例如。:

/**

* ...

* @return List

*/

细节:

enunciate.version = 1.30.1

Java 7

我选择使用TypeHint而不是List.class时使用MyType []。class。这样,文档将声明" MyType数组",对于我的带有json的rest-api,它为true。

@TypeHint(value = MyType[].class)

这可能是一个更好的答案,但是不幸的是,现在我无法对其进行测试以确认您是否正确。

如您所知,TypeHint用于向Enunciate提供有关JAX-RS资源方法返回或接受为输入参数的内容的提示。

在您的情况下,将描述返回类型。

我假设ClassReturnedByMyBuildersBuildMethod是javax.ws.rs.core.Response抽象类的子类。

对于显示的代码,您需要使用MyBuilder的生成方法-@TypeHint(ClassReturnedByMyBuildersBuildMethod.class)返回的类。

选项2 @TypeHint(MyType.class)没有任何意义。它既不是返回类型也不是输入参数。

更新1:通过您的解决方法,这可能会有些道理:)

如果将输入参数添加到getIt方法-类似于public Response getIt(ListmyList){...,则将使用选项1(@TypeHint(List.class)),因为众所周知,org.codehaus.enunciate.jaxrs.TypeHint注释类型元素声明具有Class返回类型( Class< ? > value();),并且由于删除通用类型而不能使用参数化类型(在这种情况下,参数化类型在运行时共享相同的类-List)。

但是将输入参数更改为getIt(ListmyList)可能不可行,因为必须从URI(使用javax.ws.rs的@QueryParam或@Context UriInfo)获取列表。此问题解决了在您可能将参数列表用作输入时的最佳做法。

更新2:由于XmlRootElement约束,选项1变得不太可行。

更新3:我看不到使用TypeHint注释的选项3的有效替代方案。

您将必须使用自定义选项2解决方法。

1)我同意你的第一句话。 2)是的,我的构建器返回了Response 3)我从未尝试将Response类型用于TypeHint,因为当我使用"包装"的类型时,它可以完美地工作(根据我想要实现的目的) 回应。 4)我不使用List作为函数的参数。 它包装在返回的结果中。 根据您的建议,我需要尝试一下,然后才能说出您的答案是否有用。

它没有工作。 element的值被视为(custom),而不是指向JSON示例的超链接。 因此,这并不比问题中所述的解决方法更好。

我更新了您所做修改的答案。

hint java_关于java:TypeHint,用于在Enunciate中进行收集相关推荐

  1. endorsed java_关于java:在jdk1.6中使用Endorsed目录的确切方法是什么

    我想将jaxws升级到2.2(jdk1.6与jaxws 2.1捆绑在一起).我的jdk是(我没有安装public jre): java version"1.6.0_20" Java ...

  2. getconnection java_在MyEclipse用java写的一个GetConnection1.java,用于连接MySQL,却总是出错。(没有财富值了,见谅!)...

    在MyEclipse用java写的一个GetConnection1.java,用于连接MySQL,却总是出错.求救!!!packageJavaBean1;importjava.sql.*;import ...

  3. 是否可以将Java 8用于Android开发?

    本文翻译自:Is it possible to use Java 8 for Android development? Searching the web, it is not clear if Ja ...

  4. java akka_用于大型事件处理的Akka Java

    java akka 我们正在设计一个大型的分布式事件驱动系统,用于跨事务数据库的实时数据复制. 来自源系统的数据(消息)在到达目的地之前经历了一系列转换和路由逻辑. 这些转换是多进程和多线程的操作,包 ...

  5. aes256加密java_使用Java和JCEKS进行AES-256加密

    aes256加密java 总览 由于最近爱德华·斯诺登 ( Edward Snowden)发布了文件,以及针对JC Penny , Sony和Target等在线商业商店的黑客攻击激增,安全性已成为近年 ...

  6. web csrf java_在Java Web应用程序中阻止CSRF

    web csrf java 跨站点请求伪造攻击(CSRF)在Web应用程序中非常常见,如果允许,可能会造成重大危害. 如果您从未听说过CSRF,建议您查看有关它的OWASP页面 . 幸运的是,阻止CS ...

  7. 2021-12-27 Java String contains() 方法用于判断字符串中是否包含指定的字符或字符串。用.toLowerCase().contains忽视大小写。

    一.public boolean contains(CharSequence chars) contains() 方法用于判断字符串中是否包含指定的字符或字符串. 二.返回值        如果包含指 ...

  8. androidlib.java_实现 Java SDK 库

    Android 平台包含大量的共享 Java 库,可以使用应用清单中的 标记选择性地将其纳入应用的类路径中.由于应用与这些库相关联,因此在兼容性.API 审核和工具支持方面,应将其与其他 Androi ...

  9. 命令行卸载java_卸载java

    有小伙伴经常会遇到Java没有卸载干净的情况,造成重新安装JDK能正常安装,接着安装JRE的时候总是报1603错误.虽然说JRE安装报错了没安装上,但是eclipse.IntelliJ IDEA和An ...

最新文章

  1. Spring Boot 中 @EnableXXX 注解的驱动逻辑
  2. Web 开发最有用的 jQuery 插件集锦
  3. pytorch保存准确率_初学Pytorch:MNIST数据集训练详解
  4. 4g的服务器mysql配置文件,服务器物理内存16G mysql数据库my.cnf配置及参数说明
  5. 青苹果影视系统源码v1.3.20 多功能开源影视源码
  6. iOS oc 线程 进程,同步异步,并发串行,来捋捋
  7. Effective c++读书笔记
  8. 求集合的所有子集问题
  9. 《抉择与命运》读后感
  10. Android中将EditText里面的内容设置成任意想要的状
  11. java就业班学什么呀_传智播客JAVA就业班的学习心得
  12. 《大话数据结构》-1-数据结构绪论-基本概念-数据,数据结构,逻辑结构,物理结构等
  13. (六省)蓝桥真题 奇妙的数字
  14. 单片机c51语言实训总结,单片机实训报告
  15. Numpy中take的用法
  16. python编程计算圆面积和体积_计算sph体积和表面积的面向对象Python程序
  17. union与order by 结合使用
  18. SpringBoot+Vue实现前后端分离的学校快递站点管理系统
  19. 高等数学(一)夹逼定理
  20. TIA博途V16版本中如何进行项目的归档和恢复?

热门文章

  1. 学以致用——Java源码——键盘事件演示程序(Keystroke Events Demo Program)
  2. 车联网是什么,车联网的发展面临哪些问题
  3. 嵌入式系统在物联网中的应用及架构
  4. TypeError: load() missing 1 required positional argument: ‘Loader‘解决方案
  5. KL3611 型号 7脚多位数码管驱动方法
  6. 91熊猫看书电脑版 v0.8.0|官方安装版下载
  7. 发布的APP并检测出病毒
  8. WORKGROUP无法访问,您可能没有权限使用网络资源,请与这台服务器的管理员联系以查明您是否有访问权限。
  9. 网军与黑产组织百科全书2.0
  10. win7摄像头不在计算机,win7摄像头在哪里打开