java中 queryparam_@PathParam 和 @QueryParam

今天调试一个上传功能,客户端手持机发送数据,在URL中附加一个参数,后台用@PathParam接收,但是报错,无法获取这个参数。

url:http://192.168.1.3/web1_service/convert/vict_hj1000?unit=160106

64b25e5dc5df7ba5dd5c90ec501b71c0.png

代码:

@Path("/vict_hj1000")

@POST

@Consumes(MediaType.MULTIPART_FORM_DATA)

publicResponse createVictHJ1000Detect(@FormDataParam("name0") InputStream uploadedInputStream,@PathParam("unit") Long unit)throwsJSONException {@Path("/vict_hj1000")

@POST

@Consumes(MediaType.MULTIPART_FORM_DATA)

public Response createVictHJ1000Detect(@FormDataParam("name0") InputStream uploadedInputStream, @PathParam("unit") Long unit) throws JSONException {

也就是说,这个unit参数获取不到,怎么回事呢?

网上查了一遍,找到了原因,是url中参数的写法不对,导致后台的@PathParam无法获取,下面列出@PathParam和@QueryParam的区别:

1. @PathParam ,url中直接在斜杠后面添加参数值,              例如:www.a.com/student/001;

2. @QueryParam ,url中在后面添加【键值对】形式的参数,例如:www.a.com/student?id=001 ;

我的应用里面,url用的是键值对形式的参数,而后台用的是@PathParam,不匹配,因此无法获取。

解决办法就是修改URL,取消键值对,在斜杠后直接加参数值,改成:http://192.168.1.3/web1_service/convert/vict_hj1000/160106

并且后台修改@Path注解,改为:

@Path("/vict_hj1000/{unit}")@Path("/vict_hj1000/{unit}")问题解决!

原文转载: http://blog.csdn.NET/zhouyingge1104/article/details/51034970

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值