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. [MVC_Json序列化]Json字符串反序列化成C#对象

    上一篇中有Json序列化相关问题得到了解决. 那么结果集为Json串时,如何将Json串转成C#对象呢? 现举例说明: -现有如下字符串数据 string k = "{\"ring ...

  2. Bootstrap之Carousel不能自动播放的解决办法(转)

    Bootstrap是一个非常好的css/javaScript框架,尤其对于移动端的自适应和适配能力都比较强. 用Bootstrap自带的Carousel写了一个图片轮播的广告部分,用js调用后却出现了 ...

  3. ~/.config/user-dirs.dirs【桌面设置】

    # This file is written by xdg-user-dirs-update # If you want to change or add directories, just edit ...

  4. raw转qcow2

    raw转qcow2命令 : qemu-img convert -f raw test.img -O qcow2 test.img.qcow2 转晚之后,还需要virsh edit test,修改里面的 ...

  5. BZOJ4247挂饰

    Description     JOI君有N个装在手机上的挂饰,编号为1...N. JOI君可以将其中的一些装在手机上.     JOI君的挂饰有一些与众不同--其中的一些挂饰附有可以挂其他挂件的挂钩 ...

  6. 发生tcp丢包(拥堵、超时)重传

    可以根据wireshark的Seq序列号和Ack序列号来进行详细分析. 可见,网络丢包(可能是网络拥堵.也有可能是骨干网上有"防火墙"故意随机丢包,因为这个服务器的IP放在国外)对 ...

  7. jQuery插件解析

    简单的插件demo //sample:扩展jquery对象的方法,bold()用于加粗字体. (function ($) { $.fn.extend({ "bold": funct ...

  8. web.py框架入门

    在使用微信搭建公众平台的时候,使用的是web.py这个方便简单的框架,学习一下. 框架文档:http://webpy.org/docs/0.3/tutorial.zh-cn  按照文档的内容写一遍程序 ...

  9. MySQL exists的用法介绍

    有一个查询如下: 1 SELECT c.CustomerId, CompanyName   2 FROM Customers c   3 WHERE EXISTS(   4     SELECT Or ...

  10. PC端和移动端一些奇葩兼容性问题

    IE10默认在input框中输入内容时会显示一个'X',密码框会显示一个'小眼睛',怎么把这个默认的'X'或者'小眼睛'删除掉. 在password输入框显示一个“小眼睛”的按钮,去掉他的方法如下: ...