private var loader:URLLoader;
...
private function init():void
{
loader = new URLLoader;
req=URLRequest = new URLRequest("1.txt");
  //req.dataFormat = URLLoaderDataFormat.BINARY;
loader.load(req);
loader.addEventListener(Event.COMPLETE,oncomlete);
}
private function save(bt:ByteArray):void
{
  var fr:FileReference = new fileReference;
  fr.save(bt,"2.txt");
}
private function oncomplete(e:Event):void
{
  if(true)
  {
   var str:String=loader.data;
   trace("src///////");
   trace(str);
  str=secret(str);
   var bt:ByteArray = new ByteArray;
    bt.writeUTFBytes(str);
    bt.compress(); 
  }   
  else
  {
     
    var bt:ByteArray=loader.data;
      bt.uncompress();
     str=bt.readUTFButes(bt.length);
   str=unsecret(str);
    trace("unsecret//////////////\n"+str)
  }
} private var add_key:Array=[800,650,400,525,100,250]//间距大于122(z的unicode值)
private var range:Array=[65,91,97,123]//65,70,75,91,97,100,123
private var xor_key:Array=[0xaa,0xbb]
private var pos_key:Array=[8,4]// private function secret(src:String):String
{
var res:String="";
var i:int,len:int,unicode:int;
len=src.length
for(i=0;i<len;i++)
{
unicode=str.charCodeAt(i);
var idx=index(unicode);
res+=String.fromCharCode(xor(add_key[idx]+unicode+random(i)))
}
res=pos(res);
return res;
}
i
private function xor(v:int):int
{
var i:int,len:int;
len=xor_key.length
for(i=0;i<len;i++)
{
v^=xor_key[i];
}
return v;
} private function random(i:int):int
{
swicth(i%4)
{
case 0:
if(i%9==0)
return((1-Math.sin(i))*(i%100)>>0);
else
return((1-Math.sin(i))*(i%200)>>0);
case 1:
return ((1-Math.cos(i))*(i%300)>>0);
case 2:
return ((1-Math.cos(i)*Math.sin(i))*(i%400)>>0);
case 3
if(i%3==0)
return((1-Math.sin(i)*Math.cos(i)*Math.cos(i))*(i%500)>>0);
else
return((1-Math.sin(i)*Math.cos(i)*Math.cos(i))*(i%600)>>0);
}
return 1;
} private function index(u:int):int
{
if(u>64&&u<91||u>96&&u<123)
{
var i:int,len:int;
len=range.length-1;
for(i=0;i<len;i++)
{
if(u>=range[i]&&u<range[i+1])
break;
}
return i
}
else
return 5
} private function index2(u:int):int
{
var i:int,len:int;
len=add_key.length-1;
for(i=0;i<len;i++)
{
if(u>=add_key[i]&&u<=add_key[i]+123)
break;
}
return u-add_key[i];
} private function unsecret(src:String):String
{
src=unpos(src);
var res:String="";
var i:int,len:int;
var u:int;
len=src.length;
for(i=0;i<len;i++)
{
u=xor(src.charCodeAt(i)-random(i));
u=index2(u);
res+=String.formCharCode(u);
}
return res;
} private function pos(src:String):String
{
  var i,j,k,len,len1,n;
  var res:String;
  len = pos_key.length;
  len1=src.length;
  for(i,len)
  {
    src=res||src;
    res="";
    for(j,pos_key[i])
    {
      n=len1%pos_key[i];
      if(n>0)
        n=pos_key[i]-n;
       while(n--)
        src+='#';
        len1=src.length;
        k=j;
        while(k<len1)
        {
          res+=src.charAt(k);
          k+=pos_key[i]
        }
    }   }
return res;
} private function unpos(src:String):String
{
 
 var i,j,k,len,len1,n;
  var res:String;
  len = pos_key.length;
  len1=src.length;
  for(i,len)
  {
    dis=Math.ceil(len1/pos_key[i]);
    src=res||src;
    res="";
    for(j,dis)
    {
      k=j;
      while(k<len1)
      {
        res+=src.charAt(k)
        k+=dis;
      }
    }
  }
return res;
}
[65,70,80,91,97,110,123]

