6

データベースからメディアを表示するアクションを作成しようとしています (ASP.NET MVC4):

var memoryStream = new MemoryStream(mediaContent.File.FileData.Data);

return new FileStreamResult(memoryStream, MimeMapping.GetMimeMapping(mediaContent.File.Filename));

写真は問題mysite/media/4なく表示されますが、Chrome または Firefox でリンクしようとするとビデオ (.avi) に問題が発生します。

<embed width="100%" height="100%" name="plugin" src="http://mysite/media/4" type="video/x-msvideo">

ただし、ビデオは再生されません (リンクが実際のビデオ ファイルを指している場合に発生します)。IE でこのリンクを開くと、ファイルをダウンロードするように求められ、プレーヤーからこのファイルを開くと正常に動作します。

応答ヘッダー:

Cache-Control:private, s-maxage=0
Content-Length:808680
Content-Type:video/x-msvideo
Date:Wed, 06 Nov 2013 10:03:09 GMT
Server:Microsoft-IIS/7.5
X-AspNet-Version:4.0.30319
X-AspNetMvc-Version:4.0
X-MiniProfiler-Ids:["e305dcdb-79be-4452-94d2-a9999ffaa13a","c0c81d12-8b31-425c-a57b-2ad186c958d5","1f7f3c09-a695-49f1-9203-6b5bf44b837a","fb0d637e-5926-4759-ad6f-f7322403e98c","f08c0392-10d6-4477-b2df-be52ab9a1d64","366d6122-15a5-41b4-840a-607fc6931996","11fd2eb7-efce-47a1-96f8-09fbdb0b1fa0","690e67b7-b1fb-46a3-9aa3-ef6207203f55","a51640ad-f31d-4f12-a807-6ea06ba0ee46","38adc052-9c41-4243-97d2-41dbf3b36093","9d255225-c122-44ef-8021-5b6f9d4dd549","2b249ff3-9e37-43c3-b6ab-b78b26c6d6ce","2bec0b1b-4898-4b14-bf12-cc331e27ecfc","49c72e01-c8d4-495f-af7e-8ffd687e94e9","1c87e454-f90d-49f4-9618-8dfe0d9c0329","2152a9a8-54ae-47d8-b98a-83ac32dbdb0c","9cf93254-9552-4834-826e-df7e8a7d8e73","a2d782e2-96ca-4e9c-b612-9782a37a06ca","e10ecc8a-5811-4cca-b566-3f09e1de3f2c","3769bb15-60f9-43c3-ad6c-285f3fb47112","1996c4aa-9f76-4f33-95fa-3f7f5b3e72f4"]
X-Powered-By:ASP.NET

私が間違っていることは何ですか?<object>このビデオをページに表示するために使用できるリンクが必要です。

更新 1: 物理的なビデオ ファイルの URL を入力した場合に得られる応答は意味がありません。

HTTP/1.1 304 Not Modified
Last-Modified: Tue, 05 Nov 2013 17:07:56 GMT
Accept-Ranges: bytes
ETag: "5d50369249dace1:0"
Server: Microsoft-IIS/7.5
X-Powered-By: ASP.NET
Date: Wed, 06 Nov 2013 11:20:32 GMT

しかし、それは機能し、インストールされた VLC プレーヤー プラグインを使用してブラウザ内でビデオの再生を開始します。

更新 2: ビデオを返すためにさまざまな実装を試し、のへsrcのリンクを配置しようとしましたobject

<object id="video-player" class="preview-container" type="video/x-msvideo" src="{link to video}" loop="true" controls="false" autoplay="true"></object>

したがって、「localhost/media/some_video.avi」のような実際のビデオへのリンクの場合、内部objectで正常に動作し、URL に直接アクセスするとうまくいきます。

さまざまな実装の動作を確認しました

1)return File(memoryStream, MimeMapping.GetMimeMapping(mediaContent.File.Filename), mediaContent.File.Filename);

