jsp中文件上传的实现

jsp中文件上传的实现

表单设置:<input type="file">

需注意的是:
服务器获取请求参数不能向普通表单项那样通过request.getParameter(“name”)方式获取,而是需要通过fileUpload.parseRequest(req)获取,该方法返回值是list,需进行遍历,对每一项进行判断是普通表单项还是上传文件表单项。当是普通项通过map.put(fileItem.getFieldName(),fileItem.getString())提交给服务器,若是上传文件表单项需先通过 fileItem.write(file),再调用map.put(“pic”,pathname)方法。

关于fileUpload的详细介绍通过commons-fileupload包查看深层源代码。

fileUpload的使用需导包:servletUpload

  • 在项目WEB-INF中lib中添加

  • 在编译器中添加

在这里插入图片描述
在这里插入图片描述
具体实现代码如下:

private Map<String, String> getParameterMap(HttpServletRequest req) {
        DiskFileItemFactory diskFileItemFactory = new DiskFileItemFactory();
        FileUpload fileUpload = new FileUpload(diskFileItemFactory);


        Map<String,String> map = new HashMap<>();
        try {
            List<FileItem> list = fileUpload.parseRequest(req);
           
            for (FileItem fileItem : list) {

                if (fileItem.isFormField()){//判断是否是普通表单项
                    map.put(fileItem.getFieldName(),fileItem.getString());

                }else{//是   文件上传的表单项,  处理 上传文件,将   上传文件   保存到服务器的硬盘中

                    String path = this.getServletContext().getRealPath("/")+"upload"+ File.separator;
                    String fileName = UUID.randomUUID().toString();//避免同名覆盖
                    String suffix = fileItem.getName().substring(fileItem.getName().lastIndexOf('.'));

                    //TODO  验证大小,类型  等
                    System.out.println(path+fileName+suffix);
                    File file = new File(path+fileName+suffix);
                    fileItem.write(file);

                    //将路径  存储到   map,以便再存到数据库里
                    map.put("pic","/upload/"+fileName+suffix);
                }


            }

        } catch (FileUploadException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return map;
    }
}

在StudentServlet的post请求中add方法:

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        String action = req.getParameter("a");

        resp.setContentType("text/html;chartset=utf-8");
        req.setCharacterEncoding("utf-8");
        resp.setCharacterEncoding("utf-8");

        switch (action){
            case "add":

                //添加文件上传后,编码格式发生了变化,不能用getParamerter获取参数
               /* String name = req.getParameter("name");
                int age = Integer.parseInt(req.getParameter("age"));
                int gender = Integer.parseInt(req.getParameter("gender"));
                String tel = req.getParameter("tel");
                int class_id = Integer.parseInt(req.getParameter("class_id"));

                Student student = new Student(name,age,gender,tel,class_id);*/

                Map<String, String> map = getParameterMap(req);

                Student student = new Student(map.get("name"),new Integer(map.get("age")),new Integer(map.get("gender")),map.get("tel"),new Integer(map.get("class_id")),map.get("pic"));


                //调用业务层
                boolean flag = ssi.add(student);

                if(flag){
                    String path = req.getRequestURI()+"?a=look";
                    resp.sendRedirect(path);
                }else{
                    resp.getWriter().print("<script>alert('error');history.back();</script>");
                }

                break;


在添加文件上传后form表单编码发生变化,需在.jsp文件表单标签中设置enctype=“multipart/form-data”:

<form class="form-horizontal col-md-12" id="fm" action="<%=contextPath%>/stu?a=add" method="post" enctype="multipart/form-data">

文件上传表单类型设置为file:

 <input type="file" name="pic" class="form-control" id="pic" placeholder="照片">

附原理图如下:在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本代码主要应用的是jsp技术,而实现文件上传功能,这个功能也是比较常见的,也是比较常用的,更是在网络比较流行的。 技术为创建显示动态生成内容的Web页面提供了一个简捷而快速的方法。JSP技术的设计目的是使得构造基于Web的应用程序更加容易和快捷,而这些应用程序能够与各种Web服务器,应用服务器,浏览器和开发工具共同工作。 Web应用开发的JavaServer Pages技术方法 在开发JSP规范的过程,太阳微系统公司(Sun Microsystems Inc.)与许许多多主要的Web服务器、应用服务器和开发工具供应商,以及各种各样富有经验的开发团体进行合作。其结果是找到了一种为应用和页面开发人员平衡了可移植性和易用性的开发方法。 JSP技术在多个方面加速了动态Web页面的开发: 将内容的生成和显示进行分离 使用JSP技术,Web页面开发人员可以使用HTML或者XML标识来设计和格式化最终页面。使用JSP标识或者小脚本来生成页面上的动态内容(内容是根据请求来变化的,例如请求帐户信息或者特定的一瓶酒的价格)。生成内容的逻辑被封装在标识和JavaBeans组件,并且捆绑在小脚本,所有的脚本在服务器端运行。如果核心逻辑被封装在标识和Beans,那么其他人,如Web管理人员和页面设计者,能够编辑和使用JSP页面,而不影响内容的生成。 在服务器端,JSP引擎解释JSP标识和小脚本,生成所请求的内容(例如,通过访问JavaBeans组件,使用JDBCTM技术访问数据库,或者包含文件),并且将结果以HTML(或者XML)页面的形式发送回浏览器。这有助于作者保护自己的代码,而又保证任何基于HTML的Web浏览器的完全可用性。 强调可重用的组件 绝大多数JSP页面依赖于可重用的,跨平台的组件(JavaBeans或者Enterprise JavaBeansTM组件)来执行应用程序所要求的更为复杂的处理。开发人员能够共享和交换执行普通操作的组件,或者使得这些组件为更多的使用者或者客户团体所使用。基于组件的方法加速了总体开发过程,并且使得各种组织在他们现有的技能和优化结果的开发努力得到平衡。 采用标识简化页面开发 Web页面开发人员不会都是熟悉脚本语言的编程人员。JavaServer Page技术封装了许多功能,这些功能是在易用的、与JSP相关的XML标识进行动态内容生成所需要的。标准的JSP标识能够访问和实例化JavaBeans组件,设置或者检索组件属性,下载Applet,以及执行用其他方法更难于编码和耗时的功能。 通过开发定制化标识库,JSP技术是可以扩展的。今后,第三方开发人员和其他人员可以为常用功能创建自己的标识库。这使得Web页面开发人员能够使用熟悉的工具和如同标识一样的执行特定功能的构件来工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值