@PathParam和@QueryParam区别简析

网友投稿 239 2023-02-25


@PathParam和@QueryParam区别简析

本文主要研究的是@PathParam和@QueryParam区别问题,具体如下。

问题

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

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

代码

@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中直接在斜杠后面添加参数值, 例如:a.com/student/001 ;

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

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

解决办法就是修改URL,取消键值对,在斜杠后直接加参数值,改成:

http://192.168.1.3/web1_service/convert/vict_hj1000/160106

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

@Path("/vict_hj1000/{unit}")

问题解决!

总结

以上就是本文关于@PathParam和@QueryParam区别简析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringMVC返回图片的几种方式(小结)
下一篇:laravel5.3 vue 实现收藏夹功能实例详解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~