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

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

今天继续学习JAX-RS中的@formparam和@headerparam
1 @formparam
    其功能是可以将前端的HTML绑定,先看例子
 
Java代码
  1.   
  2. html>   
  3. <body>   
  4.     <h1>JAX-RS @FormQuery Testing</h1>   
  5.     
  6.     <form action="rest/user/add" method="post">   
  7.            
  8.             Name : <input type="text" name="name" />   
  9.            
  10.   
  11.            
  12.             Age : <input type="text" name="age" />   
  13.            
  14.   
  15.         <input type="submit" value="Add User" />   
  16.     </form>   
  17.     
  18. </body>   
  19. </html>  
html>	

JAX-RS @FormQuery Testing

Name :
Age :
   处理:
  
Java代码
  1. @Path("/user")   
  2. public class UserService {   
  3.     
  4.     @POST  
  5.     @Path("/add")   
  6.     public Response addUser(   
  7.         @FormParam("name") String name,   
  8.         @FormParam("age"int age) {   
  9.     
  10.         return Response.status(200)   
  11.             .entity("addUser is called, name : " + name + ", age : " + age)   
  12.             .build();   
  13.     
  14.     }  
@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(); 	}
  对于前端的HTML浏览,比如:
   http://localhost:8080/RESTfulExample/UserForm.html
  会出现普通的HTML表单,当提交按钮时,会转到
http://localhost:8080/RESTfulExample/rest/user/add
这个URL,这样,REST就去匹配addUser方法了,所以就会把表单中提交的数据输出。
2 在JAX-RS中,有两种方法能取得HTTP REQUEST头,
  1)@headparam
  
Java代码
  1.   
  2. @Path("/users")   
  3. public class UserService {   
  4.     
  5.     @GET  
  6.     @Path("/get")   
  7.     public Response addUser(@HeaderParam("user-agent") String userAgent) {   
  8.     
  9.         return Response.status(200)   
  10.             .entity("addUser is called, userAgent : " + userAgent)   
  11.             .build();   
  12.     
  13.     }  
@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(); 	}
  当访问URL:
  /users/get
会输出HTTP 头信息,即:
  addUser is called, userAgent : Mozilla/5.0 (Windows NT 6.1; rv:5.0) Gecko/20100101 Firefox/5.0
   另外的方法是,
Java代码
  1. @Path("/users")   
  2. public class UserService {   
  3.     
  4.     @GET  
  5.     @Path("/get")   
  6.     public Response addUser(@Context HttpHeaders headers) {   
  7.     
  8.         String userAgent = headers.getRequestHeader("user-agent").get(0);   
  9.     
  10.         return Response.status(200)   
  11.             .entity("addUser is called, userAgent : " + userAgent)   
  12.             .build();   
  13.     
  14.     }  
@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://aacf.baihongyu.com/

你可能感兴趣的文章
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>