前端传递参数后端发生变化,但后端未做过特殊处理。

1.问题描述

        前端传递1+2+3,后端对象中存的值变成了1 2 3,修改传递的参数值为其他,发现并没有问题。

2.前端代码:
# 异常
var name'1+2+3';
var url = "${ctx}/login?name="+name;

# 正常
var name'system';
var url = "${ctx}/login?name="+name;

# 正常
var name'admin==';
var url = "${ctx}/login?name="+name;
3.后端代码:
// Controller
@RequestMapping(value = "login")
public String test(Query query, Model model) {
        return "modules/index";
}


// 实体类
@Data
public class Query implements Serializable {
    private String name;
}
4.解决方案:

        使用 JavaScript 中的 encodeURIComponent() 函数来对参数进行编码,以确保它们在 URL 中正确传递。

var name'1+2+3';
name = encodeURIComponent(name);
var url = "${ctx}/login?name="+name;

处理前端表单数据传递到后端通常涉及以下几个步骤: 1. **HTML 表单提交**: 在HTML中,使用`<form>`标签将表单数据封装起来。设置`action`属性为后端API的URL,`method`属性为"POST"(对于提交新的数据)或"PUT/PATCH"(如果更新已有数据),同时设置`enctype`为"application/x-www-form-urlencoded" 或 "multipart/form-data" 根据表单是否含有文件上传。 ```html <form action="/api/register" method="post" enctype="application/x-www-form-urlencoded"> <input type="text" name="username" /> <input type="password" name="password" /> <!-- 其他字段... --> <button type="submit">注册</button> </form> ``` 2. **发送数据**: 使用JavaScript的`fetch()`或`axios`等库发起HTTP请求。当用户点击提交按钮时,获取表单内的值,然后将其作为`FormData`对象或直接作为查询字符串(`application/x-www-form-urlencoded`)发送到服务器。 ```javascript const form = document.querySelector('form'); form.addEventListener('submit', (event) => { event.preventDefault(); // 防止默认提交行为 const formData = new FormData(form); // 对于包含文件的表单 // 或者 formData.append('username', document.querySelector('#username').value); fetch('/api/register', { method: 'POST', body: formData, headers: { 'Content-Type': 'multipart/form-data' } // 或者 application/x-www-form-urlencoded }) .then(response => response.json()) .then(data => console.log(data)); // 处理服务器响应 }); ``` 3. **后端接收数据**: 在Spring Boot的控制器中,使用`@PostMapping`来处理接收到的POST请求。可以使用`org.springframework.web.bind.annotation.RequestParam`或`org.springframework.web.bind.annotation.FormHttpBinding`来映射前端传来的数据。 ```java @PostMapping("/register") public ResponseEntity<?> register(@RequestParam("username") String username, @RequestParam("password") String password) { // 这里的用户名和密码是前端POST过来的 } ``` **相关问题--:** 1. 如何在Spring Boot中验证接收到的表单数据? 2. 如果表单数据需要加密,如何在前端后端分别处理? 3. 如何处理前端Ajax请求失败的情况?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值