webgame开发中的文件解密

简介: 上一篇讲的是文件的加密,这一篇记录一下如何加载并显示图片。   因为图片文件经过加密,已经成了二进制流的文件了(一堆乱码),只能使用URLStream来加载资源了。 这里有一点要注意:URLStream中的读取操作是非阻塞的,在读取数据之前必须使用bytesAvailable属性来确定是否能够获取足够的数据,如何不能获取足够的数据,将引发EOFError异常。

上一篇讲的是文件的加密,这一篇记录一下如何加载并显示图片。

 

因为图片文件经过加密,已经成了二进制流的文件了(一堆乱码),只能使用URLStream来加载资源了。

这里有一点要注意:URLStream中的读取操作是非阻塞的,在读取数据之前必须使用bytesAvailable属性来确定是否能够获取足够的数据,如何不能获取足够的数据,将引发EOFError异常。

 

主要思路:

1、加载加密后的资源,使用URLStream

2、调用解密方法,获取解密后的数据

3、使用Loader类的loadBytes方法加载资源

 

   1: var urlLoader:URLStream = new URLStream();
   2: var url:String = getEncryptURL(url);    //通过需要加载的资源url,来获取实际需要加载的资源地址,如xx.png实际将请求xx.p
   3:  
   4: //监听urlLoader的事件
   5: //Event.Complete、IOErrorEvent.IO_ERROR、ProgressEvent.PROGRESS、HTTPStatusEvent.HTTP_STATUS、Event.OPEN
   6:  
   7: var req:URLRequest = new URLRequest(url);
   8:  
   9: urlLoadedCount = 0;
  10:  
  11: urlLoader.load(req);
  12:  
  13:  
  14:  
  15:  
  16:  
  17: //onCompleteHandler方法中
  18: var byte:ByteArray;
  19: var byteLen:int;
  20:  
  21: try 
  22: {
  23:     byteLen = urlLoader.bytesAvailable;
  24: }
  25: catch(e:Error)
  26: {
  27:     if (urlLoadedCount++ > 3)
  28:     {
  29:         return ;
  30:     }
  31:     
  32:     //reload 重新加载,直至超过3次
  33:     
  34:     return ;
  35: }
  36:  
  37: urlLoadedCount = 0;
  38:  
  39: byte = new ByteArray();
  40: urlLoader.readBytes(byte, 0, byteLen);
  41: byte = EncryptUtils.DeEncrypt(byte); //对数据进行解密操作,与上一篇中的加密方法对应
  42: byte.position = 0;
  43:  
  44: //开始加载图片
  45: var loader = new Loader();
  46:  
  47: //监听Event.Complete事件
  48: loader.contentLoaderInfo.removeEventListener(Event.COMPLETE, loadImgCompleteHandler);
  49:  
  50: var context:LoaderContext = new LoaderContext();
  51: context.applicationDomain = ApplicationDomain.currentDomain;
  52: context.securityDomain = SecurityDomain.currentDomain;
  53:  
  54: loader.loadBytes(byte, context);
  55:  
  56:  
  57: //loadImgCompleteHandler方法
  58: 此时loader.content已经为Bitmap类了,使用addChild即可完成图片的加载
  59:  
  60:  
  61: //如果要加载的是xml、txt等文件内容,则无需此方法,使用byte.readUTFBytes(byte.bytesAvailable)便可得到解密后的字符串了
  62:  

 

 

更多参考:

flash.display.Loader>>

flash.display.Bitmap>>

flash.net.URLStream>>

目录
相关文章
|
10月前
|
弹性计算 人工智能 数据管理
AI场景下的对象存储OSS数据管理实践
本文介绍了ECS和OSS的操作流程,分为两大部分。第一部分详细讲解了ECS的登录、密码重置、安全组设置及OSSUTIL工具的安装与配置,通过实验创建并管理存储桶,上传下载文件,确保资源及时释放。第二部分则聚焦于OSSFS工具的应用,演示如何将对象存储挂载为磁盘,进行大文件加载与模型训练,强调环境搭建(如Conda环境)及依赖安装步骤,确保实验结束后正确清理AccessKey和相关资源。整个过程注重操作细节与安全性,帮助用户高效利用云资源完成实验任务。
935 161
CCF推荐A类会议和期刊总结:计算机体系结构/并行与分布计算/存储系统领域
中国计算机学会(CCF)2022年版推荐目录涵盖了计算机体系结构、并行与分布计算、存储系统领域的多个A类会议和期刊。本文汇总了这些顶级资源的全称、出版社、dblp网址及领域。包括《ACM计算机系统汇刊》、《ACM存储汇刊》等期刊,以及ACM PPoPP、USENIX FAST等会议,为研究人员提供了重要学术参考。
12879 64
CCF推荐A类会议和期刊总结:计算机体系结构/并行与分布计算/存储系统领域
|
Java API C++
Java JNI开发时常用数据类型与C++中数据类型转换
Java JNI开发时常用数据类型与C++中数据类型转换
516 0
|
缓存 安全 Java
在 Java 中如何将 ArrayList 设为只读
【8月更文挑战第23天】
228 0
|
Web App开发 JavaScript 前端开发
Windows 10上安装Node.js的初学者指南
Node.js是是一个强大的JavaScript运行时环境,建立在Chrome的V8 JavaScript引擎上,让你能够在服务器端运行JavaScript。 通过本教程,你将学会如何设置Node.js和npm(节点包管理器等现代Web开发的必备工具。无论你是希望构建Web应用程序、创建服务器端脚本,还是涉足全栈开发,安装Node.js都是你的第一步。那么,让我们开始吧!
|
编译器 C++
【C++进阶(三)】STL大法--vector迭代器失效&深浅拷贝问题剖析
【C++进阶(三)】STL大法--vector迭代器失效&深浅拷贝问题剖析
vue3打包war压缩包配置
vue3打包war压缩包配置
234 0
|
移动开发 JavaScript 小程序
uView Textarea 文本域
uView Textarea 文本域
206 0
|
存储 人工智能 安全
能多端登录的无影云电脑玩的就是“花样”!
众所周知,无影办公是近年来较为流行的一种新型办公方式,其采用云计算、虚拟化、网络传输等技术,实现了办公终端的全面云化。这种方式在传统的办公场景中,具有很多优势,使用无影硬件终端可以让员工更加高效地完成工作,提高了企业的生产效率。那么本文就来简单分享一下能多端登录的无影云电脑。
1945 2
能多端登录的无影云电脑玩的就是“花样”!
|
XML 数据格式
SpringMVC中拦截器使用实践详解
SpringMVC中拦截器使用实践详解
223 0