为什么Web Api HttpResponseMessage没有下载文件?(Why Web Api HttpResponseMessage not download the file?)
我目前正在对Web Api方法进行
GET
,并将文件名作为参数传递。 当我到达方法时,我的参数被正确解析,文件内容正在写入HttpResponseMessage
对象中的响应内容。public HttpResponseMessage Get ([FromUri]string filen) { string downloadPath = WebConfigurationManager.AppSettings["DownloadLocation"]; var fileName = string.Format("{0}{1}", downloadPath, filen); var response = Request.CreateResponse(); if (!File.Exists(fileName)) { response.StatusCode = HttpStatusCode.NotFound; response.ReasonPhrase = string.Format("The file [{0}] does not exist.", filen); throw new HttpResponseException(response); } response.Content = new PushStreamContent(async (outputStream, httpContent, transportContext) => { try { var buffer = new byte[65536]; using (var file = File.Open(fileName, FileMode.Open, FileAccess.Read)) { var length = (int)file.Length; var bytesRead = 1; while (length > 0 && bytesRead > 0) { bytesRead = file.Read(buffer, 0, Math.Min(length, buffer.Length)); await outputStream.WriteAsync(buffer, 0, bytesRead); length -= bytesRead; } } } finally { outputStream.Close(); } }); response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream"); response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment") { FileName = filen }; return response; }
似乎没有任何事情发生,而不是看到文件被下载。 似乎文件在任何地方都丢失了。 我想让浏览器自动下载该文件。 我确实在fiddler中看到了响应中的内容。 所以发生了什么事? 任何指针将不胜感激!
HTTP/1.1 200 OK Cache-Control: no-cache Pragma: no-cache Transfer-Encoding: chunked Content-Type: application/octet-stream Expires: -1 Server: Microsoft-IIS/8.0 Content-Disposition: attachment; filename=w-brand.png X-AspNet-Version: 4.0.30319 X-SourceFiles: =?UTF-8?B?RDpcSnVubGlcQXN5bmNGaWxlVXBsb2FkV2ViQVBJRGVtb1xBc3luY0ZpbGVVcGxvYWRXZWJBUElEZW1vXGFwaVxGaWxlRG93bmxvYWQ=?= X-Powered-By: ASP.NET Date: Thu, 12 Feb 2015 19:32:33 GMT 27b5 PNG ...
I am currently doing a
GET
to a Web Api method and am passing the file name as parameter. When I get to the method, my parameters are resolved properly, and the file content is writing to the response content in theHttpResponseMessage
object.public HttpResponseMessage Get ([FromUri]string filen) { string downloadPath = WebConfigurationManager.AppSettings["DownloadLocation"]; var fileName = string.Format("{0}{1}", downloadPath, filen); var response = Request.CreateResponse(); if (!File.Exists(fileName)) { response.StatusCode = HttpStatusCode.NotFound; response.ReasonPhrase = string.Format("The file [{0}] does not exist.", filen); throw new HttpResponseException(response); } response.Content = new PushStreamContent(async (outputStream, httpContent, transportContext) => { try { var buffer = new byte[65536]; using (var file = File.Open(fileName, FileMode.Open, FileAccess.Read)) { var length = (int)file.Length; var bytesRead = 1; while (length > 0 && bytesRead > 0) { bytesRead = file.Read(buffer, 0, Math.Min(length, buffer.Length)); await outputStream.WriteAsync(buffer, 0, bytesRead); length -= bytesRead; } } } finally { outputStream.Close(); } }); response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream"); response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment") { FileName = filen }; return response; }
Instead of seeing the file being downloaded, nothing seems to happen. It seems the file just get lost anywhere. I would like to have the browser to auto download the file. I do see the content in the response in fiddler. So what happened? Any pointers would be appreciated!
HTTP/1.1 200 OK Cache-Control: no-cache Pragma: no-cache Transfer-Encoding: chunked Content-Type: application/octet-stream Expires: -1 Server: Microsoft-IIS/8.0 Content-Disposition: attachment; filename=w-brand.png X-AspNet-Version: 4.0.30319 X-SourceFiles: =?UTF-8?B?RDpcSnVubGlcQXN5bmNGaWxlVXBsb2FkV2ViQVBJRGVtb1xBc3luY0ZpbGVVcGxvYWRXZWJBUElEZW1vXGFwaVxGaWxlRG93bmxvYWQ=?= X-Powered-By: ASP.NET Date: Thu, 12 Feb 2015 19:32:33 GMT 27b5 PNG ...
原文:https://stackoverflow.com/questions/28486579
最满意答案
您可以使用BeautifulSoup中的
get_text
方法items = soup.find_all("li") for item in items: print item.get_text().strip()
You can use
get_text
method from BeautifulSoupitems = soup.find_all("li") for item in items: print item.get_text().strip()
相关问答
更多-
页脚上方有额外空间(Extra space above footer)[2022-03-21]
它来自#contentright的底部填充: 您可以通过将底部填充设置为0来解决此问题: #contentright { /* Your existing styles plus...*/ padding-bottom: 0; } 然后你可以将你的10px margin-top应用到你的页脚: #footer { /* Your existing styles plus...*/ margin-top: 10px; } 演示 It's coming from the bottom pad ... -
下面的String操作是否在python中使用了额外的空间?(Does String operation like below uses extra space in python?)[2022-07-18]
每次你做a[b:c]类a[b:c]事情时,Python都会创建一个新对象。 所以,是的,你正在使用额外的空间。 我建议像这样使用replace()方法: S.replace(" ", "") 它会一次删除所有空格。 顺便说一句,你不要在你的代码中增加i并且:在while语句中缺少。 Every time you do something like a[b:c], Python creates a new object. So yes, you are using extra space. I would ... -
您可以使用BeautifulSoup中的get_text方法 items = soup.find_all("li") for item in items: print item.get_text().strip() You can use get_text method from BeautifulSoup items = soup.find_all("li") for item in items: print item.get_text().strip()
-
在这里使用str.lstrip ,因为白色空间只在前面: List = [s.lstrip() for s in List] # ['5432', '23421', '43242', ...] 或者在这种情况下,看到你知道有多少空格你可以做: List = [s[1:] for s in List] Use str.lstrip here, as the white-space is only at the front: List = [s.lstrip() for s in List] # ['543 ...
-
浏览器通常会为段落指定默认边距。 所以就把它拿走吧。 给
一个0的边距: .Box p{ margin: 0; } 在这里查看: http : //jsfiddle.net/aG27X/ It's common for browsers to give paragraphs a default margin. So just take it away. Give the
a margin of 0: .Box p{ margin: 0; } Check it here: ht ...
-
尝试添加padding: 0; 到主css文件中的.row .col.s4 。 .row .col.s4 { padding: 0; }
在Python中,如何从二维数组中删除额外的空间元素?(In Python how remove extra space elements from two dimensional array?)[2022-07-23]
我想你的意思是你希望从你的2darray中删除空的元素。 如果是这样的话,那么: old_list = [['2', '2', '', ''], ['3', '3', '', ''], ['4', '4', '', '']] new_list = [[instance for instance in sublist if len(instance)>0] for sublist in old_list] 如果你想删除只包含空格(空格等)的元素,那么year可能会做如下操作: old_list = [['2 ...最后删除额外空间(Remove Extra Space At End)[2024-03-19]
你的代码非常好。 我觉得没问题。 看看这个 while (n1 <= n) { x = (3 * n1 * n1 - n1) / 2; System.out.print(x + ((n1 == n) ? "\n" : " ")); n1++; } 如果需要,用" " (空格)替换"\n" (新行)! Your code is perfectly fine. I see no problem with it. Just check this out while (n1 <= n) ...print函数有一个默认参数sep ,它是给予print函数的每个参数之间的分隔符。 默认情况下,它设置为空格。 您可以轻松地更改它,(在您的情况下为空),如下所示: print('Cost of paint: $', math.ceil(paint_needed), sep='') # Cost of paint: $150 如果你想用换行符分隔每个参数,你可以这样做: print('Cost of paint: $', math.ceil(paint_needed), sep='\n') # Cost ...删除gridded python Tkinter小部件之间的自动间隙(Remove automatic gap between gridded python Tkinter widgets)[2022-04-17]
您还需要将highlightthickness设置为零。 self.c1 = tk.Canvas(..., highlightthickness=0) 从effbot highlightthickness的画布页面解释为: 高光边框的宽度。 默认值是系统特定的(通常是一个或两个像素)。 (highlightThickness / HighlightThickness) You need to set highlightthickness to zero as well. self.c1 = tk.Canv ...相关文章
更多- 使用jQuery、Yahoo API和HTML5的geolocation来开发一个天气预报web应用
- Web scraper open source
- MyBatis Java API详解
- Shiro整合到Web应用
- 自制公众平台Web Api(微信)
- 从HDFS下载文件到本地
- POI 操作 Excel的主要API
- web storm使用和配置
- API调用太麻烦 eBay推出Web查询语言
- 如何打造高性能Web应用
最新问答
更多- 您如何使用git diff文件,并将其应用于同一存储库的副本的本地分支?(How do you take a git diff file, and apply it to a local branch that is a copy of the same repository?)
- 将长浮点值剪切为2个小数点并复制到字符数组(Cut Long Float Value to 2 decimal points and copy to Character Array)
- OctoberCMS侧边栏不呈现(OctoberCMS Sidebar not rendering)
- 页面加载后对象是否有资格进行垃圾回收?(Are objects eligible for garbage collection after the page loads?)
- codeigniter中的语言不能按预期工作(language in codeigniter doesn' t work as expected)
- 在计算机拍照在哪里进入
- 使用cin.get()从c ++中的输入流中丢弃不需要的字符(Using cin.get() to discard unwanted characters from the input stream in c++)
- No for循环将在for循环中运行。(No for loop will run inside for loop. Testing for primes)
- 单页应用程序:页面重新加载(Single Page Application: page reload)
- 在循环中选择具有相似模式的列名称(Selecting Column Name With Similar Pattern in a Loop)
- System.StackOverflow错误(System.StackOverflow error)
- KnockoutJS未在嵌套模板上应用beforeRemove和afterAdd(KnockoutJS not applying beforeRemove and afterAdd on nested templates)
- 散列包括方法和/或嵌套属性(Hash include methods and/or nested attributes)
- android - 如何避免使用Samsung RFS文件系统延迟/冻结?(android - how to avoid lag/freezes with Samsung RFS filesystem?)
- TensorFlow:基于索引列表创建新张量(TensorFlow: Create a new tensor based on list of indices)
- 企业安全培训的各项内容
- 错误:RPC失败;(error: RPC failed; curl transfer closed with outstanding read data remaining)
- C#类名中允许哪些字符?(What characters are allowed in C# class name?)
- NumPy:将int64值存储在np.array中并使用dtype float64并将其转换回整数是否安全?(NumPy: Is it safe to store an int64 value in an np.array with dtype float64 and later convert it back to integer?)
- 注销后如何隐藏导航portlet?(How to hide navigation portlet after logout?)
- 将多个行和可变行移动到列(moving multiple and variable rows to columns)
- 提交表单时忽略基础href,而不使用Javascript(ignore base href when submitting form, without using Javascript)
- 对setOnInfoWindowClickListener的意图(Intent on setOnInfoWindowClickListener)
- Angular $资源不会改变方法(Angular $resource doesn't change method)
- 在Angular 5中不是一个函数(is not a function in Angular 5)
- 如何配置Composite C1以将.m和桌面作为同一站点提供服务(How to configure Composite C1 to serve .m and desktop as the same site)
- 不适用:悬停在悬停时:在元素之前[复制](Don't apply :hover when hovering on :before element [duplicate])
- 常见的python rpc和cli接口(Common python rpc and cli interface)
- Mysql DB单个字段匹配多个其他字段(Mysql DB single field matching to multiple other fields)
- 产品页面上的Magento Up出售对齐问题(Magento Up sell alignment issue on the products page)