接口入参特殊符号被转义处理办法

博客讨论了一种前后端交互时遇到的特殊字符转义问题。原先使用form-data格式传递参数,因服务端框架拦截器导致参数被转义。解决方案包括:服务端针对特殊字符字段做解码处理,或者将参数改为JSON格式通过@RequestBody接收,避免转义。这两种方法分别有其适用场景和改造成本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文章备忘。后边研究透了来填坑,先写背景和解决方案。

背景:

原业务功能接口入参比较简单,所以使用的是 form-data格式作为入参。对业务做了扩展之后,入参的业务场景中有特殊符号,结果会查不到数据,经检查,是到服务端之后,被转义。

初步定位:

经过多方面排查,框架上有拦截器做了处理,请求头 使用的是:x-www-form-urlencoded ,所以到服务端之后,所以form-data的入参被转义了。
因为入参是form-data,前端vue使用 encodeURIComponent(uri) 处理的时候,也不行(可能是我使用的问题,如果有知道正确使用的,欢迎留言交流哈)

解决办法:

简化后的代码:

    @ResponseBody
    @RequestMapping("list")
    public DemoRes list(@RequestParam(defaultValue = "1") int pageNumber,
                        @RequestParam(defaultValue = "20") int pageSize,
                        @RequestParam(name = "code", required = false) String code,
                        @RequestParam(name = "mame", required = false) String mame,
                        @RequestParam(name = "desc", required = false) String desc,
                        @RequestParam(name = "methodName", required = false) String methodName,
                        @RequestParam(name = "status", required = false) String status) {
        log.info("入参,{},{}", methodName, code);
        // ....业务逻辑部分
        return null;
    }

很简单,原接口只有页码 和 页数,后对接口拓展,为了改造最小化,没有调整对应的请求方式

方案一。

服务端针对包含特殊字符的字段处理,这样不治本。但是有效

代码如下:

    @ResponseBody
    @RequestMapping("list")
    public DemoRes list(@RequestParam(defaultValue = "1") int pageNumber,
                        @RequestParam(defaultValue = "20") int pageSize,
                        @RequestParam(name = "code", required = false) String code,
                        @RequestParam(name = "mame", required = false) String mame,
                        @RequestParam(name = "desc", required = false) String desc,
                        @RequestParam(name = "methodName", required = false) String methodName,
                        @RequestParam(name = "status", required = false) String status) {
        log.info("入参,{},{}", methodName, code);
        if (StringUtils.isNotBlank(methodName)){
            methodName= StringEscapeUtils.unescapeHtml4(methodName);
        }
        // ....业务逻辑部分
        return null;
    }

方案二。

改动多,需要前端和服务端同时调整,但是解决比较彻底。那就是把包含特殊字符的入参放到实体里边,请求入参方式改成 applicaiton/json

改造后的代码如下:

    @ResponseBody
    @RequestMapping("list")
    public DemoRes list(@RequestParam(defaultValue = "1") int pageNumber,
                        @RequestParam(defaultValue = "20") int pageSize,
                        @RequestBody DemoReq request) {
        // ....业务逻辑部分
        return null;
    }

    @Data
    public static class DemoRes implements Serializable {
        private String name;
    }

    @Data
    public static class DemoReq implements Serializable {
        private String code;
        private String mame;
        private String desc;
        private String methodName;
        private String status;

    }

这样入参中包含特殊字符也不会被转义。

以上是针对问题的解决办法,只知修复未知原因,还需深挖,暂留坑备忘,便于日后本人时间充裕,细细钻研其中奥义再来补充。

智能网联汽车的安全员高级考试涉及多个方面的专业知识,包括但不限于自动驾驶技术原理、车辆传感器融合、网络安全防护以及法律法规等内容。以下是针对该主题的一些核心知识点解析: ### 关于智能网联车安全员高级考试的核心内容 #### 1. 自动驾驶分级标准 国际自动机工程师学会(SAE International)定义了六个级别的自动驾驶等级,从L0到L5[^1]。其中,L3及以上级别需要安全员具备更高的应急处理能力。 #### 2. 车辆感知系统的组成与功能 智能网联车通常配备多种传感器,如激光雷达、毫米波雷达、摄像头和超声波传感器等。这些设备协同工作以实现环境感知、障碍物检测等功能[^2]。 #### 3. 数据通信与网络安全 智能网联车依赖V2X(Vehicle-to-Everything)技术进行数据交换,在此过程中需防范潜在的网络攻击风险,例如中间人攻击或恶意软件侵[^3]。 #### 4. 法律法规要求 不同国家和地区对于无人驾驶测试及运营有着严格的规定,考生应熟悉当地交通法典中有关自动化驾驶部分的具体条款[^4]。 ```python # 示例代码:模拟简单决策逻辑 def decide_action(sensor_data): if sensor_data['obstacle'] and not sensor_data['emergency']: return 'slow_down' elif sensor_data['pedestrian_crossing']: return 'stop_and_yield' else: return 'continue_driving' example_input = {'obstacle': True, 'emergency': False, 'pedestrian_crossing': False} action = decide_action(example_input) print(f"Action to take: {action}") ``` 需要注意的是,“橙点同学”作为特定平台上的学习资源名称,并不提供官方认证的标准答案集;建议通过正规渠道获取教材并加培训课程来准备此类资格认证考试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值