如何获取jwplayer的URL源代码部分

时间:2018-05-16 05:21:09

标签: php html regex jwplayer

好日子的朋友......

如何获取jwplayer的URL源代码部分,我的意思是mp4部分,我找到了我在这里寻找的内容the source

我尝试使用它但是我做不好,抱歉我的英文不好,有人可以看看下面我的PHP代码....我想抓住链接http://localhost/srt/43534234/viral022018SD.MP4和{ {3}}或其中的所有mp4网址在viral022018.html

谢谢你希望有人帮助我...谢谢你

这是我的php代码

<?php
$html = file_get_contents('https://localhost/video/viral022018.html');
//$dom->loadHtml('', LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);
$dom = new DOMDocument();
$dom->loadHTML($html);

$xpath = new DOMXPath($dom);

$sources = [];
foreach ($xpath->query("//script[@type=\"text/javascript\"]") as $script) {
    if (stristr($script->nodeValue, 'playerInstance') !== false) {
        preg_match_all('#file: \"(.+)\"#', $script->nodeValue, $match);
        $sources = $match[1];
    }
}

print_r($sources);
?>

这是viral022018.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" />
<link href='https://fonts.googleapis.com/css?family=Hanuman' rel='stylesheet' type='text/css'>
<link href="https://fonts.googleapis.com/css?family=Scada" rel="stylesheet">
<link href="jwplayer-7.12.8/skins/prime.min2.css" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="jwplayer-7.12.8/jwplayer.js"></script>
<script type="text/javascript">jwplayer.key="I9HOJrL1NmqruQ60as34wt34/23422dsdrwer==";</script>
</head>
<body>
<div id="picasa" class="picasa"></div>
<script type="text/javascript">
    var playerInstance = jwplayer("picasa");
        playerInstance.setup({
        id:'picasa',
        controls: true,
        displaytitle: true,

        flashplayer: "//ssl.p.jwpcdn.com/player/v/7.12.5/jwplayer.flash.swf",
        width: "100%",
        height: "100%",
        aspectratio: "16:9",
        fullscreen: "true",
        provider: 'http',
        autostart: false,
        image:'http://localhost/viral/viralvideo.jpg',
            sources: [{file:"http://localhost/srt/43534234/viral022018SD.MP4",label:"SD",type: "video/mp4"},{file:"http://localhost/srt/43534234/viral022018HD.MP4",label:"HD",type: "video/mp4",default: true}],
            sharing:{
                link: "",
                code: "",
                heading: "Share",
                sites: ["facebook","twitter","tumblr","googleplus","reddit","linkedin","interest","email"],
            },
sharing:{
                link: "",
                code: "",
                heading: "Share",
                sites: ["facebook","twitter","tumblr","googleplus","reddit","linkedin","interest","email"],
            },
tracks: [{
            file: 'http://localhost/srt/viralvideo022018.srt',
            label: 'English',
            kind: 'captions',
            "default":true
}],

     captions: {
        color: '#FFEB3B',
        fontSize: 14,
        fontFamily: 'Scada, Hanuman, sans-serif, Verdana, cursive',
        fontOpacity: 100,
        backgroundOpacity: 0,
backgroundColor: '#000000',
        edgeStyle: 'raised',
        windowColor: '#000000',
        windowOpacity: 0
    },
skin: {
        name: 'prime',
    },




          });

</script>
</body>
</html>

1 个答案:

答案 0 :(得分:0)

请试试这个正则表达式:

{\s*file\s*:\s*["']\s*(http[^"']+\.mp4)

在此处试试:https://regex101.com/r/rmgKId/2

匹配的网址位于第1组。

(编辑:添加\.mp4以使其特定于这些文件)

编辑:要在PHP中实现,通常你会做这样的事情:

preg_match_all('/{\s*file\s*:\s*["\']\s*(http[^"\']+\.mp4)/i', $subject,
    $result, PREG_PATTERN_ORDER);
$result = $result[1];

$result将是正则表达式中编号组1匹配的所有文本的数组。但是我留给你插入上面的代码(更改变量名称以匹配你想要的)。