zoukankan      html  css  js  c++  java
  • header中Content-Disposition的作用

    在servlet3.0中 支持文件上传的注解@MultipartConfig 发现有个例子开头打印的信息中有Content-Disposition,一时好奇,所以了解了一下。顺便学习一下文件上传所需要的注意事项。

          Content-disposition 是 MIME 协议的扩展,MIME 协议指示 MIME 用户代理如何显示附加的文件。当 Internet Explorer 接收到头时,它会激活文件下载对话框,它的文件名框自动填充了头中指定的文件名。(请注意,这是设计导致的;无法使用此功能将文档保存到用户的计算机上,而不向用户询问保存位置。)   

            服务端向客户端游览器发送文件时,如果是浏览器支持的文件类型,一般会默认使用浏览器打开,比如txt、jpg等,会直接在浏览器中显示,如果需要提示用户保存,就要利用Content-Disposition进行一下处理,关键在于一定要加上attachment:

    Response.AppendHeader("Content-Disposition","attachment;filename=FileName.txt");

    备注:这样浏览器会提示保存还是打开,即使选择打开,也会使用相关联的程序比如记事本打开,而不是IE直接打开了。

    Content-Disposition就是当用户想把请求所得的内容存为一个文件的时候提供一个默认的文件名。具体的定义如下:

    content-disposition = “Content-Disposition” “:”

    disposition-type *( “;” disposition-parm )

    disposition-type = “attachment” | disp-extension-token

    disposition-parm = filename-parm | disp-extension-parm

    filename-parm = “filename” “=” quoted-string

    disp-extension-token = token

    disp-extension-parm = token “=” ( token | quoted-string )

    那么由上可知具体的例子:

    Content-Disposition: attachment; filename=“filename.xls”

           当然filename参数可以包含路径信息,但User-Agnet会忽略掉这些信息,只会把路径信息的最后一部分做为文件名。当你在响应类型为application/octet- stream情况下使用了这个头信息的话,那就意味着你不想直接显示内容,而是弹出一个”文件下载”的对话框,接下来就是由你来决定“打开”还是“保存” 了。

    注意事项:

    1.当代码里面使用Content-Disposition来确保浏览器弹出下载对话框的时候。 response.addHeader("Content-Disposition","attachment");一定要确保没有做过关于禁止浏览器缓存的操作。如下:

    response.setHeader("Pragma", "No-cache"); 
    response.setHeader("Cache-Control", "No-cache"); 
    response.setDateHeader("Expires", 0);

    不然会发现下载功能在operafirefox里面好好的没问题,在IE下面就是不行,就是找不到文件。

    例子:

    protected void doPost(HttpServletRequest req, HttpServletResponse response)
                throws ServletException, IOException {
            req.setCharacterEncoding("UTF-8");
            Part part = req.getPart("upload");
            // 格式如:form-data; name="upload"; filename="YNote.exe"
            String disposition = part.getHeader("content-disposition");
            System.out.println(disposition);
            String fileName = disposition.substring(disposition.lastIndexOf("=") + 2, disposition.length() - 1);
            String fileType = part.getContentType();
            long fileSize = part.getSize();
            System.out.println("fileName: " + fileName);
            System.out.println("fileType: " + fileType);
            System.out.println("fileSize: " + fileSize);
            //路径必须先创建在根目录下面/upload
            String uploadPath = req.getServletContext().getRealPath("/upload");
            System.out.println("uploadPath" + uploadPath);
            part.write(uploadPath + File.separator + fileName);
        }

    打印部分的

    form-data; name="upload"; filename="clipboard.png"
    fileName: clipboard.png
    fileType: image/png
    fileSize: 39917
    uploadPathD:InstallSoft omcatapache-tomcat-7.0.65wtpwebapps estwebupload

  • 相关阅读:
    UnityGUI Keynote
    Unity3D Asset 导入&导出
    Unity3d平台信息设置
    Unity3D自带Demo AngryBots路径
    如何判定Unity已破解成功
    fbx模型
    Init & Deinit & ARC
    Subscript & Inheritance
    Properties & Method
    Enumeration & Class & Structure
  • 原文地址:https://www.cnblogs.com/mistor/p/5727616.html
Copyright © 2011-2022 走看看