全平台网页播放器兼容H5与Flash还带播放列表

时间:2024-03-02 17:45:45

许久不发文了,2018年第一篇文章,写点干货——关于网页播放器的问题。嗯,实际上我是在52破解首发的,当做新人贴。
目前来说,网页播放器不少,随便找找都能找到一大堆,然而好用的就那么几个,比如ckplayer什么的。2017年底,自己想给这个小博客增加视频播放功能,之前也发过几篇关于typecho视频播放器的帖子,奈何都是别人的成果,总想自己搞一个,并且同时支持PC+移动端+播放列表的功能,要想完成还是要费一番功夫的,巧的是当时逛谷歌的时候真的让我找到了一个这样的播放器,当然也是付费的!接下来的工作想必都能猜到O(∩_∩)O哈哈~

先放出实验对象——Flash HTML5 Web Video Player我觉得一个正常的公司不会起一个这么直白的名字 -_-|| 还卖39美元!实际卖的是一个十几兆的小软件,自定义后可自动生成swf格式的播放器,只要在网页上引用就可以实现播放功能了。官方提供试用版,但是播放视频会在左上角带有一个官网地址的标记,非常烦人,详细见下图。Flash HTML5 Web Video Player我要做的就是去掉这个链接,但是,我的做法不是破解注册软件本身,而是从生成的swf文件入手。很自然地想到对swf文件逆向,这确实可行,用AS3 Sorcerer的确可以拿到swf的源码,并且源码看上去还很正常,AS3 Sorcerer在很多地方都可以下载到,我尝试了其他的逆向工具,无奈都失败了,有些工具逆向出来的部分AS文件是空白的。逆向后会发现在所有文件架最外层有一个主文件,打开这个AS3文件真的算是大开眼界,代码非常工整,很容易就找到了我们要找的地方:

private function InitWatermark():void
       {
           var _local_1:*;
           var _local_2:TextFormat;
           var _local_3:*;
           if (cfgObject.demo)
           {
               _local_1 = new TextField();
               _local_1.multiline = true;
               _local_1.wordWrap = false;
               _local_1.selectable = false;
               _local_1.htmlText = "<a ><font face=\'Arial,Verdana\'>http://www.magichtml.com</font></a>";
               _local_1.autoSize = TextFieldAutoSize.LEFT;
               _local_2 = new TextFormat();
               _local_2.align = TextFormatAlign.CENTER;
               _local_1.setTextFormat(_local_2);
               _local_1.x = 8;
               _local_1.y = 8;
               _local_3 = new Sprite();
               _local_3.graphics.beginFill(0xFFFFFF);
               _local_3.graphics.drawRoundRect(0, 0, (_local_1.width + 8), (_local_1.height + 8), 8, 8);
               _local_3.graphics.endFill();
               _local_3.x = 4;
               _local_3.y = 4;
               _local_3.alpha = 1;
               watermarkMC = new MovieClip();
               watermarkMC.addChild(_local_3);
               watermarkMC.addChild(_local_1);
               this.addChild(watermarkMC);
               watermarkMC.x = 8;
               watermarkMC.y = 8;
           };
       }

问题就集中在那个if判断里,本想着只要不进入if里就可以,修改后再编译成swf就行。但是,事情并没有那么简单,自己尝试了很多次,虽然调用Flash SDK下的mxmlc确实可以不报错生成swf文件,但是完全不能用,浏览器调用后只会显示一块黑色区域。PS:后来发现,那个公司最成功的一款产品是swf加密软件,估计在生成swf文件过程中也加密了。
出现这种情况对我来讲基本无解了,因为完全不知道问题在哪。后来在使用另一款软件ActionScriptViewer后发现,该款软件可以在不破坏swf文件的前提下直接编辑swf里的常量!看到希望了\(o)/~
返回之前的源码,发现在if里的判断实际就是调用了常量demo,这个值实际是软件自己加上去的,跟第一张图右侧播放器的相关设置在一起(类似xml文件)放在主文件开头出,相当于一个全局常量。所以只要一开始设置播放器时给一个false常量然后把if判断指向这个常量就好了。我这里用到的是randomPlay。只要在ActionScriptViewer里将demo换成randomPlay就完成了。之后保存就好,浏览器再调用swf就正常了。至此,结束。至于调用的视频,swf播放器会调用一个同名的xml文件,里面指明了视频地址和缩略图。

我把自己修改好的播放器文件放出来:https://files.cnblogs.com/files/liuke-note/player.zip 至于使用方法,很简单看看里面的html文件就懂了