广告
返回顶部
首页 > 资讯 > 后端开发 > Python >SpringMVC中如何获取@PathVariable的值
  • 1099
分享到

SpringMVC中如何获取@PathVariable的值

2024-04-02 19:04:59 1099人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录如何获取@PathVariable的值一、地址:**/{id}二、方式springMVC使用@PathVariable时,应该注意点什么?一、使用@PathVariable的转变

如何获取@PathVariable的值

一、地址:**/{id}


@RequestMapping(value = "/del/{id}", method = RequestMethod.GET)
public void del(httpservletRequest request, @PathVariable("id") Long id){
   System.out.println(id);
}

二、方式

1、直接通过@PathVariable注解获取


    @RequestMapping(value = "/del/{id}", method = RequestMethod.GET)
    public void del(HttpServletRequest request, @PathVariable("id") Long id){
       System.out.println(id);
    }

2、通用@PathVariable注解批量获取, 只有注解的参数才能得到


@RequestMapping(value = "/del/{id}", method = RequestMethod.GET)
   public void del(HttpServletRequest request, @PathVariable("id") Long id){
        NativeWEBRequest webRequest = new ServletWebRequest(request);
        Map<String, Object> map = (Map<String, Object>) webRequest.getAttribute(View.PATH_VARIABLES, RequestAttributes.SCOPE_REQUEST);
        System.out.println(map.get("id"));
  }

3、批量获取,不需要任何注解


@RequestMapping(value = "/del/{id}", method = RequestMethod.GET)
  public void del(HttpServletRequest request){
       NativeWebRequest webRequest = new ServletWebRequest(request);
       Map<String, String> map = (Map<String, String>) webRequest.getAttribute(HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE, RequestAttributes.SCOPE_REQUEST);
       System.out.println(map.get("id"));
  }

springmvc 使用@PathVariable时,应该注意点什么?

近来在做库存调剂系统时,我从前台到后台的传值方式,主要包括:1个,用@PathVariable或者@RequestParam从路径取;大于一个,用于更新或者添加操作的,我用的是表单实体传到后台;大于一个,用于查询的,我用的@RequestBody(好吧,我承认这个只是我觉得好玩,但没有多少人愿意在后台一行又一行的写:String test=request.getParameter("test");吧?????)

现在,主要就是想说一个从路径取值的“坑”,而重中之重,就想说一下我更偏爱的@PathVariable(别问我为什么,/{param}/fn.do,简单啊)

一、使用@PathVariable的转变过程

首先:

在盘古开天辟地时,就是一切还很混沌时,姑娘我连用@PathVariable取值都没有取过来,还蒙圈蒙了一小会儿,完全不明白发生了什么,因为我看着我的语法和格式,哪儿哪儿都对,但就是没有传过来值。我一想我原来写/{param}/fn.do这种方式传值的时候,也没有问题呀,怎么今天是见鬼了???? 蒙圈完了之后,就发现端倪了。

请看看我怎么写的哈:


@RequestMapping("/dealerStock/swapOrder/{orderID}/cancelAuditThisOrder.do")
public @ResponseBody String cancelAuditThisOrder(@PathVariable("OrderID") String strOrderID)){
...
...
}

然后的然后,我就一直没有请求到这个方法,更别谈什么有没有取到值的问题!后来解决的时候,真想一掌拍自己脑门上!

然后:

当代码规范审查通过后,也经过了测试部的一级功能业务测试以及业务部的二级业务流程测试。文档之类的,都准备好了(我还能再说什么呢,无声的两个呵 呵) 正要布上去生产线的时候,老大再次审查了一遍代码,审查到最后也没个啥结果,但是,突然间看到那个@PathVariable就问了我两个问题:

  • 一、如果我的ID是不连续的,这种方法还能好使吗?比如说:HC 782981;
  • 二、是不是只要我拿到这个请求路径,而我随便推测一个ID号,就能避过用户操作别人的数据?

姑娘我再次被雷击倒,无言以对,马上实际验证。结果:Yes! 你说第一个的结果是Yes,这个我很满意,但第二个是Yes,就很想哭了。 测试出结果后,就请命去干掉这个问题了。

我的第一步尝试:

添加method=RequestMethod.post,也就是说用户不能输入Url地址以get的形式获取数据,只能通过系统内部请求。

  • 组长:你自己说,就算咱们改成了Post请求,你能不能访问到?
  • 姑娘:我能,就自己写一个按钮,再用post请求就行了。如果用户里面有懂点程序编码的,轻而易举就能破掉。我再去改
  • 组长:其实,我们只能防君子,哪个系统都有漏洞,没有绝对的权限控制和安全,但咱们尽量的给做好。

