博客
关于我
JAX-RS之@formparam和@HeaderParam
阅读量:129 次
发布时间:2019-02-26

本文共 1671 字,大约阅读时间需要 5 分钟。

今天继续学习JAX-RS中的@formparam和@headerparam。

1. @formparam

@formparam是一种在JAX-RS中强大的绑定机制,允许前端HTML表单数据直接传递给后端服务。通过@formparam,可以轻松将HTML表单字段映射到Java方法参数中。

示例

考虑以下HTML表单:

  

JAX-RS @FormQuery Testing

Name :
Age :

当表单提交时,数据会发送到rest/user/add endpoint。服务端可以通过@formparam注解来接收表单数据。

服务端代码

@Path("/user")public class UserService {    @POST    @Path("/add")    public Response addUser(        @FormParam("name") String name,        @FormParam("age") int age    ) {        return Response.status(200)            .entity("addUser is called, name : " + name + ", age : " + age)            .build();    }}

2. @headerparam

除了@formparam,JAX-RS还提供了@headerparam用来获取HTTP请求头信息。通过@headerparam,可以直接从HTTP请求头中获取特定头字段的值。

方法一:@HeaderParam注解

@Path("/users")public class UserService {    @GET    @Path("/get")    public Response addUser(        @HeaderParam("user-agent") String userAgent    ) {        return Response.status(200)            .entity("addUser is called, userAgent : " + userAgent)            .build();    }}

当访问/users/get endpoint时,会返回包含用户代理信息的响应。

方法二:@Context HttpHeaders

另一种获取HTTP头信息的方法是使用@Context注解获取HttpHeaders对象,然后手动获取所需头字段。

@Path("/users")public class UserService {    @GET    @Path("/get")    public Response addUser(        @Context HttpHeaders headers    ) {        String userAgent = headers.getRequestHeader("user-agent").get(0);        return Response.status(200)            .entity("addUser is called, userAgent : " + userAgent)            .build();    }}

测试

  • 访问http://localhost:8080/RESTfulExample/UserForm.html会看到一个标准的HTML表单。-提交表单后,数据会发送到http://localhost:8080/RESTfulExample/rest/user/add endpoint。

通过以上方法,可以轻松地在JAX-RS服务中处理HTML表单数据和HTTP请求头信息。

转载地址:http://aacf.baihongyu.com/

你可能感兴趣的文章
PAT甲级——1007 Maximum Subsequence Sum (25分)
查看>>
PAT甲级——1009 Product of Polynomials (25分)(最后一个测试点段错误)
查看>>
Spring对jdbc的支持
查看>>
PayPal网站付款标准版(for PHP)
查看>>
Paystack Android SDK 集成与使用指南
查看>>
pbf格式详解,javascript加载导出pbf文件示例
查看>>
PBOC2.0与3.0的区别
查看>>
PbootCMS entrance.php SQL注入漏洞复现
查看>>
PbootCMS 前台RCE漏洞复现
查看>>
PBT
查看>>
PB级分析型数据库ClickHouse的应用场景和特性
查看>>
pc3-12800
查看>>
PCA---主成成分分析
查看>>
pca算法
查看>>
PCA降维demo
查看>>
SharePoint 2013 图文开发系列之定义站点模板
查看>>
PCB设计十条黄金法则
查看>>
SpringSecurity框架介绍
查看>>
PCI Express学习篇:Power Management(二)
查看>>
pcie握手机制_【博文连载】PCIe扫盲——Ack/Nak 机制详解(一)
查看>>