Java Jersey错误地调用子资源
我正在学习使用JAX-RS的RESTfulWeb服务。 我有一个Java Jersey错误地调用子资源,java,rest,jersey,jax-rs,exceptionmapper,Java,Rest,Jersey,Jax Rs,Exceptionmapper,我正在学习使用JAX-RS的RESTfulWeb服务。 我有一个MessageResource和一个子资源CommentResource 在我的MessageResource中,我用test方法映射了comment子资源,我在MessageResource类中对其进行了注释,因为我不希望调用CommentResource package org.kaushik.javabrains.messenger.resource; import java.net.URI; import java.uti
MessageResource
和一个子资源CommentResource
在我的MessageResource
中,我用test方法映射了comment子资源,我在MessageResource
类中对其进行了注释,因为我不希望调用CommentResource
package org.kaushik.javabrains.messenger.resource;
import java.net.URI;
import java.util.List;
import javax.ws.rs.Consumes;
import javax.ws.rs.DELETE;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.PUT;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.Status;
import javax.ws.rs.core.UriBuilder;
import javax.ws.rs.core.UriInfo;
import org.glassfish.jersey.server.Uri;
import org.kaushik.javabrains.messenger.exception.DataNotFoundException;
import org.kaushik.javabrains.messenger.model.Message;
import org.kaushik.javabrains.messenger.services.MessageService;
@Path("/messages")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public class MessageResource {
public MessageResource() {
// TODO Auto-generated constructor stub
}
@GET
public List<Message> getAllMessage() {
MessageService obj = new MessageService();
return obj.getAllMessages();
}
@GET
@Path("/{messageId}")
public Message getMessageById(@PathParam("messageId") String messageId) {
MessageService obj = new MessageService();
Message retrivedMessage = obj.getMessage(Long.parseLong(messageId));
return retrivedMessage;
}
/*
* This method is used to add new message in database returns created
* message with generated id
*/
/*
* @POST public Message postMessage(Message msg){
*
* MessageService obj = new MessageService(); msg = obj.addMessage(msg);
*
* return msg; }
*/
/**
* This method created the new message and sends new message with 201 status
* code using Response
*
* @param msg
* @return
*/
@POST
public Response postMessage(Message msg, @Context UriInfo uriInfo) {
MessageService obj = new MessageService();
msg = obj.addMessage(msg);
// This is to send only created status
// return Response.status(Status.CREATED).entity(msg).build();
// If we want to send status + new created resource path
String newId = msg.getId() + "";
URI uri = uriInfo.getAbsolutePathBuilder().path(newId).build();
return Response.created(uri).entity(msg).build();
}
@PUT
@Path("/{messageId}")
public Message updateMessage(Message msg, @PathParam("messageId") long id) {
MessageService obj = new MessageService();
msg.setId(id);
msg = obj.updateMessage(msg);
return msg;
}
@DELETE
@Path("/{messageId}")
public void deleteMessage(@PathParam("messageId") long id) {
MessageService obj = new MessageService();
obj.removeMessage(id);
}
/**
* This method is invoked if url asked for comments irrespective of http
* method, it will invoke the CommentResource which is a sub resouce of
* Message
*
* @return
*/
/*
* @Path("/{messageId}/comments") public CommentResource test() { return new
* CommentResource(); }
*/
}
我创建了一个通用异常映射器,它映射到Throwable
类。
它是为此目的创建的,如果在服务器端发生任何异常,而不是显示Tomcat错误报告页面,则应该发送有意义的消息
@Provider
public class GenericExceptionMapper implements ExceptionMapper<Throwable> {
@Override
public Response toResponse(Throwable ex) {
System.out.println("in Genereic mapper");
ErrorMessage message = new ErrorMessage(ex.getMessage(),"/Messenger/documentation",500);
return Response.status(Status.INTERNAL_SERVER_ERROR).entity(message).build();
}
}
如果我评论上述方法,我会在《邮递员》中得到正确的回应
有人能解释这种行为吗。提前感谢。从评论资源中删除@Path(“/”
)。正在将其添加为根资源。因此,当您访问/mesa
时,CommentResource
被映射到/
,它会点击映射到@Path(“{whatever}”)
的资源方法
子资源定位器类不应具有@Path
。这仅适用于根资源类。在子资源定位器请求中,它将被忽略,但在应用程序启动时,它仍然像常规根资源一样注册。表示注释资源不是作为子资源使用,而是作为独立资源使用??无论是否使用@Path(“/”)
它仍然作为子资源类使用,但是@路径
被忽略。正如我所说,子资源类不应该用@Path
注释。有了它,它将被映射到/
。如果您不想这样做,那么删除@Path(“/”
ya,即使在从注释资源中删除@Path之后,它仍然可以工作。
@Provider
public class GenericExceptionMapper implements ExceptionMapper<Throwable> {
@Override
public Response toResponse(Throwable ex) {
System.out.println("in Genereic mapper");
ErrorMessage message = new ErrorMessage(ex.getMessage(),"/Messenger/documentation",500);
return Response.status(Status.INTERNAL_SERVER_ERROR).entity(message).build();
}
}
@GET
@Path("/{commentId}")
public String getCommentById(@PathParam("messageId") String messageId, @PathParam("commentId") String commentId) {
return commentId + " This is dummy comment for messageID=" + messageId;
}