呂光金
(上海財(cái)經(jīng)大學(xué)浙江學(xué)院,,浙江 金華 321015)
摘要:隨著Flash動(dòng)畫商業(yè)價(jià)值的不斷提升,,各種加密和解密軟件也應(yīng)運(yùn)而生,如何有效地保護(hù)動(dòng)畫作品是一個(gè)值得探討的問題,。首先對(duì)Flash文件進(jìn)行了解析,,然后闡述了幾種保護(hù)Flash動(dòng)畫的加密方法,并對(duì)幾款相關(guān)的加密軟件進(jìn)行了測(cè)試比較,,得出用加殼打包類軟件進(jìn)行加密比較安全,。
關(guān)鍵詞:Flash動(dòng)畫;知識(shí)產(chǎn)權(quán)保護(hù),;加密,;特征提取
0引言
Flash是Micromedia公司開發(fā)的一款動(dòng)畫制作軟件。許多愛好者運(yùn)用Flash制作出優(yōu)秀的動(dòng)畫作品,,并上傳至閃客帝國(guó),、TOMFlash動(dòng)畫頻道等專業(yè)網(wǎng)站進(jìn)行學(xué)習(xí)與交流,極大地推動(dòng)了Flash等多媒體技術(shù)以及動(dòng)畫的傳播與發(fā)展[1]。隨著Flash作品的商業(yè)價(jià)值的劇增,,各種加密和解密軟件也應(yīng)運(yùn)而生,,個(gè)別用戶非法運(yùn)用解密軟件嚴(yán)重?fù)p害了用戶的知識(shí)產(chǎn)權(quán)。如運(yùn)用碩思閃客精靈軟件,,將SWF文件反編譯成FLA文件提取各個(gè)元素,。為了防止作品未經(jīng)許可被盜用或惡意修改,有必要對(duì)SWF作品加密方法進(jìn)行研究,。
關(guān)于動(dòng)畫加密,,國(guó)內(nèi)外一些學(xué)者和公司進(jìn)行了相應(yīng)的研究,如Micromedia公司在Flash軟件中自帶了防止導(dǎo)入功能,?;鄯逍旁纯萍加邢薰狙邪l(fā)的網(wǎng)刃平臺(tái)支持對(duì)SWF文件和FLA文件的加密。文獻(xiàn)[2]對(duì)Flash動(dòng)畫的內(nèi)容特征提取進(jìn)行了深入的研究,,并用VC++軟件開發(fā)了一個(gè)提取平臺(tái)。文獻(xiàn)[4]提出了基于Flash動(dòng)畫的信息隱藏算法,。文獻(xiàn)[5]對(duì)SWF文件的版權(quán)保護(hù)設(shè)計(jì)了一個(gè)加密器,,在一定程度上防止了反編譯軟件的攻擊。文獻(xiàn)[6]對(duì)基于AES的Flash加密方式進(jìn)行了研究,。文獻(xiàn)[7]對(duì)運(yùn)用AESCCM模式進(jìn)行數(shù)據(jù)加密進(jìn)行了研究,。目前為止,雖然理論研究較多,,但是實(shí)踐很少,,對(duì)現(xiàn)有的軟件介紹幾乎沒有,因此,,本文先對(duì)SWF文件進(jìn)行解析,,然后對(duì)現(xiàn)有的SWF加密軟件和方法進(jìn)行探討與實(shí)踐。
1Flash文件解析
Flash能把文本,、圖形,、圖像、動(dòng)畫,、聲音,、視頻以及交互方式等融合為一個(gè)整體[1],制作成基于“流技術(shù)”的動(dòng)畫,。 Flash動(dòng)畫的文件格式主要有兩種,,即源文件格式(*.FLA文件)和播放文件格式(*.SWF文件),源文件可以通過Flash動(dòng)畫制作軟件修改和編輯,,播放文件需要通過其他專業(yè)軟件反編譯后才能修改,,本文所指文件為SWF格式文件。
SWF文件與XML文件的內(nèi)部結(jié)構(gòu)相似[2],,采用二進(jìn)制標(biāo)簽對(duì)動(dòng)畫文件中的各個(gè)對(duì)象,、效果以及交互方式進(jìn)行定義,。SWF文件由三部分組成:文件頭(Header)、文件主體(Body,,由多個(gè)Tag組成),、文件結(jié)束標(biāo)簽(End Tag),其結(jié)構(gòu)如圖1所示,。
文件頭定義了SWF動(dòng)畫的基本信息,,如文件的版本、文件大小,、是否壓縮,、幀頻、影格大小,、總的幀數(shù)等[3],。SWF中的標(biāo)簽又可以分為定義型標(biāo)簽和控制型標(biāo)簽兩種。標(biāo)簽的組織順序可以任意排列,,但必須遵循先定義后引用,、先定義后控制的規(guī)則,聲音流標(biāo)簽必須按順序播放,,結(jié)束標(biāo)簽只能有一個(gè),,而且必須是最后一個(gè)。部分加密軟件是通過修改SWF的文件頭,,從而導(dǎo)致SWF解析器在對(duì)SWF文件解析時(shí)出錯(cuò)來達(dá)到加密目的,。
2Flash動(dòng)畫加密方法
傳統(tǒng)的數(shù)字版權(quán)保護(hù)主要有以下幾種:(1)通過在產(chǎn)品中內(nèi)置注冊(cè)體系的軟件保護(hù)方式。(2)在外面加一個(gè)加密外殼,,從而保證程序不被別人盜用或改寫,。(3)通過硬件方式對(duì)軟件產(chǎn)品進(jìn)行保護(hù),主要采用USB卡,、加密狗等,。前兩種一般統(tǒng)稱為軟保護(hù)。第(3)種為硬件加密方法,,一般認(rèn)為硬件加密最安全,,但是必須用光盤分發(fā),不能通過互聯(lián)網(wǎng)大范圍傳播,,在SWF動(dòng)畫加密中一般不采用,。
2.1運(yùn)用Flash自帶的防止導(dǎo)入功能
Flash作品的保護(hù)或加密,最原始的辦法就是防止導(dǎo)入,。即防止將SWF導(dǎo)入到Flash軟件中提取各種特征元素,。比如,當(dāng)把一份優(yōu)秀的SWF動(dòng)畫發(fā)布到網(wǎng)上后,經(jīng)過一段時(shí)間,,會(huì)發(fā)現(xiàn)動(dòng)畫中的各種元素(Flash中稱為元件)出現(xiàn)在了別人的動(dòng)畫中,。為了防止導(dǎo)入Flash動(dòng)畫提取元素,可以通過Flash軟件本身的“防止導(dǎo)入”功能實(shí)現(xiàn)簡(jiǎn)單的加密,。具體方法是,,在Flash “文件”菜單下,選擇“發(fā)布設(shè)置”命令,,然后選擇“Flash” 選項(xiàng)卡,,選取“防止導(dǎo)入”,在下面的密碼區(qū)輸入“防止導(dǎo)入”的密碼進(jìn)行發(fā)布,。該密碼只有在源文件中可以看到,。
2.2運(yùn)用ActionScript編程
在Flash軟件中,可以運(yùn)用ActionScript編寫代碼控制動(dòng)畫的播放以及與用戶實(shí)現(xiàn)交互,,也可以通過編寫代碼對(duì)動(dòng)畫進(jìn)行加密,。ActionScript是一種程序設(shè)計(jì)語言,它的語法結(jié)構(gòu)與JavaScript的語法結(jié)構(gòu)基本相似,,在播放時(shí),,由Flash Player中的ActionScrip虛擬機(jī)來解釋并執(zhí)行[8]。Flash的最新版本是FlashCS6,,腳本語言為ActionScript3.0,簡(jiǎn)稱AS3,。在用Flash制作動(dòng)畫時(shí),,可以運(yùn)用AS3腳本語言在程序代碼中設(shè)置口令、時(shí)間鎖,、地址限制,、屏蔽右鍵和限制下載等功能。
2.2.1設(shè)置口令或時(shí)間限制
例如,,下面的代碼實(shí)現(xiàn)了根據(jù)口令或在限定時(shí)間內(nèi)播放動(dòng)畫的功能,。
stop();
Daylimit=new Date(2016,1,1);
todayDate=new Date();
_root.onEnterFrame =function(){
if(Key.isDown(13)){
if(a=="password")||(todayDate<Daylimit)
{ fscommand("fullscreen","true");gotoAndPlay(2);}
else fscommand("quit","true");}}
圖2Flash讀取XML文件過程這種代碼編寫方法通俗易懂,安全性也較低,??梢赃M(jìn)一步改進(jìn),將密碼與時(shí)間存儲(chǔ)在獨(dú)立存放的XML文件中,,然后通過讀取XML文件內(nèi)容生成密碼和比對(duì)時(shí)間,,但是程序編寫要復(fù)雜得多。Flash讀取XML文件的內(nèi)容需要有路徑的定義,、URL的請(qǐng)求和加載過程,,與讀取外部圖片或聲音的方法類似但調(diào)用的類不同。讀取XML的過程如圖2所示。
2.2.2運(yùn)用LoadMovie()命令
在把Flash作品發(fā)布成SWF文件之前,,可以將源文件分割成多個(gè)子文件,,然后把各個(gè).fla子文件分別發(fā)布成播放文件(如“child1.swf”、“child2.swf”等),,并放在不同的路徑下,,以相互嵌套的方式調(diào)用,可以起到保護(hù)作品的作用,。因?yàn)楫?dāng)該作品被其他用戶下載時(shí),,用戶只能下載它的主文件,而其他子文件不能被下載,。運(yùn)用LoadMovie()函數(shù)調(diào)用Flash子文件的方法為:LoadMovie(“某路徑下的子文件childx.swf”,,“mySWF”)。其中的路徑可以是相對(duì)路徑或絕對(duì)路徑,,x必須為具體數(shù)字,,如child1.swf。
2.3運(yùn)用Flash專業(yè)加密軟件
運(yùn)用專業(yè)軟件對(duì)Flash作品進(jìn)行加密更安全,,但是一般都需要付費(fèi),,如 GeneralEncryptor 、Swfkit,、DoSWF等,。這些軟件對(duì)SWF加密主要使用了動(dòng)態(tài)內(nèi)存修改技術(shù)(DMM)、ActionScript 混淆技術(shù),、加殼打包技術(shù),、綁定硬件(CPU、網(wǎng)卡,、硬盤)技術(shù)等,。
2.3.1動(dòng)態(tài)內(nèi)存修改技術(shù)
動(dòng)態(tài)內(nèi)存修改技術(shù)類加密軟件有DoSWF、Flashincrypt和SWFEncrypt等,,它們都是SWF文件加密工具,,能防止SWF文件被反編譯成源文件,通常使用動(dòng)態(tài)內(nèi)存修改技術(shù)和腳本混淆技術(shù)進(jìn)行保護(hù),。DoSWF軟件采用一些工具做代碼混淆,,降低了程序的可讀性,即使被破解了,,也很難看懂,,這種方法其實(shí)可以稱之為加密代碼。但是加密后的文件會(huì)明顯變大,,為了避免加密后文件過大的問題,,可以在加密前先將FLA源文件分解并生成多個(gè)SWF文件,,然后再進(jìn)行逐個(gè)加密。
2.3.2加殼打包技術(shù)
Swfkit是一款優(yōu)秀的加殼打包軟件,,它不僅能創(chuàng)建 Flash播放程序或屏幕保護(hù)程序,,而且能為它們建立安裝程序。用該軟件打包的EXE文件不容易被還原,,因?yàn)樗虬母袷讲煌贔lash軟件中打包的EXE,,而且調(diào)用IE中的Flash控件進(jìn)行播放,因此,,F(xiàn)lashtool,、Exe2swf等軟件無法將其反編譯;利用碩思閃客精靈,、ImperatorFLA,、閃客精靈之錘等破解軟件也不能提取作品中的元素。常用的加殼打包類加密軟件還有網(wǎng)刃數(shù)字版權(quán)保護(hù)平臺(tái),、FlashJestor,、Swfkit、Iceprojector,、Swishstudio等,。
2.3.3硬件綁定模式
GeneralEncryptor不僅支持SWF文件加密,而且也支持FLA文件加密,。用戶可以選擇不同的硬件綁定模式對(duì)用戶機(jī)器進(jìn)行綁定,,如選定CPU、主板,、Flash硬盤,、網(wǎng)卡等設(shè)備進(jìn)行“一機(jī)一碼”方式的授權(quán);它還支持水印效果,、播放次數(shù)限制、有效期設(shè)置,。常用的硬件綁定類加密軟件還有FlashEncryptor,、EasySWF、SWFprojection等,。
3幾種加密軟件的比較
為了驗(yàn)證SWF加密軟件的功能,,制作了一個(gè)Flash動(dòng)畫,并選用了幾種常用加密和解密軟件的試用版進(jìn)行了相關(guān)實(shí)驗(yàn),,結(jié)果如表1所示,。
通過實(shí)驗(yàn)發(fā)現(xiàn),(1)Exe2swf解密軟件功能較強(qiáng),,能將Flash播放器生成的EXE文件解密成SWF文件,,并通過解析SWF文件讀取文件頭,,顯示文件的基本信息,包括:文件版本,、文件大小,、是否壓縮、影格大小,、影格比例,、總幀數(shù)。(2)SWFEncrypt,、DoSWF等軟件的加密功能一般,,加密后生成的SWF文件明顯變大,而且能被碩思閃客精靈解密并提取元素,;(3)加殼打包類軟件的加密功能比較強(qiáng)大,,不能被Exe2swf解密,只是加密后生成的EXE文件明顯變大,。由此可知,,從安全角度考慮,加密時(shí)建議選取加殼打包的方法,。
4結(jié)束語
本文針對(duì)Flash動(dòng)畫的加密方法進(jìn)行了探討與實(shí)踐,。雖然市場(chǎng)上出現(xiàn)了各種各樣的SWF加密軟件,但是仍無法抵制一些著名的專業(yè)解密軟件和破解方法,。因此,,只有不斷增強(qiáng)全民的知識(shí)產(chǎn)權(quán)保護(hù)意識(shí),倡導(dǎo)購(gòu)買或使用經(jīng)過授權(quán)的作品或軟件,,才能將盜版現(xiàn)象降低到最低限度,。
參考文獻(xiàn)
[1] 詹青龍,,吳學(xué)會(huì),宗哲玲. Flash二維動(dòng)畫設(shè)計(jì)與制作[M]. 北京:清華大學(xué)出版社,,2010.
[2] 徐振國(guó),,孟祥增.Flash動(dòng)畫的內(nèi)容特征提取研究[J].電化教育研究,2015(6):5560.
?。?] 倪應(yīng)華,金炳堯.SWF矢量動(dòng)解析框架設(shè)計(jì)[J].計(jì)算機(jī)系統(tǒng)應(yīng)用,2010(3):202205.
?。?] 張曉彥,,張曉明.基于Flash動(dòng)畫的信息隱藏算法[J].計(jì)算機(jī)工程,2010(1):181183.
[5] 王繼州,,袁雪霞.一種SWF文件保護(hù)簡(jiǎn)單實(shí)現(xiàn)方案[J].數(shù)字技術(shù)與應(yīng)用,2012(8):169171.
?。?] 鄒蕾. 基于AES的Flash加密實(shí)現(xiàn)[J].電腦編程技巧與維護(hù),2014(22):115116.
[7] 仇國(guó)慶,,包俊杰,,曹冬梅,,等. 基于AES算法的ZigBee網(wǎng)絡(luò)加密方法研究[J].電子技術(shù)應(yīng)用,2014,40(4):5658.
?。?] 陳銀鳳. Flash中利用Action Script3.0實(shí)現(xiàn)圖像的扭曲效果[J].微型機(jī)與應(yīng)用,2012,,31(16):3537.