Il y a quelque temps, j'ai vu quelqu'un mentionner sur flashseer : les fichiers SWF peuvent être transférés via socket, ce qui fait que les utilisateurs ne peuvent pas obtenir les fichiers SWF... A cette époque, la décompilation AS3 n'était pas encore sortie, donc je m'en fichais à propos de la protection du programme. Avec la décompilation Les gens qui ne veulent pas que les autres voient le code source du programme sont plus anxieux...
L'idée de transmettre des fichiers swf via des sockets vers éviter de divulguer le code source (applicable uniquement à as3) : laissez le chargeur (réception) du programme principal swf) se connecter au programme d'arrière-plan via le socket, puis demander le fichier du programme principal requis. L'arrière-plan lit les données du programme principal. et l'envoie au chargeur du programme principal via le socket. Le swf frontal applique la méthode Loader.loadBytes pour afficher le fichier du programme principal
Voici le programme source du test :
package { import flash.display.Sprite; import flash.net.Socket; import flash.events.*; import flash.errors.IOError; import flash.display.Loader; public class SocketTest extends Sprite { public function SocketTest() { var socket = new Socket(); socket.connect("localhost", 5277); socket.addEventListener(Event.CLOSE, closeHandler); socket.addEventListener(Event.CONNECT, connectHandler); socket.addEventListener(IOErrorEvent.IO_ERROR, ioErrorHandler); socket.addEventListener(SecurityErrorEvent.SECURITY_ERROR, securityErrorHandler); socket.addEventListener(ProgressEvent.SOCKET_DATA, socketDataHandler); var response:String; function writeln(str:String):void { str+=""; try { socket.writeUTFBytes(str); } catch (e:IOError) { trace(e); } } function sendRequest():void { trace("sendRequest"); response=""; writeln('bin'); socket.flush(); } function readResponse():void { //接受数据 var str:String=socket.readUTFBytes(socket.bytesAvailable); response+=str; //当数据以end结束的时候,数据传输结束 if (StringUtil.endsWith(str,'end')) { response=response.substr(0,response.length-3); //把字符串转换为ByteArray var ba=Base64.decodeToByteArray(response); //trace('bytearray=====',ba); var l:Loader = new Loader(); //从 ByteArray 对象中所存储的二进制数据中加载。 l.loadBytes(ba); //trace(l.content); addChild(l); } } function closeHandler(e:Event):void { trace("Socket closed! "); } function connectHandler(e:Event):void { trace("Socket connected!"); sendRequest(); } function ioErrorHandler(e:IOErrorEvent):void { trace("IOError!"); } function securityErrorHandler(e:SecurityErrorEvent):void { trace("SecurityError!"); } function socketDataHandler(e:ProgressEvent):void { trace("Socket have data!"); readResponse(); } } } }
//后台scoket程序,由于适用php写比较简单,就用php写了. //error_reporting(E_ALL); error_reporting(0); set_time_limit(0); ob_implicit_flush(); $address = 'localhost'; $port = 5277; if (($sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) < 0) { echo 'socket_create() failed: reason: ' . socket_strerror($sock) . '\n'; } if (($ret = socket_bind($sock, $address, $port)) < 0) { echo 'socket_bind() failed: reason: ' . socket_strerror($ret) . '\n'; } if (($ret = socket_listen($sock, 5)) < 0) { echo 'socket_listen() failed: reason: ' . socket_strerror($ret) . '\n'; } echo 'connect…………….'; do { if (($msgsock = socket_accept($sock)) < 0) { echo 'socket_accept() failed: reason: ' . socket_strerror($msgsock) . '\n'; break; } do { socket_recv($msgsock, $buf, 2048, 0); if ($buf == "") { socket_close($msgsock); echo "some one quit"; break; } else if ($buf == "bin") { //读取主程序数据 $f = fopen('main.swf','r'); $data = fread($f,filesize('main.swf')); fclose($f); //转换为字符串 //echo base64_encode($data); $talkback = base64_encode($data).'end'; } //发送 socket_send($msgsock, $talkback, strlen($talkback),0); } while (true); socket_close($msgsock); } while (true); socket_close($sock);