我的第二步尝试:

在第二步尝试前,我想了一会儿。我发现这个事件有以下几个突破口:

  • 一、像订单编号这个敏感的数据,能不能做到不被推测出来?
  • 二、用户是根据访问路径,然后加上一个ID号去请求,如果用户拿不到访问路径呢?
  • 三、要点就是用户只能操作自己的数据,我可以在敏感操作的时候,同时校验当前用户。
  • 四、既然都是@PathVariable这种方式带来的一些问题,那我可以把相应的方法,换掉这种传值方式。
  • 五、用户看到的是一个请求方法路径,我可不可以在路径中加入随机密码盐,进一步的控制关键操作的访问。

好吧,为了方便迅速,我直接把这种传值方式给改了。当然也没有改完,时间关系,像一些本来就属于公开数据的内容,还是没改。

我的第三步尝试:

在第二步的时候,就已经改完代码了。然后,我觉得我是一个很较真的人。忙里偷闲,我把我在第二步尝试中想到了几个点,都写代码测了测。最先测出来的是第三种(同时检验当前用户,也就简单类似于where orderID=? and userID=? ) 其次,还测了测那个密码盐值,也确实能够控制住,但是,想了想系统的性质和资源的最终走向,没改。然后,去禁止用户打开开发工具或者查看源代码,然而,这根本不是我能控制住的。我也最多就是能控制住快捷键打开,但人家还有鼠标啊??????浏览器提供的功能,不是我想干掉就干掉滴滴滴滴。

我的第一个方案,就是改造订单生成的方式,然后我觉得吧,这个好像不怎么靠谱。但毫无疑问比当前的生成方式要靠谱得太多,但这要改动下来,呃,原谅我很怂。

二、个人总结

我最大的问题,不是我后来想不出更为优雅的方案去解决,而是,我从根本上,对这是个问题的问题毫无知觉。我甚至都不觉得那样有什么问题,这才是我最该考虑的点。

其实,我用@PathVariable或者什么别的方式去传值,这都无可厚非。但我也应该更进一步的考虑到它的应用场景和系统功能涉及到的数据,以及可能带来的后果。就比如说我这个@PathVariable的问题,在别的查询一些区域信息(公共展示数据)的时候,我也这么用了,组长也看见了,但为什么他着重说了订单这一块,还要求这一块必须改。反正,我就是欠思考。。。。。。

很多很多的东西,都是建立在日常生活体验上的。我以前就很崇拜架构师,现在也很崇拜。但是,我突然明白,架构师也不是光有空架子的。就比如说我自己吧,我还算是乱七八糟的想法挺多的那种(虽然并不是每个都靠谱)但是,做事情不能光凭想象,要实际操作的。

感觉最近做得比较好一点的就是:

1,因为有一个地方查询的数据有很多,那天我跟组长提出,我要换一种查询方法,提升查询效率。然后组长就问我究竟想怎么换?我就直接同时运行了两套代码干同样的事儿给他看,结果,就很so easy的换成了我想换的那种方式,我想说的话,全都在代码里。后来弄完了,闲下来,我解释了一下不同点,关键点。

2,因为强调代码规范和效率嘛。我就在自己私下写代码的时候,旁边就放着一本代码整洁之道,还有阿里代码规范手册,然后还有我闲下来的时候,去官网找的一些常用数据结构、数据类型的应用对比。我是一边写,一边看。有不知道怎么写的,就干脆先看一眼,照着书写。刚开始挺痛苦的,因为写一句就错一句,也不能说错,就是不够优美。但是,感觉现在慢慢变得好了特别特别多。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: SpringMVC中如何获取@PathVariable的值

