• Servlet系列教材 (十二)- 基础


     

    步骤1:先运行,看到效果,再学习
    步骤2:模仿和排错
    步骤3:首先准备上传页面 upload.html
    步骤4:接着准备 UploadPhotoServlet
    步骤5:配置web.xml
    步骤6:复制jar包
    步骤7:在项目中导入jar包
    步骤8:上传测试
    步骤9:如何处理其他非File字段

    步骤 1 : 先运行,看到效果,再学习

    老规矩,先下载下载区(点击进入)的可运行项目,配置运行起来,确认可用之后,再学习做了哪些步骤以达到这样的效果。

    步骤 2 : 模仿和排错

    在确保可运行项目能够正确无误地运行之后,再严格照着教程的步骤,对代码模仿一遍。 
    模仿过程难免代码有出入,导致无法得到期望的运行结果,此时此刻通过比较正确答案 ( 可运行项目 ) 和自己的代码,来定位问题所在。 
    采用这种方式,学习有效果,排错有效率,可以较为明显地提升学习速度,跨过学习路上的各个槛。 

    推荐使用diffmerge软件,进行文件夹比较。把你自己做的项目文件夹,和我的可运行项目文件夹进行比较。 
    这个软件很牛逼的,可以知道文件夹里哪两个文件不对,并且很明显地标记出来 
    这里提供了绿色安装和使用教程:diffmerge 下载和使用教程

    步骤 3 : 首先准备上传页面 upload.html

    上传页面有两点需要注意
    1. form 的method必须是post的,get不能上传文件。 还需要加上enctype="multipart/form-data" 表示提交的数据是二进制文件

    <form action="uploadPhoto" method="post" enctype="multipart/form-data">


    2. 需要提供type="file" 的字段进行上传

    <!DOCTYPE html>

    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

    <form action="uploadPhoto" method="post" enctype="multipart/form-data">

      英雄名称:<input type="text" name="heroName" /> <br

      上传头像 : <input type="file" name="filepath" /> <br

      <input type="submit" value="上传">

    </form>

    步骤 4 : 接着准备 UploadPhotoServlet

    在UploadPhotoServlet进行上传的功能开发。
    1. 需要用到两个第三方的jar包,commons-io-1.4.jarcommons-fileupload-1.2.2.jar。 在右侧下载,并放在WEB-INF/lib下

    2. 前部分代码是固定写法,用来做一些准备工作。 直到遍历出Item,一个Item就是对应一个浏览器提交的数据,通过item.getInputStream可以打开浏览器上传的文件的输入流。

    3. 客户提交的文件名有可能是一样的,所以在服务端保存文件的时候,不能使用客户提交的文件名。这里使用的是一种粗糙的解决文件名重复的办法,即使用时间戳。 

    4. 读取输入流中的数据,保存在服务端的目录下 e:/project/j2ee/web/uploaded,这个目录是通过getRealPath获取到的。 如果项目部署在其他地方,那么会自动做相应的变化。
    注: 为什么要放这里? 因为后续网页上显示的时候是通过http://127.0.0.1/uploaded/xxx.jpg 路径来获取图片。


    5. 根据临时生成的文件名,创建一个html img元素,然后通过response返回浏览器

    接着准备 UploadPhotoServlet

    import java.io.File;

    import java.io.FileNotFoundException;

    import java.io.FileOutputStream;

    import java.io.InputStream;

    import java.io.PrintWriter;

    import java.util.Iterator;

    import java.util.List;

      

    import javax.servlet.ServletException;

    import javax.servlet.http.HttpServlet;

    import javax.servlet.http.HttpServletRequest;

    import javax.servlet.http.HttpServletResponse;

      

    import org.apache.commons.fileupload.FileItem;

    import org.apache.commons.fileupload.FileUploadException;

    import org.apache.commons.fileupload.disk.DiskFileItemFactory;

    import org.apache.commons.fileupload.servlet.ServletFileUpload;

      

    public class UploadPhotoServlet extends HttpServlet {

      

        public void doPost(HttpServletRequest request, HttpServletResponse response) {

      

            String filename = null;

            try {

                DiskFileItemFactory factory = new DiskFileItemFactory();

                ServletFileUpload upload = new ServletFileUpload(factory);

                // 设置上传文件的大小限制为1M

                factory.setSizeThreshold(1024 1024);

                 

                List items = null;

                try {

                    items = upload.parseRequest(request);

                catch (FileUploadException e) {

                    e.printStackTrace();

                }

      

                Iterator iter = items.iterator();

                while (iter.hasNext()) {

                    FileItem item = (FileItem) iter.next();

                    if (!item.isFormField()) {

      

                        // 根据时间戳创建头像文件

                        filename = System.currentTimeMillis() + ".jpg";

                         

                        //通过getRealPath获取上传文件夹,如果项目在e:/project/j2ee/web,那么就会自动获取到 e:/project/j2ee/web/uploaded

                        String photoFolder =request.getServletContext().getRealPath("uploaded");

                         

                        File f = new File(photoFolder, filename);

                        f.getParentFile().mkdirs();

      

                        // 通过item.getInputStream()获取浏览器上传的文件的输入流

                        InputStream is = item.getInputStream();

      

                        // 复制文件

                        FileOutputStream fos = new FileOutputStream(f);

                        byte b[] = new byte[1024 1024];

                        int length = 0;

                        while (-1 != (length = is.read(b))) {

                            fos.write(b, 0, length);

                        }

                        fos.close();

      

                    else {

                        System.out.println(item.getFieldName());

                        String value = item.getString();

                        value = new String(value.getBytes("ISO-8859-1"), "UTF-8");

                        System.out.println(value);

                    }

                }

                 

                String html = "<img width='200' height='150' src='uploaded/%s' />";

                response.setContentType("text/html");

                PrintWriter pw= response.getWriter();

                 

                pw.format(html, filename);

                 

            catch (FileNotFoundException e) {

                // TODO Auto-generated catch block

                e.printStackTrace();

            catch (Exception e) {

                // TODO Auto-generated catch block

                e.printStackTrace();

            }

        }

    }

    步骤 5 : 配置web.xml

    配置UploadPhotoServlet

    <servlet>

        <servlet-name>UploadPhotoServlet</servlet-name>

        <servlet-class>UploadPhotoServlet</servlet-class>

    </servlet>

    <servlet-mapping>

        <servlet-name>UploadPhotoServlet</servlet-name>

        <url-pattern>/uploadPhoto</url-pattern>

    </servlet-mapping>    

    步骤 6 : 复制jar包

    再强调一遍:把右侧的两个jar包commons-io-1.4.jar,commons-fileupload-1.2.2.jar 复制到WEB-INF/lib 目录下

    复制jar包

    步骤 7 : 在项目中导入jar包

    把jar包导入到项目中,导包办法:右键 project->properties->java build path->libaries->add external jars

    步骤 8 : 上传测试

    重启tomcat, 打开页面进行上传

    http://127.0.0.1/upload.html


    选中某个图片点击上传,就可以看到上传的图片了

    上传测试

    步骤 9 : 如何处理其他非File字段

    因为浏览器指定了以二进制的形式提交数据,那么就不能通过常规的手段获取非File字段:

    request.getParameter("heroName")



    在遍历Item时(Item即对应浏览器提交的字段),可以通过

    item.isFormField


    来判断是否是常规字段还是提交的文件。 当item.isFormField返回true的时候,就表示是常规字段。

    然后通过item.getFieldName()和item.getString()就知道分别是哪个字段,以及字段的值了。

    如何处理其他非File字段

    import java.io.File;

    import java.io.FileNotFoundException;

    import java.io.FileOutputStream;

    import java.io.InputStream;

    import java.io.PrintWriter;

    import java.util.Iterator;

    import java.util.List;

      

    import javax.servlet.ServletException;

    import javax.servlet.http.HttpServlet;

    import javax.servlet.http.HttpServletRequest;

    import javax.servlet.http.HttpServletResponse;

      

    import org.apache.commons.fileupload.FileItem;

    import org.apache.commons.fileupload.FileUploadException;

    import org.apache.commons.fileupload.disk.DiskFileItemFactory;

    import org.apache.commons.fileupload.servlet.ServletFileUpload;

      

    public class UploadPhotoServlet extends HttpServlet {

      

        public void doPost(HttpServletRequest request, HttpServletResponse response) {

      

            String filename = null;

            try {

                DiskFileItemFactory factory = new DiskFileItemFactory();

                ServletFileUpload upload = new ServletFileUpload(factory);

                // 设置上传文件的大小限制为1M

                factory.setSizeThreshold(1024 1024);

                 

                List items = null;

                try {

                    items = upload.parseRequest(request);

                catch (FileUploadException e) {

                    e.printStackTrace();

                }

      

                Iterator iter = items.iterator();

                while (iter.hasNext()) {

                    FileItem item = (FileItem) iter.next();

                    if (!item.isFormField()) {

      

                        // 根据时间戳创建头像文件

                        filename = System.currentTimeMillis() + ".jpg";

                        String photoFolder = "e:\project\j2ee\web\uploaded";

                        File f = new File(photoFolder, filename);

                        f.getParentFile().mkdirs();

      

                        // 通过item.getInputStream()获取浏览器上传的文件的输入流

                        InputStream is = item.getInputStream();

      

                        // 复制文件

                        FileOutputStream fos = new FileOutputStream(f);

                        byte b[] = new byte[1024 1024];

                        int length = 0;

                        while (-1 != (length = is.read(b))) {

                            fos.write(b, 0, length);

                        }

                        fos.close();

      

                    else {

                        System.out.println(item.getFieldName());

                        String value = item.getString();

                        value = new String(value.getBytes("ISO-8859-1"), "UTF-8");

                        System.out.println(value);

                    }

                }

                 

                String html = "<img width='200' height='150' src='uploaded/%s' />";

                PrintWriter pw= response.getWriter();

                pw.format(html, filename);

                 

            catch (FileNotFoundException e) {

                // TODO Auto-generated catch block

                e.printStackTrace();

            catch (Exception e) {

                // TODO Auto-generated catch block

                e.printStackTrace();

            }

        }

    }


    更多内容,点击了解: https://how2j.cn/k/servlet/servlet-upload/587.html

  • 相关阅读:
    [原创]java WEB学习笔记26:MVC案例完整实践(part 7)---修改的设计和实现
    [原创]java WEB学习笔记25:MVC案例完整实践(part 6)---新增操作的设计与实现
    [原创]java WEB学习笔记24:MVC案例完整实践(part 5)---删除操作的设计与实现
    [原创]java WEB学习笔记23:MVC案例完整实践(part 4)---模糊查询的设计与实现
    Tapestry IoC Configuration
    Tapestry IoC Decorator
    Tapestry IoC Service
    Tapestry-Again
    mysql error nr.1045 解决方法
    Bootstrap学习 导航
  • 原文地址:https://www.cnblogs.com/Lanht/p/12615413.html
Copyright © 2020-2023  润新知