as3 代码加解密的更多相关文章

  1. Java 使用AES/CBC/PKCS7Padding 加解密字符串

    介于java 不支持PKCS7Padding,只支持PKCS5Padding 但是PKCS7Padding 和 PKCS5Padding 没有什么区别要实现在java端用PKCS7Padding填充, ...

  2. web.config/app.config敏感数据加/解密的二种方法

    一 建立虚拟目录  http://localhost/EncryptWebConfig,并添加web.config,其中包含数据库连接字符串: <connectionStrings>    ...

  3. Rsa加解密Java、C#、php通用代码 密钥转换工具

    之前发了一篇"TripleDes的加解密Java.C#.php通用代码",后面又有项目用到了Rsa加解密,还是在不同系统之间进行交互,Rsa在不同语言的密钥格式不一样,所以过程中主 ...

  4. PHP RSA加解密详解(附代码)

    前言:RSA加密一般用在涉及到重要数据时所使用的加密算法,比如用户的账户密码传输,订单的相关数据传输等. 加密方式说明:公钥加密,私钥解密.也可以  私钥加密,公钥解密 一.RSA简介 RSA公钥加密 ...

  5. 彻底告别加解密模块代码拷贝-JCE核心Cpiher详解

    前提 javax.crypto.Cipher,翻译为密码,其实叫做密码器更加合适.Cipher是JCA(Java Cryptographic Extension,Java加密扩展)的核心,提供基于多种 ...

  6. 惊呆了!不改一行 Java 代码竟然就能轻松解决敏感信息加解密|原创

    前言 出于安全考虑,现需要将数据库的中敏感信息加密存储到数据库中,但是正常业务交互还是需要使用明文数据,所以查询返回我们还需要经过相应的解密才能返回给调用方. ps:日常开发中,我们要有一定的安全意识 ...

  7. C/C++ 对代码节的动态加解密

    加壳的原理就是加密或者压缩程序中的已有资源,然后当程序执行后外壳将模拟PE加载器对EXE中的区块进行动态装入,下面我们来自己实现一个简单的区块加解密程序,来让大家学习了解一下壳的基本运作原理. 本次使 ...

  8. 数据採集器服务——Socket(今天才发现AES加解密代码跟贴的时候不一样,貌似乱码,不知什么情况)

    近期刚做的一个项目.关于 Socket TCP 通信. 需求方提供了一个 ARM 机器,及数据採集器,须要我做一个服务端与数据採集器进行交互. 目的: 数据採集器:定时将读取到的数据发送到服务端. 服 ...

  9. SWF加解密资源索引之加密混淆篇【转】

    ============================ SWF加解密资源索引之加密混淆篇 ============================ [心得] swf加密混淆器(带源码) http:/ ...

随机推荐

  1. hadoop修改MR的提交的代码程序的副本数

    hadoop修改MR的提交的代码程序的副本数 Under-Replicated Blocks的数量很多,有7万多个.hadoop fsck -blocks 检查发现有很多replica missing ...

  2. 基于ubuntu 14搭建nginx+php+mysql环境

    基于最新的Ubuntu 14.04(2014年9月)搭建nginx.php.mysql环境, 以下全部命令行操作: 1 由于需要大量的权限操作,方便起见临时提升权限,使用root账号 sudo su ...

  3. 易货beta版本项目展示报告

    一.团队成员和个人博客地址 PM:刘猛 开发人员:胡亚坤,董元财 测试人员:马汉虎,赖彦谕 团队名:bestRW 团队博客地址:http://www.cnblogs.com/niceRW/ 董元财:h ...

  4. 根据标记清空页面中所有的input对象

    function clear1(flag) { //获取页面中所有的input对象 var inputs = document.getElementsByTagName("input&quo ...

  5. gulp 基本使用

    1, gulp 依赖node, 使用gulp 之前,要先安装node.  Node 安装完成后,它自带npm. Npm: node package manager 就是node 包管理器. 用过jav ...

  6. no route to host

    防火墙没有关闭: systemctl stop firewalld

  7. stm32串口输出丢失第一个字符的问题及原因

    因为TC和TXE 标志位在复位的时候会被置1,导致第一次没有发送. 所以在初始化串口的时候可以增加一句 USARTx->SR=0;(如 USART1->SR=0;)

  8. linux centos 安装mysql

    安装步骤 http://www.cnblogs.com/gaojupeng/p/5727069.html 下面这个报错 主要还是在 题啊加软连接的   命令出了问题 1.启动  报错 mysqld_s ...

  9. jquery获得option的值和对option进行操作

    Query获取Select元素,并选择的Text和Value: $("#select_id").change(function(){//code...}); //为Select添加 ...

  10. C#面向对象特征的具体实现及作用详解

    转自:http://www.jb51.net/article/42390.htm 众所周知,面向对象编程的特点为:封装.继承.多态.C#是一门完全面向对象的语言,由于比Java推出的时间还要晚,所以对 ...