SpringMVC上传文件三种方式对比

本文对比了SpringMVC中的三种文件上传方法:通过流的方式上传、使用file.transferTo保存文件以及利用SpringMVC提供的类进行上传。通过运行时间等关键指标分析了不同方法的优劣。

springmvc三种上传方式对比:
前端页面:

<form action="${pageContext.request.contextPath}/Upload/fileUpload1.action" method="post" enctype="multipart/form-data">
文件:<input type="file"  name="file">
<input type="submit" value="提交方法一">
</form>
<form action="${pageContext.request.contextPath}/Upload/fileUpload2.action" method="post" enctype="multipart/form-data">
文件:<input type="file"  name="file1">
<input type="submit" value="提交方法二">
</form>
<form action="${pageContext.request.contextPath}/Upload/springUpload.action" method="post" enctype="multipart/form-data">
文件:<input type="file"  name="file">
<input type="submit" value="提交方法三">

配置都是一样的:

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <property name="defaultEncoding" value="UTF-8"/>
        <property name="maxUploadSize" value="10485760000"></property>  
        <property name="maxInMemorySize" value="40960"></property>  
        <property name="uploadTempDir" value="fileUpload"></property>
</bean>

方法一(通过流的方式上传文件):
通过流的方式上传文件
@RequestParam(“file”) 将name=file控件得到的文件封装成CommonsMultipartFile 对象

@RequestMapping("fileUpload1")
    public String  fileUpload(@RequestParam("file") CommonsMultipartFile file,HttpServletRequest request) throws IOException {
        //用来检测程序运行时间
        long  startTime=System.currentTimeMillis();
        System.out.println("fileName:"+file.getOriginalFilename());

        try {
            //获取输出流
            OutputStream os=new FileOutputStream(request.getSession().getServletContext().getRealPath("/") + "fileUpload/"+file.getOriginalFilename());
            //获取输入流 CommonsMultipartFile 中可以直接得到文件的流
            InputStream is=file.getInputStream();
            int temp;
            //一个一个字节的读取并写入
            while((temp=is.read())!=(-1))
            {
                os.write(temp);
            }
           os.flush();
           os.close();
           is.close();

        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
        long  endTime=System.currentTimeMillis();
        System.out.println("方法一的运行时间:"+String.valueOf(endTime-startTime)+"ms");
        return "/return.jsp"; 
    }

方法二:
采用file.Transto 来保存上传的文件

@RequestMapping("fileUpload2")
    public ModelAndView importExcel(@RequestParam("file1") MultipartFile file, HttpServletRequest request){
        long  startTime=System.currentTimeMillis();
        ModelAndView modelAndView = new ModelAndView();
        // 判断文件是否为空  
        if (!file.isEmpty()) {  
            // 文件保存路径  
            String filePath = request.getSession().getServletContext().getRealPath("/") + "fileUpload/"  
                    + file.getOriginalFilename();  
            // 转存文件  
            try {
                file.transferTo(new File(filePath));
                modelAndView.setViewName("/return.jsp");
                modelAndView.addObject("result", file.getOriginalFilename()+"上传成功");
            } catch (Exception e) {
                modelAndView.addObject("result", file.getOriginalFilename()+"上传失败");
                e.printStackTrace();
            } 
        }
        long  endTime=System.currentTimeMillis();
        System.out.println("方法二的运行时间:"+String.valueOf(endTime-startTime)+"ms");
        return modelAndView;
    }

方法三:
使用spring mvc提供的类的方法上传文件

@RequestMapping("springUpload")
    public ModelAndView  springUpload(HttpServletRequest request) throws IllegalStateException, IOException
    {
        ModelAndView modelAndView = new ModelAndView();

        long  startTime=System.currentTimeMillis();
         //将当前上下文初始化给  CommonsMutipartResolver (多部分解析器)
        CommonsMultipartResolver multipartResolver=new CommonsMultipartResolver(
                request.getSession().getServletContext());
        //检查form中是否有enctype="multipart/form-data"
        if(multipartResolver.isMultipart(request))
        {
            //将request变成多部分request
            MultipartHttpServletRequest multiRequest=(MultipartHttpServletRequest)request;
           //获取multiRequest 中所有的文件名
            Iterator iter=multiRequest.getFileNames();

            while(iter.hasNext())
            {
                //一次遍历所有文件
                MultipartFile file=multiRequest.getFile(iter.next().toString());
                if(file!=null)
                {
                    String path=request.getSession().getServletContext().getRealPath("/") + "fileUpload/"+file.getOriginalFilename();
                    //上传
                    file.transferTo(new File(path));
                    modelAndView.addObject("result", file.getOriginalFilename()+"上传成功");
                }

            }

        }
        long  endTime=System.currentTimeMillis();

        System.out.println("方法三的运行时间:"+String.valueOf(endTime-startTime)+"ms");
        modelAndView.setViewName("/return.jsp");
        return modelAndView; 
    }

第一种通过流的方式上传文件太慢,尽量使用第二或第三种方式。

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值