jersey tomcat MySQL_IDEA+Jersey+Tomcat搭建RESTful API

环境:

IDEA Ultimate 2017.2.2 + JDK 1.8 + Jersey 2 + Maven + Tomcat 9.0.0.M22

首先创建项目:

选中Web Application(3.1)框架,勾选Create web.xml,IDE会在创建项目时创建web.xml配置文件。

196d274d65cf

创建项目

创建项目后右键选中项目,添加框架支持,选中Maven,随即生成pom.xml文件。这里会弹出Event对话框,会有提示你Enable Auto-Import,这里我们Enable一下。

196d274d65cf

添加框架

然后开始通过maven添加依赖jar包,引用Jersey,pom.xml配置如下:

com.overc_i3.jerseydemo

JerseyDemo

1.0-SNAPSHOT

1.8

1.8

2.25

org.glassfish.jersey.containers

jersey-container-servlet

${jersey.version}

org.glassfish.jersey.core

jersey-server

${jersey.version}

org.glassfish.jersey.core

jersey-client

${jersey.version}

org.glassfish.jersey.media

jersey-media-json-jackson

${jersey.version}

接下来是配置web.xml,项目里的路径是web/WEB-INF/web.xml,这里我们将 Jersey 当做 Servlet:

jerseyServlet

org.glassfish.jersey.servlet.ServletContainer

jersey.config.server.provider.packages

com.overc_i3.jerseydemo

1

jerseyServlet

/*

也可将 Jersey 当做 Servlet Filter,如下配置:

MyApplication

org.glassfish.jersey.servlet.ServletContainer

...

...

MyApplication

/myApp/*

元素内容将取决于你如何决定资源配置不同的 Jersey 资源。

最后一步配置,在输出中把jar包全部加进去

196d274d65cf

在输出中加入库文件

配置完成,开始写上API代码,首先在src\main\java中根据之前配置的包建好对应的包,我这里配置的是com\overc_i3\jerseydemo,这里使用Json做交互,先建model:

package com.overc_i3.model;

import java.util.List;

public class ReqJson {

private String id;

private List list;

public List getList() {

return list;

}

public void setList(List list) {

this.list = list;

}

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

public static class ListBean {

private String maxname;

public String getMaxname() {

return maxname;

}

public void setMaxname(String maxname) {

this.maxname = maxname;

}

}

}

创建TestApi类:

package com.overc_i3.jerseydemo;

import com.overc_i3.model.ReqJson;

import javax.ws.rs.*;

import javax.ws.rs.core.MediaType;

import javax.ws.rs.core.Response;

import java.util.ArrayList;

import java.util.List;

@Path("/")

public class TestApi {

//GET注解设置接受请求类型为GET

@GET

// 与Produces对应的是@Consumes

@Produces(MediaType.TEXT_PLAIN)

//用作测试服务启动情况

public String getMessage() {

return "Hello world!";

}

@GET

@Consumes(MediaType.TEXT_PLAIN)//注解指定解压方式接收数据类型

@Path("/hello")

public Response postJson(@QueryParam("name") String name) {

return Response.status(200).entity("hello "+name).build();

}

@POST

@Consumes(MediaType.APPLICATION_JSON)//注解指定解压方式接收数据类型

@Produces(MediaType.APPLICATION_JSON)//注解指定压缩方式返回数据类型

@Path("/postJson2")

public Response postJson2(ReqJson msg) {

ReqJson reqJson = new ReqJson();

reqJson.setId(msg.getId());

List listBeanList = new ArrayList<>();

for (int i = 0; i < msg.getList().size(); i++) {

ReqJson.ListBean listBean = new ReqJson.ListBean();

listBean.setMaxname(msg.getList().get(i).getMaxname());

listBeanList.add(listBean);

}

reqJson.setList(listBeanList);

return Response.status(200).entity(reqJson).build();

}

}

现在配置Tomcat运行一下:

点击Run >Edit Configurations… > “+” > Tomcat Server > Local,加入Tomcat,选择Deployment tab, 点击 “+”, 选择唯一的Artifact,点击"OK"即可。

196d274d65cf

Tomcat配置

配置好之后直接运行,在浏览器访问http://localhost:8080

196d274d65cf

默认地址

196d274d65cf

Get hello

到这里RESTful API已经正常运行,接下来再用Fiddler调用API(注意设置请求格式Content-Type: application/json):

196d274d65cf

调用API

196d274d65cf

查看调API结果

到这里RESTful API已经搭建完成,下面是部署的一些其它“姿势”:

自定义 Application 子类

如果你的继承 Application 类来提供有关根资源类的列表(getresources())和单身(getsingletons()),即你的 JAX-RS 应用模型,然后你需要注册一个 javax.ws.rs.Application [原名] 名称的 Servlet 或 Servlet 过滤器作为 web 应用程序的初始化参数,在 web.xml 中进行部署描述:

配置 Jersey 容器 Servlet 或者 过滤器来自定义 Application 子类

javax.ws.rs.Application

org.foo.MyApplication

Jersey 将考虑所有 Application 实现的 getClasses() 和 getSingletons() 方法的返回。

注意:JAX-RS 规范定义的配置名称确实是 javax.ws.rs.Application 而不是 javax.ws.rs.core.Application

Jersey 扫描包

如果配置属性无需设置,要部署应用程序只包括存储在特定的包的资源和提供者,那么你可以指示 Jersey 自动扫描这些包,这样就能自动注册找到的任何资源和提供者:

配置 Jersey 的 Servlet 或者 Filter 来扫描包

jersey.config.server.provider.packages

org.foo.myresources,org.bar.otherresources

jersey.config.server.provider.scanning.recursive

false

Jersey 将会自动发现被选中的资源和提供者。你可以通过设置 >jersey.config.server.provider.scanning.recursive 属性来决定 Jersey 是否扫描子包。默认值是 true , 即启用递归扫描子包。

源码:https://github.com/overclockingi3/JerseyDemo

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值