www.cftea.com

ASP.NET Response.TransmitFile 与 Response.Redirect 的区别

千一网络(原创)2018/5/8 8:34:08

路径支持

支持全路径,比如:Response.TransmitFile("D:\\cftea.txt")

支持相对路径,比如:Response.TransmitFile("cftea.mp4");

支持 ../,比如:Response.TransmitFile("../upload/cftea.com.mp4");

但是不支持 ../ 对到应用程序以外。也就是说并不是不支持 ../,而是不支持用 ../ 退到应用程序以外。这种情况只有用全路径了。

关于 Response.End

Response.TransmitFile 不像 Response.Redirect,Response.Redirect 默认跳转后就结束本网页后面代码的执行,而 Response.TransmitFile 不会,所以往往在 Response.TransmitFile 后面还要手工跟上 Response.End。

关于 Header

如果直接访问一个 txt 文件,浏览器得到的 header 类似如下 :

Content-Length →126
Content-Type →text/plain

而如果 Response.TransmitFile("cftea.txt"),浏览器得到的 header 类似如下 :

Content-Length →126
Content-Type →text/html

可以看出 Content-Type 不一样,这会导致一些问题,就是浏览器不能正确识别文件类型,正确指定了这个,浏览器才会正确使用自己的网页引擎、还是视频引擎、还是 PDF 引擎。否则即使遇到视频文件,浏览器也会当作普通文本将其内容呈现在网页上,而不是播放。

Content-Length 不必定义,由 IIS 自动管理。这玩意我们本身指定了也无效,因为我们无法预知 IIS 还会加多少 Header(这些 Header 的长度也要算在里面噢)。

还有一个 Header,偶尔有用。

一点不如意

我在测试中发现一个问题,当我 TransmitFile 一个视频文件,并用安卓代码访问它时,就会非常卡顿(这可是局域网啊),而且很快 IIS 就死掉了,但是如果用 Chrome 直接访问这个视频,Chrome 都可以非常流畅地播放这视频,而且不会把 IIS 搞死,不知道为什么。

<<返回首页<<