概述


在常规的HTTP应答中,Content-Disposition 消息头指示回复的内容该以何种形式展示,是以内联的形式(即网页或者页面的一部分),还是以附件的形式下载并保存到本地。通俗的解释就是对于URL对应的文件(内容)是直接在浏览器中打开还是保存。


格式说明:

content-disposition = "Content-Disposition" ":" disposition-type *( ";" disposition-parm )

示例:

Content-Disposition: attachment; filename="filename.jpg"

字段说明:


  • Content-Disposition为属性名;
  • disposition-type是以什么方式下载,如attachment为以附件方式下载;
  • disposition-parm为默认保存时的文件名。

说明: 服务端向客户端游览器发送文件时,如果是浏览器支持的文件类型,一般会默认使用浏览器打开,比如txt、jpg等,会直接在浏览器中显示,如果需要提示用户保存,就要利用Content-Disposition进行一下处理,关键在于一定要加上attachment。这样浏览器会提示保存还是打开,即使选择打开,也会使用相关联的程序比如记事本打开,而不是IE直接打开了。

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

注意: 在浏览器中测试URL时一定要确保没有做过关于禁止浏览器缓存的操作。

案例测试:

使用Azure Storage Blob 结合Python Storage SDK进行测试。

前期准备
  1. azure-storage-python SDK
  2. Microsoft Azure Storage Exployer下载及使用指南

Code Sample:


# coding=utf-8 from azure.storage.blob import BlockBlobService, ContentSettings
import urllib.parse def run_sample(): block_blob_service = BlockBlobService(connection_string='<Storage Connection String>')
service = block_blob_service
container_name = 'dev'
blob_name = 'demo.txt'
service.create_blob_from_text(container_name, blob_name, 'hello world') # 设置下载方式及默认下载文件名
settings = ContentSettings(content_type='application/octet-stream', content_disposition='attachment;filename="yutest.txt"') service.set_blob_properties(container_name, blob_name, content_settings=settings)
blob = service.get_blob_properties(container_name, blob_name)
content_disposition = blob.properties.content_settings.content_disposition
print(content_disposition) # Main method.
if __name__ == '__main__':
run_sample()
上传文件使用工具查看:

获取的文件URL使用Chrome浏览器发现默认的并不是指定的filename。但是使用工具对文件生成SAS在浏览器中下载,功能正常。

原始URL测试

SAS测试

通过F12对比发现,默认的URL使用的x-ms-version:2009-09-19版本较老,使用SAS使用的x-ms-version:2017-04-17。老的api返回的结果中并不包含Content-Disposition属性,需要使用新的api。

修改存储账户默认的api版本
  • C#示例代码
var cloudStorageAccount = new CloudStorageAccount(new StorageCredentials("<account name>", "<account key>"), "core.chinacloudapi.cn", false);

serviceProperties.DefaultServiceVersion = "2017-04-17";

cloudStorageAccount.CreateCloudBlobClient().SetServiceProperties(serviceProperties);

关于version的修改也可以参考AzureBlobUtility工具实现。

修改后URL的测试

filename中文字符支持问题

官方说明


如果任何名称/值对包含非 ASCII 字符,则会收到 400 Bad Request 。 元数据名称/值对是有效的 HTTP 标头,因此必须遵循所有控制 HTTP 标头的限制。 因此,对于包含非 ASCII 字符的名称和值,建议使用URL编码或Base64编码。


  • URL编码方案参考:

import urllib.parse
settings = ContentSettings(content_type='application/octet-stream', content_disposition='attachment;filename="{}";'.format(urllib.parse.quote('中文测试.txt')))

参考链接:

The contentDisposition does not work with the createWriteStreamToBlockBlob method option.

Content-Disposition

flask+gunicorn中文文件下载报错问题及解决

