springboot接收from-data参数为空解决办法。

有时候我们传的参数很大,比如图片转成的base64字符,如果普通传参肯定会报错,可以把这种参数放在from-data的body里面,我们JAVA后台需要接收from-data的参数。

public ReturnModel fromDateTest(HttpServletRequest request){
        ReturnModel returnModel = new ReturnModel();
        JSONObject jsonObject = new JSONObject();
        DiskFileItemFactory factory = new DiskFileItemFactory();
        ServletFileUpload upload = new ServletFileUpload(factory);
        List<FileItem> items = null;
        try {
            items = upload.parseRequest(new ServletRequestContext(request));
        } catch (FileUploadException e) {
            returnModel.setCode(1);
            returnModel.setMessage("上传失败");
            e.printStackTrace();
        }
        for(int i=0;i<items.size();i++)
        {
            String fileName = items.get(i).getFieldName();
            String fileValue =  items.get(i).getString();
            jsonObject.put(fileName, fileValue);
        }
        
        returnModel.setCode(0);
        returnModel.setMessage("上传成功");
        returnModel.setBody("");
        return returnModel;
    }

正常这样子是可以接收到的。
但是实际情况是这样子的。
在这里插入图片描述
在这里插入图片描述
很明显,request里面是有值的,但是为什么我们获取不到呢?
后来查看了一些资料才知道使用Apache Commons FileUpload组件上传文件时总是返回null,调试发现ServletFileUpload对象为空,在Spring Boot中有默认的文件上传组件,在使用ServletFileUpload时需要关闭Spring Boot的默认配置 ,禁用MultipartResolverSpring提供的默认值,在配置文件中加入

spring.http.multipart.enabled=false

然后试了一下
在这里插入图片描述
就可以获取到了。
下面在贴一下发送from-data请求的代码:

