全平台网页播放器兼容H5与Flash还带播放列表
许久不发文了,2018年第一篇文章,写点干货——关于网页播放器的问题。嗯,实际上我是在52破解首发的,当做新人贴。
目前来说,网页播放器不少,随便找找都能找到一大堆,然而好用的就那么几个,比如ckplayer什么的。2017年底,自己想给这个小博客增加视频播放功能,之前也发过几篇关于typecho视频播放器的帖子,奈何都是别人的成果,总想自己搞一个,并且同时支持PC+移动端+播放列表的功能,要想完成还是要费一番功夫的,巧的是当时逛谷歌的时候真的让我找到了一个这样的播放器,当然也是付费的!接下来的工作想必都能猜到O(∩_∩)O哈哈~
先放出实验对象——Flash HTML5 Web Video Player我觉得一个正常的公司不会起一个这么直白的名字 -_-|| 还卖39美元!实际卖的是一个十几兆的小软件,自定义后可自动生成swf格式的播放器,只要在网页上引用就可以实现播放功能了。官方提供试用版,但是播放视频会在左上角带有一个官网地址的标记,非常烦人,详细见下图。我要做的就是去掉这个链接,但是,我的做法不是破解注册软件本身,而是从生成的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文件就懂了