to url: ビデオ ファイルのダウンロードを促すプロンプト。オブジェクト内: 空のプラグインを表示します。

2)return new FileContentResult(mediaContent.File.FileData.Data, "application/x-vlc-plugin")

to url: 空のプラグインを表示します。オブジェクト内: 空のプラグインを表示します。

3)return new FileContentResult(mediaContent.File.FileData.Data, "video/avi")

to url: ビデオ ファイルのダウンロードを促すプロンプト。オブジェクト内: 空のプラグインを表示します。

更新 3: HttpHandler を作成しました:

public void ProcessRequest(HttpContext context)
{
    MediaContent mediaContent;
    //getting mediaContent

    context.Response.Clear();
    context.Response.Buffer = true;
    context.Response.AppendHeader("Content-Disposition", "inline; filename=" + mediaContent.File.Filename);
    context.Response.ContentType = MimeMapping.GetMimeMapping(mediaContent.File.Filename);
    context.Response.BinaryWrite(mediaContent.File.FileData.Data);
    context.Response.End();
}

そして、それは単に機能します。Ok。次に、Handler と同じロジックでアクションを作成しました。

[HttpGet]
public void Media(int id)
{
    MediaContent mediaContent;
    //getting mediaContent

    Response.Clear();
    Response.Buffer = true;
    Response.AppendHeader("Content-Disposition", "inline; filename=" + mediaContent.File.Filename);
    Response.ContentType = MimeMapping.GetMimeMapping(mediaContent.File.Filename);
    Response.BinaryWrite(mediaContent.File.FileData.Data);
    Response.End();
}

しかし、このアクションはまだビデオでは機能せず、応答ヘッダーを比較し始めました。

ハンドラ:

HTTP/1.1 200 OK
Cache-Control: private
Content-Type: video/x-msvideo
Server: Microsoft-IIS/7.5
Content-Disposition: inline; filename=Reebok_App_attract640L.avi
X-AspNet-Version: 4.0.30319
X-Powered-By: ASP.NET
Date: Wed, 06 Nov 2013 17:02:45 GMT
Content-Length: 808680

アクション:

HTTP/1.1 200 OK
Cache-Control: private, s-maxage=0
Content-Type: video/x-msvideo
Transfer-Encoding: chunked
Server: Microsoft-IIS/7.5
X-AspNetMvc-Version: 4.0
Content-Disposition: inline; filename=Reebok_App_attract640L.avi
X-AspNet-Version: 4.0.30319
X-Powered-By: ASP.NET
Date: Wed, 06 Nov 2013 17:02:47 GMT

Transfer-Encoding を取り除くために、Content-Length をアクションに追加しました。

Response.AddHeader("Content-Length", mediaContent.File.FileData.Data.Length.ToString());

を取り除くことはできませんでしs-maxage=0たが、ヘッダーは似ています (とヘッダーs-maxage=0X-AspNetMvc-Version: 4.0順序を除く)

4

2 に答える 2

-1

データベースに保存されているファイルの場所をバイトバッファー配列に入れ、配列全体を一度に読み取る代わりに、配列からチャンクで読み取ることができます

WebRequest wreq = (HttpWebRequest)WebRequest.Create(url);
using (HttpWebResponse wresp = (HttpWebResponse)wreq.GetResponse())
using (Stream mystream = wresp.GetResponseStream())
{
  using (BinaryReader reader = new BinaryReader(mystream))
  {
    int length = Convert.ToInt32(wresp.ContentLength);
    byte[] buffer = new byte[length];
    buffer = reader.ReadBytes(length);

    Response.Clear();
    Response.Buffer = false;
    Response.ContentType = "video/mp4";
    while(true) {
    int bytesRead = myStream.Read(buffer, 0, buffer.Length);
    if (bytesRead == 0) break;
    Response.OutputStream.Write(buffer, 0, bytesRead);
}
    Response.End();
  }
}

また、役立つURLの天気を確認することもできます 。

ありがとう

于 2013-11-09T17:23:18.150 に答える