@SuppressWarnings("rawtypes")
    public static String formUpload(String urlStr, Map<String, String> textMap) {
        String res = "";
        HttpURLConnection conn = null;
        textMap.put("keyId","111");
        textMap.put("photo","222");
        // boundary就是request头和上传文件内容的分隔符
        String BOUNDARY = "---------------------------123821742118716";
        try {
            URL url = new URL(urlStr);
            conn = (HttpURLConnection) url.openConnection();
            conn.setConnectTimeout(5000);
            conn.setReadTimeout(30000);
            conn.setDoOutput(true);
            conn.setDoInput(true);
            conn.setUseCaches(false);
            conn.setRequestMethod("POST");
            conn.setRequestProperty("Connection", "Keep-Alive");
            // conn.setRequestProperty("User-Agent","Mozilla/5.0 (Windows; U; Windows NT 6.1; zh-CN; rv:1.9.2.6)");
            conn.setRequestProperty("Content-Type","multipart/form-data; boundary=" + BOUNDARY);
            OutputStream out = new DataOutputStream(conn.getOutputStream());
            // text
            if (textMap != null) {
                StringBuffer strBuf = new StringBuffer();
                Iterator iter = textMap.entrySet().iterator();
                while (iter.hasNext()) {
                    Map.Entry entry = (Map.Entry) iter.next();
                    String inputName = (String) entry.getKey();
                    String inputValue = (String) entry.getValue();
                    if (inputValue == null) {
                        continue;
                    }
                    strBuf.append("\r\n").append("--").append(BOUNDARY).append("\r\n");
                    strBuf.append("Content-Disposition: form-data; name=\"" + inputName + "\"\r\n\r\n");
                    strBuf.append(inputValue);
                }
                out.write(strBuf.toString().getBytes());
            }
            byte[] endData = ("\r\n--" + BOUNDARY + "--\r\n").getBytes();
            out.write(endData);
            out.flush();
            out.close();
            // 读取返回数据
            StringBuffer strBuf = new StringBuffer();
            BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
            String line = null;
            while ((line = reader.readLine()) != null) {
                strBuf.append(line).append("\n");
            }
            res = strBuf.toString();
            reader.close();
            reader = null;
        } catch (Exception e) {
            System.out.println("发送POST请求出错。" + urlStr);
            e.printStackTrace();
        } finally {
            if (conn != null) {
                conn.disconnect();
                conn = null;
            }
        }
        return res;
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您好,关于SpringBoot和MyBatis-Plus的批量删除前后端代码,我可以为您提供一些信息。 首先,您需要在后端编写一个接口来处理批量删除的请求。可以使用MyBatis-Plus提供的批量删除方法来实现这一点。例如: ```java List<Integer> idList = Arrays.asList(1, 2, 3); int deleteCount = myService.removeByIds(idList); ``` 在前端,您需要创建一个表格或列表来显示需要删除的数据,并提供一个按钮来触发批量删除请求。可以使用JavaScript框架(如jQuery)来捕获用户点击事件并向后端发送请求。例如: ```javascript $('#deleteButton').click(function() { var idList = []; $('input[name="id"]:checked').each(function() { idList.push($(this).val()); }); $.ajax({ url: '/my-api/batch-delete', method: 'POST', data: { idList: idList }, success: function(response) { alert(response.message); }, error: function(jqXHR, textStatus, errorThrown) { alert('Error: ' + textStatus + ' - ' + errorThrown); } }); }); ``` 这里假设您的后端接口是`/my-api/batch-delete`,并且需要从前端接收一个名为`idList`的数组参数。 希望这些信息能对您有所帮助。如果您需要更具体的代码示例或其他方面的帮助,请随时提出。 ### 回答2: Spring Boot是一种用于创建基于Java的独立的、生产级别的应用程序的框架。MyBatis-Plus是一个建立在MyBatis之上的增强工具,提供了更多的功能和便利性。要批量删除前后端代码,可以按照以下步骤进行操作。 首先,确保你已经配置好了Spring Boot和MyBatis-Plus的环境,并且已经建立了数据库表和实体类。 一、前端代码删除 1. 打开前端代码所在的项目,找到要删除的文件或文件夹。 2. 右键点击选择“删除”或使用命令行删除相应文件。 3. 如果需要,可以在版本控制系统中提交并推送这些删除的更改。 二、后端代码删除 1. 打开后端代码所在的项目,找到要删除的文件或文件夹。 2. 右键点击选择“删除”或使用命令行删除相应文件。 3. 如果需要,可以在版本控制系统中提交并推送这些删除的更改。 三、数据库删除 1. 打开数据库管理工具,连接到你的数据库。 2. 找到与要删除的文件或文件夹对应的数据库表。 3. 使用SQL语句执行批量删除操作,例如:DELETE FROM 表名 WHERE 条件。 4. 如果需要,可以在数据库管理工具中提交和保存这些更改。 以上就是使用Spring Boot和MyBatis-Plus批量删除前后端代码的步骤。确保在删除代码之前备份相关文件和数据库,以防止数据丢失或无法恢复。同时,要小心地进行删除操作,确保不会删除错误的文件或数据。 ### 回答3: 如果要在Spring Boot中使用MyBatis-Plus进行批量删除操作,你需要完成以下几个步骤: 1. 首先,确保已经引入了Spring Boot和MyBatis-Plus的依赖包。可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>${mybatis-plus.version}</version> </dependency> ``` 2. 定义一个实体类,表示要进行删除操作的数据表。可以使用注解@Table和@Id来指定对应的表名和主键字段。例如: ```java @Table("user") public class User { @Id private Long id; private String name; private Integer age; // 省略getter和setter方法 } ``` 3. 创建一个Mapper接口,使用MyBatis-Plus的注解来定义要进行的删除操作。例如,可以使用@Delete注解和@Param注解来指定要删除的条件: ```java public interface UserMapper extends BaseMapper<User> { @Delete("delete from user where age > #{minAge} and age < #{maxAge}") int deleteByAgeRange(@Param("minAge") Integer minAge, @Param("maxAge") Integer maxAge); } ``` 4. 在服务层(Service)中调用Mapper接口的方法来进行删除操作。例如,可以直接调用deleteByAgeRange方法来删除满足条件的数据: ```java @Service public class UserService { @Autowired private UserMapper userMapper; public void deleteByAgeRange(Integer minAge, Integer maxAge) { int result = userMapper.deleteByAgeRange(minAge, maxAge); // 处理删除操作的结果 } } ``` 5. 最后,在控制器层(Controller)中处理请求,并调用相应的服务层方法来完成批量删除操作。例如,可以定义一个RESTful接口来接收前端发送的删除请求: ```java @RestController public class UserController { @Autowired private UserService userService; @DeleteMapping("/users") public void deleteUsers(@RequestParam("minAge") Integer minAge, @RequestParam("maxAge") Integer maxAge) { userService.deleteByAgeRange(minAge, maxAge); // 返回删除结果或其他响应 } } ``` 以上就是使用Spring Boot和MyBatis-Plus进行批量删除操作的基本步骤。通过定义实体类、Mapper接口和服务层方法,再结合控制器层对前端请求的处理,可以方便地实现批量删除功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值