如何在源为https uri时播放wpf MediaElement

Cri*_*van 6 c# wpf mediaelement nullreferenceexception

在wpf独立应用程序(.exe)中,我在MainWindow中包含了一个MediaElement

<Window x:Class="Media.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="Main Window" Height="350" Width="525">
    <Grid>
        <MediaElement x:Name="Player" Stretch="Uniform" LoadedBehavior="Manual" UnloadedBehavior="Stop"/>
    </Grid>
</Window>
Run Code Online (Sandbox Code Playgroud)

从后面的代码我将其设置Source为任何https Uri:

public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();

        var source = new Uri("https://stream_which_can_be_opened_with_windows_media_player.com", UriKind.Absolute);
        Player.Source = source;
        Player.Play();
    }
}
Run Code Online (Sandbox Code Playgroud)

Play()方法被称为NullReferenceException被抛出,而不是播放媒体内容.MediaElement初始化,NullReferenceExceptionPlay()方法抛出,见下文.

可以在Windows Media Player(文件 - >打开URL)中打开视频的相同Uri.

问题似乎是在MediaPlayerState.OpenMedia方法(MediaElement内部使用的对象)中,该方法试图检查从中检索的appDeploymentUri SecurityHelper.ExtractUriForClickOnceDeployedApp是否具有方案HTTPS.该应用程序未部署ClickOnce(它有一个独立的安装程序),appDeploymentUri为null,因此NullReferenceException.

这是来自PresentationFramework.dll,System.Windows.Media.MediaPlayerState.OpenMedia

    if (SecurityHelper.AreStringTypesEqual(uriToOpen.Scheme, Uri.UriSchemeHttps))
    {
        // target is HTTPS. Then, elevate ONLY if we are NOT coming from HTTPS (=XDomain HTTPS app to HTTPS media disallowed)

        //source of the issue
        Uri appDeploymentUri = SecurityHelper.ExtractUriForClickOnceDeployedApp();
        //appDeploymentUri is null
        if (!SecurityHelper.AreStringTypesEqual(appDeploymentUri.Scheme, Uri.UriSchemeHttps))
Run Code Online (Sandbox Code Playgroud)

有没有人有任何解决方法/解决方案,使其工作?

Ert*_*maa 6

我一直在使用MediaElement很多次,我可以说老实说这是一个糟糕的错误,并且比我遇到的任何其他WPF组件都有更多错误.它不仅存在缺陷,而且缺少Silverlight的许多功能.HTTPS适用于Silverlight.

我通过代码,我没有看到改变它的方法.也许有一些MAD反射黑客会允许你这样做,但这是黑客攻击,我不建议这样做.Ps,它似乎是一个真正的错误,也许让微软的人知道它.

最简单的解决方案是使用OWIN制作"内存网络服务器".然后,您可以流式传输http://localhost:1337并包装基础https://内容.https内容仍然是安全的,因为您从"内存网络服务器"流式传输,并且没有"真正的"网络请求.它仍然应该是高效和安全的.