一旦我得到这个问题 Latest Jersey example does not work 的答案,我就遇到了另一个奇怪的问题:
服务器,GET 方法工作正常。我测试并添加了一些测试代码 helloworld-pure-jax-rs例子,尤其是为 JSON 添加了 POST 请求:
package org.glassfish.jersey.examples.helloworld.jaxrs;
import javax.ws.rs.Consumes;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
@Path("helloworld")
public class HelloWorldResource
{
public static final String CLICHED_MESSAGE = "Hello World!";
@GET
@Produces(MediaType.TEXT_PLAIN)
public String getHello()
{
return CLICHED_MESSAGE;
}
@GET
@Produces(MediaType.APPLICATION_JSON)
public String getHelloJson()
{
return "{ \"message\":" + CLICHED_MESSAGE + "}";
}
@GET
@Produces(MediaType.TEXT_HTML)
public String getHelloHtml()
{
return "<html> " + "<title>" + "Hello Jersey" + "</title>" + "<body><h1>" + CLICHED_MESSAGE
+ "</body></h1>" + "</html> ";
}
@GET
@Produces(MediaType.TEXT_PLAIN)
@Path("/v2")
public String getHello2()
{
return CLICHED_MESSAGE + " v2";
}
@GET
@Produces(MediaType.TEXT_PLAIN)
@Path("/{id}")
public String getHelloId(@PathParam("id") String id)
{
return CLICHED_MESSAGE + " Parameter: " + id;
}
@GET
@Produces(MediaType.TEXT_PLAIN)
@Path("/id/{id : [a-zA-Z][a-zA-Z_0-9]}")
public String getHelloIdId(@PathParam("id") String id)
{
return CLICHED_MESSAGE + " Parameter: " + id;
}
@POST
@Consumes(MediaType.TEXT_PLAIN)
@Produces(MediaType.TEXT_PLAIN)
public Response test(String test)
{
if (test.equals("test"))
return Response.status(400).entity("Error: " + test).build();
return Response.status(200).entity(test).build();
}
@POST
@Path("/test")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response testJSON(Test test)
{
String result = "Test JSON created : " + test.getName() + "" + test.getAge();
// return result;
return Response.status(200).entity(result).build();
}
@POST
@Path("/test")
@Consumes(MediaType.APPLICATION_XML)
@Produces(MediaType.APPLICATION_XML)
public Response testXML(Test test)
{
String result = "Test XML created : " + test.getName() + "" + test.getAge();
// return result;
return Response.status(200).entity(result).build();
}
}
这是其余的类:
package org.glassfish.jersey.examples.helloworld.jaxrs;
import java.io.IOException;
import java.net.InetSocketAddress;
import java.net.URI;
import javax.ws.rs.core.UriBuilder;
import javax.ws.rs.ext.RuntimeDelegate;
import com.sun.net.httpserver.HttpHandler;
import com.sun.net.httpserver.HttpServer;
/**
* Hello world application using only the standard JAX-RS API and lightweight
* HTTP server bundled in JDK.
*
* @author Martin Matula (martin.matula at oracle.com)
*/
@SuppressWarnings("restriction")
public class App
{
/**
* Starts the lightweight HTTP server serving the JAX-RS application.
*
* @return new instance of the lightweight HTTP server
* @throws IOException
*/
static HttpServer startServer() throws IOException
{
// create a new server listening at port 8080
HttpServer server = HttpServer.create(new InetSocketAddress(getBaseURI().getPort()), 0);
// create a handler wrapping the JAX-RS application
HttpHandler handler = RuntimeDelegate.getInstance().createEndpoint(new JaxRsApplication(),
HttpHandler.class);
// map JAX-RS handler to the server root
server.createContext(getBaseURI().getPath(), handler);
// start the server
server.start();
return server;
}
public static void main(String[] args) throws IOException
{
System.out.println("\"Hello World\" Jersey Example Application");
HttpServer server = startServer();
System.out.println("Application started.\n" + "Try accessing " + getBaseURI()
+ "helloworld in the browser.\n" + "Hit enter to stop the application...");
System.in.read();
server.stop(0);
}
private static int getPort(int defaultPort)
{
final String port = System.getProperty("jersey.config.test.container.port");
if (null != port)
{
try
{
return Integer.parseInt(port);
}
catch (NumberFormatException e)
{
System.out.println("Value of jersey.config.test.container.port property"
+ " is not a valid positive integer [" + port + "]."
+ " Reverting to default [" + defaultPort + "].");
}
}
return defaultPort;
}
/**
* Gets base {@link URI}.
*
* @return base {@link URI}.
*/
public static URI getBaseURI()
{
return UriBuilder.fromUri("http://localhost/").port(getPort(8080)).build();
}
}
public class Test
{
public int age = 0;
public String name = "";
/**
*
*/
public Test()
{
super();
}
/**
* @param age
*/
public Test(int age)
{
super();
this.age = age;
}
/**
* @param name
*/
public Test(String name)
{
super();
this.name = name;
}
/**
* @param name
* @param age
*/
public Test(String name, int age)
{
super();
this.name = name;
this.age = age;
}
public int getAge()
{
return age;
}
public String getName()
{
return name;
}
public void setAge(int age)
{
this.age = age;
}
public void setName(String name)
{
this.name = name;
}
}
package org.glassfish.jersey.examples.helloworld.jaxrs;
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;
import javax.ws.rs.core.Application;
public class JaxRsApplication extends Application
{
private final Set<Class<?>> classes;
public JaxRsApplication()
{
HashSet<Class<?>> c = new HashSet<Class<?>>();
c.add(HelloWorldResource.class);
classes = Collections.unmodifiableSet(c);
}
@Override
public Set<Class<?>> getClasses()
{
return classes;
}
}
这适用于纯文本发布消息,但对于 json (MediaType.APPLICATION_JSON) 和 xml 部分 (MediaType.APPLICATION_XML),它无法说明不受支持的媒体类型。知道哪里出了问题吗?
最佳答案
JAX-RS 有一堆内置的处理程序,可以编码到和从几个不同的 特定的 Java 类型。
一旦我们开始处理自定义数据绑定(bind)(编码/解码到 Java 对象),我们就进入了一个不同的球赛。我们现在需要一些其他的 MessageBodyWriters和 MesageBodyReaders .
幸运的是,已经有可用于 XML 和 JSON 数据绑定(bind)的读取器和写入器。 JAX-RS 带有标准的 XML 编码/解码,有一个警告..我们必须使用 JAXB注释。所以对于你的 Test 类,假设它是这样的
public class Test {
private String name;
private int age;
public String getName() { return name; }
public void setName(String name) { this.name = name;}
public int getAge() { return age; }
public void setAge(int age) { this.age = age; }
}
要允许 JAXB 提供者 解码/编码,我们至少应该提供一个 @XmlRootElement
@XmlRootElement
public class Test {
....
}
这样做应该允许 XML 工作。
就 JSON 而言,JSON 绑定(bind)不是规范的标准部分,但我们可以简单地向项目添加依赖项,它将自动注册所需的提供程序来处理 JSON 绑定(bind)。您可以查看 json-moxy 的 pom.xml例子。你会看到这个需要的依赖
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-moxy</artifactId>
</dependency>
依赖项允许应用程序执行的操作是使用 JAXB 注释将 jSON 编码/解码到我们的 Java 对象或从中编码。所以只需将此依赖项添加到 pom.xml 即可。该应用程序应该工作。刚刚测试。
关于java - Jersey 演示应用程序中的 MediaType.APPLICATION_XML 和 MediaType.APPLICATION_JSON,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26697102/
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我有一个非常简单的RubyRack服务器,例如:app=Proc.newdo|env|req=Rack::Request.new(env).paramspreq.inspect[200,{'Content-Type'=>'text/plain'},['Somebody']]endRack::Handler::Thin.run(app,:Port=>4001,:threaded=>true)每当我使用JSON对象向服务器发送POSTHTTP请求时:{"session":{"accountId":String,"callId":String,"from":Object,"headers":
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/
HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候