本文链接: https://www.lsjlt.com/news/155454.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SpringMVC中如何获取@PathVariable的值
    目录如何获取@PathVariable的值一、地址:**/{id}二、方式springmvc使用@PathVariable时,应该注意点什么?一、使用@PathVariable的转变...
    99+
    2022-11-12
  • springmvc HttpServletRequest 如何获取c:forEach的值
    目录如何获取c:forEach的值请教怎么做呢?springmvc向jsp传值以及c:foreach说明用foreach遍历:如果要横向显示的话:关于c:foreach:如何获取c:...
    99+
    2022-11-12
  • 如何在拦截器中获取url路径里面@PathVariable的参数值
    目录在拦截器中获取url路径里@PathVariable参数值解决办法示例接口完整示例spring @PathVariable:请求路径url 上有变量值,通过@PathVariab...
    99+
    2022-11-12
  • SpringMVC中重定向model值的获取方式
    目录SpringMVC重定向model值的获取1、步骤一:在控制器中编写2、编写对应跳转3、测试:在浏览器访问自己项目下的对应控制器4、然后浏览器跳转SpringMVC中model的...
    99+
    2022-11-12
  • @RequestMapping 如何使用@PathVariable 从URI中获取参数
    目录@RequestMapping 使用@PathVariable 从URI中获取参数URI中的请求参数定义URL变量规则获取URI变量定义多个URL变量匹配正则表达式SpringM...
    99+
    2022-11-12
  • springmvc获取前端值的方法是什么
    在Spring MVC中,获取前端值的方法有以下几种:1. 使用@RequestParam注解获取请求参数的值:java@Reque...
    99+
    2023-10-18
    springmvc
  • vue如何获取map中的值
    在vue中获取map值的方法:1.使用Object方法获取map中的key和value值;2.使用Object.entries方法获取map中的值;具体方法如下:使用Object方法获取map中的key和value值<template...
    99+
    2022-10-21
  • vue中如何获取input的值
    在vue中获取input值的方法:1.新建html项目,引入vue;2.定义input输入框,设置v-model样式;3.绑定变量和按钮;具体步骤如下:首先,新建一个html项目,并在项目中引入vue;<!DOCTYPE h...
    99+
    2022-10-16
  • jquery如何获取radio选中的值
    使用jquery获取radio选中值的方法:1.新建html项目,引入jquery;2.创建input单选框;3.添加button按钮,绑定onclick点击事件;4.通过checked选择器获取对象,使用val()方法获取radio选中的...
    99+
    2022-10-17
  • java中如何获取map的key值
    在Java中,可以使用`Map`的`keySet()`方法获取`Map`的所有key值。`keySet()`方法返回一个`Set`集...
    99+
    2023-08-31
    java
  • qt如何获取QString中的数值
    要获取 QString 中的数值,可以使用 QString 的 toInt()、toDouble()、toFloat() 等成员函数...
    99+
    2023-08-12
    qt QString
  • @PathVariable获取路径中带有 / 斜杠的解决方案
    @PathVariable获取路径中带“/”斜杠 问题 访问路径 http://192.168.10.243:1018/hpt/v2/photo/link/2021/7/headi...
    99+
    2022-11-12
  • Vue.js如何获取data-*的值
    目录data-*获取普通数据静态获取动态获取获取对象数据动态获取data-* 这个属性熟悉JS的小伙伴都知道,data-*是一个自定义属性,它的功能是视图层往js传递我们想要传的数据...
    99+
    2022-11-13
  • java如何获取map的值
    在Java中,可以使用`get()`方法从`Map`对象中获取键对应的值。具体语法如下:```javaMap map = new H...
    99+
    2023-09-11
    java
  • jquery如何获取textarea的值
    使用jquery获取textarea值的方法:1.新建html项目,引入jquery;2.使用textarea标签创建文本域,设置id属性;3.添加button按钮,绑定onclick点击事件;4.通过id获取textarea对象,使用te...
    99+
    2022-10-16
  • jquery如何获取input的值
    使用jquery获取input值的方法:1.新建html项目,引入jquery;2.添加input输入框,设置id属性;3.通过id属性获取input对象;4.使用val()方法获取input的值;具体步骤如下:首先,新建一个html项目,...
    99+
    2022-10-19
  • jquery如何获取label的值
    在jQuery中,可以通过以下方法获取label的值:1. 使用label元素的for属性和jQuery的选择器来获取label的值...
    99+
    2023-08-21
    jquery
  • jquery如何获取radio的值
    您可以使用以下代码来获取选中的radio按钮的值:```javascript// 通过name获取选中的radio按钮的值var v...
    99+
    2023-08-11
    jquery radio
  • jquery如何获取class的值
    本文小编为大家详细介绍“jquery如何获取class的值”,内容详细,步骤清晰,细节处理妥当,希望这篇“jquery如何获取class的值”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。获取class的值获取cl...
    99+
    2023-07-06
  • SpringMVC中请求参数的获取方式
    目录SpringMVC请求参数获取方式一、通过 ServletAPI 获取二、通过控制器方法的形参获取处理多个同名的请求参数三、通过 @RequestParam 注解四、@Reque...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作