关于Azure Storage Blob Content-Disposition 使用学习的更多相关文章

  1. Azure系列2.1 —— com.microsoft.azure.storage.blob

    网上azure的资料较少,尤其是API,全是英文的,中文资料更是少之又少.这次由于公司项目需要使用Azure,所以对Azure的一些学习心得做下笔记,文中不正确地方请大家指正. Azure Blob ...

  2. Connect China Azure Storage Blob By Container Token In Python SDK

    简介: 基于Python SDK,使用Container Token操作container对象.关于Token的生成可以使用Storage SDK创建,也可以使用工具快速创建供测试. 示例代码: fr ...

  3. 【Azure 存储服务】代码版 Azure Storage Blob 生成 SAS (Shared Access Signature: 共享访问签名)

    问题描述 在使用Azure存储服务,为了有效的保护Storage的Access Keys.可以使用另一种授权方式访问资源(Shared Access Signature: 共享访问签名), 它的好处可 ...

  4. Azure Storage Blob Go SDK示例

    简介 前面一篇博客介绍了关于Azure ManagerAPI Go SDK的使用,本篇继续介绍使用Blob Go SDK 操作中国区Azure Blob. SDK下载: go get github.c ...

  5. Azure Storage Blob文件重命名

    Azure Storage的SDK并没有提供文件重命名的方法,而且从StorageExplorer管理工具里操作修改文件名的时候也有明确提示: 是通过复制当前文件并命名为新文件名再删除旧文件,不保存快 ...

  6. Azure Storage Blob文件名区分大小写

    最近在使用Azure Storage的时候发现Storage的命名是区分大小写的,导致我们系统在更新图片的时候有时候更新不上,最终通过判断处理文件名解决. 因此我们在使用Storage需要注意一下文件 ...

  7. 如何获取Azure Storage Blob的MD5值

    问题表述 直接使用CloudBlockBlob对象获取的Properties是空的,无法获取到对象的MD5值,后台并未进行属性值的填充 前提:blob属性本省包含md5值,某些方式上传的blob默认并 ...

  8. Azure Storage Blob 属性设置

    概述 在使用SDK做Blob对象属性的获取或设置时,如果只是直接使用get或set方法,是无法成功获取或设置blob对象的属性.主要是因为在获取对象时,对象的属性默认并未被填充到对象,这就需要执行额外 ...

  9. 【Azure Developer】VS Code运行Java 版Azure Storage SDK操作Blob (新建Container, 上传Blob文件,下载及清理)

    问题描述 是否可以用Java代码来管理Azure blob? 可以.在代码中加入azure-storage-blob依赖.即可使用以下类操作Azure Storage Blob. BlobServic ...

随机推荐

  1. ubuntu下使用AutoKey实现ARK的自动跑/攻击/自动配种

    脚本1: if not store.has_key("ark_run"): store.set_value("ark_run", 1) keyboard.pre ...

  2. (1)python Scrapy爬虫框架

    部署 1.安装python3.6  64bit 2.下载pywin32 https://sourceforge.net/projects/pywin32/files/pywin32/ 双击安装 3.下 ...

  3. CF GukiZ hates Boxes 【二分+贪心】

    Professor GukiZ is concerned about making his way to school, because massive piles of boxes are bloc ...

  4. POJ 1703 Find them, Catch them【种类/带权并查集+判断两元素是否在同一集合/不同集合/无法确定+类似食物链】

      The police office in Tadu City decides to say ends to the chaos, as launch actions to root up the ...

  5. [CF235E]Number Challenge

    $\newcommand{fl}[1]{\left\lfloor#1\right\rfloor}$题意:求$\sum\limits_{i=1}^a\sum\limits_{j=1}^b\sum\lim ...

  6. 实用类String.length应用-用户名密码长度

    package demo3; import java.util.Scanner; //会员注册,用户名长度不小于3,密码长度不小于6,两次输入的密码必须相同 public class Register ...

  7. Scala零基础教学【21-40】

    第24讲:Scala中SAM转换实战详解 SAM:single abstract method 单个抽象方法   我们想传入一个函数来指明另一个函数具体化的工作细节,但是重复的样板代码很多. 我们不关 ...

  8. SVN安装中遇到的问题

    新的版本:1.9.5 必须使用Apache Portable Runtime Utility 1.5.4 Released没有安装的话需要先安装 需要安装apr.apr-util sqlite zli ...

  9. Queue 队列的用法

    队列是一种特殊的线性表,它只允许在表的前端进行删除操作,而在表的后端进行插入操作. LinkedList类实现了Queue接口,因此我们可以把LinkedList当成Queue来用. 以下实例演示了队 ...

  10. canvas如何兼容IE8

    大家都知道canvas是个非常好玩的东西,但是IE9以下的浏览器不支持,有时候业务需求必须用到canvas,且又要求兼容IE8浏览器,那怎么办呢? 1.添加对html5的支持:<!--[if I ...