博客
关于我
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 Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>