js中加密解密程序代码

 代码如下 复制代码

function MyDecode(str)
{
var i,k,str2="";

k=str.split(".");

for(i=0;i<k.length;i++)
{
str2+=String.fromCharCode(k[i]^0x12);
}
return str2;
}
myrand="46.97.115";

WScript.echo(MyDecode(myrand));

function Encrypt(str)
{
var monyer = new Array();
var i, s, str;

for (i = 0; i < str.length; i++)
{
monyer += str.charCodeAt(i)^0x12
monyer+=".";
}

return monyer;
}

WScript.Echo(Encrypt("<script>alert('ok')</script>").replace(/.$/,""));

下面再发一个base64的加密方法

 代码如下 复制代码

<!doctype html public "-//w3c//dtd html 4.01 transitional//en"
"http://www.w3.org/tr/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=gb2312">
<title>base64编码加密</title>
</head>

<body>
<table width="773" border="0" align="center" cellpadding="0" cellspacing="0">
  <tr>
    <td>
 <script language=javascript>
var base64encodechars = "abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz0123456789+/";
var base64decodechars = new array(
    -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
    -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
    -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,
    52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1,
    -1,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,
    15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
    -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
    41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1);

function base64encode(str) {
    var out, i, len;
    var c1, c2, c3;

    len = str.length;
    i = 0;
    out = "";
    while(i < len) {
    c1 = str.charcodeat(i++) & 0xff;
    if(i == len)
    {
        out += base64encodechars.charat(c1 >> 2);
        out += base64encodechars.charat((c1 & 0x3) << 4);
        out += "==";
        break;
    }
    c2 = str.charcodeat(i++);
    if(i == len)
    {
        out += base64encodechars.charat(c1 >> 2);
        out += base64encodechars.charat(((c1 & 0x3)<< 4) | ((c2 & 0xf0) >> 4));
        out += base64encodechars.charat((c2 & 0xf) << 2);
        out += "=";
        break;
    }
    c3 = str.charcodeat(i++);
    out += base64encodechars.charat(c1 >> 2);
    out += base64encodechars.charat(((c1 & 0x3)<< 4) | ((c2 & 0xf0) >> 4));
    out += base64encodechars.charat(((c2 & 0xf) << 2) | ((c3 & 0xc0) >>6));
    out += base64encodechars.charat(c3 & 0x3f);
    }
    return out;
}

function base64decode(str) {
    var c1, c2, c3, c4;
    var i, len, out;

    len = str.length;
    i = 0;
    out = "";
    while(i < len) {
    /* c1 */
    do {
        c1 = base64decodechars[str.charcodeat(i++) & 0xff];
    } while(i < len && c1 == -1);
    if(c1 == -1)
        break;

    /* c2 */
    do {
        c2 = base64decodechars[str.charcodeat(i++) & 0xff];
    } while(i < len && c2 == -1);
    if(c2 == -1)
        break;

    out += string.fromcharcode((c1 << 2) | ((c2 & 0x30) >> 4));

    /* c3 */
    do {
        c3 = str.charcodeat(i++) & 0xff;
        if(c3 == 61)
        return out;
        c3 = base64decodechars[c3];
    } while(i < len && c3 == -1);
    if(c3 == -1)
        break;

    out += string.fromcharcode(((c2 & 0xf) << 4) | ((c3 & 0x3c) >> 2));

    /* c4 */
    do {
        c4 = str.charcodeat(i++) & 0xff;
        if(c4 == 61)
        return out;
        c4 = base64decodechars[c4];
    } while(i < len && c4 == -1);
    if(c4 == -1)
        break;
    out += string.fromcharcode(((c3 & 0x03) << 6) | c4);
    }
    return out;
}

function utf16to8(str) {
    var out, i, len, c;

    out = "";
    len = str.length;
    for(i = 0; i < len; i++) {
    c = str.charcodeat(i);
    if ((c >= 0x0001) && (c <= 0x007f)) {
        out += str.charat(i);
    } else if (c > 0x07ff) {
        out += string.fromcharcode(0xe0 | ((c >> 12) & 0x0f));
        out += string.fromcharcode(0x80 | ((c >>  6) & 0x3f));
        out += string.fromcharcode(0x80 | ((c >>  0) & 0x3f));
    } else {
        out += string.fromcharcode(0xc0 | ((c >>  6) & 0x1f));
        out += string.fromcharcode(0x80 | ((c >>  0) & 0x3f));
    }
    }
    return out;
}

function utf8to16(str) {
    var out, i, len, c;
    var char2, char3;

    out = "";
    len = str.length;
    i = 0;
    while(i < len) {
    c = str.charcodeat(i++);
    switch(c >> 4)
    {
      case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7:
        // 0xxxxxxx
        out += str.charat(i-1);
        break;
      case 12: case 13:
        // 110x xxxx   10xx xxxx
        char2 = str.charcodeat(i++);
        out += string.fromcharcode(((c & 0x1f) << 6) | (char2 & 0x3f));
        break;
      case 14:
        // 1110 xxxx  10xx xxxx  10xx xxxx
        char2 = str.charcodeat(i++);
        char3 = str.charcodeat(i++);
        out += string.fromcharcode(((c & 0x0f) << 12) |
                       ((char2 & 0x3f) << 6) |
                       ((char3 & 0x3f) << 0));
        break;
    }
    }

    return out;
}

function doit() {
    var f = document.f
    f.output.value = base64encode(utf16to8(f.source.value))
    f.decode.value = utf8to16(base64decode(f.output.value))
}
</script>
<h1 align="center">base64编码加密
</h1>
<form name="f">
原码<br>
<textarea name="source" rows=4 cols=60 wrap="soft"></textarea><br><br>
base64 encode<br>
<textarea name="output" rows=4 cols=60 wrap="soft"></textarea><br><br>
base64 decode<br>
<textarea name="decode" rows=4 cols=60 wrap="soft"></textarea><br><br>
<input type=button value="转换" onclick="doit()">
</form>
</td>
  </tr>
</table>
</body>
</html>

时间: 2024-10-27 03:22:38

js中加密解密程序代码的相关文章

python有证书的加密解密程序代码

最近在做python的加解密工作,同时加完密的串能在php上能解出来,网上也找了一些靠谱的资料,刚好也有时间我就总结了一下python在加密与解密这块的代码,今后可能还能用的上.相对于php而言python这块加解密组件较多的,分别是:     python-crypto - 这个组件是基本组件,使用的函式相对比较复杂.     ezPyCrypto - 相对简单,但他作出?淼墓?皆课薹ㄓ肫渌?淌较嗉嫒荨?br />     SSLCrypto - 与 ezPyCrypto 是相同一个作者开发,

mybatis-RSA在js中加密,但是后台不能解密,总是在报错

问题描述 RSA在js中加密,但是后台不能解密,总是在报错 RSA在js中加密,但是后台不能解密,总是在报错,data must be longer than 64 bytes,我自己使用java加密解密就不报错,不知道为什么,有知道的没,help me啊 解决方案 你JS加密方式出来的数据格式有问题,你直接打印出来,对比java的看看 还要注意你的JS加密后的数据类型,是字符串还是byte 解决方案二: 参考:http://blog.163.com/linfeng_0212/blog/stat

求帮助啊 急用啊-利用C语言设计简单的文件加密解密程序

问题描述 利用C语言设计简单的文件加密解密程序 利用C语言设计简单的文件加密解密程序,并通过代码实现,希望得到源代码. 解决方案 最简单的用xor实现加密.http://blog.csdn.net/fdipzone/article/details/20413631 解决方案二: http://blog.163.com/chatter@126/blog/static/12766566120101020102247603/http://blog.csdn.net/szhhck/article/det

PHP字符串加密解密程序例子

最常见的应用在用户登录以及一些API数据交换的场景. 笔者收录了一些比较经典的PHP加密解密函数代码,分享给大家.加密解密原理一般都是通过一定的加密解密算法,将密钥加入到算法中,最终得到加密解密结果. 1.非常给力的authcode加密函数,Discuz!经典代码(带详解):    代码如下 复制代码 function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {       // 动态密匙长度,相同的明文会

Android、iOS和Java通用的AES128加密解密示例代码_java

前言 移动端越来越火了,我们在开发过程中,总会碰到要和移动端打交道的场景,比如android和iOS的打交道.为了让数据交互更安全,我们需要对数据进行加密传输. 这篇文章给大家分享AES的加密和解密.Android和ios通用的AES加密算法.大家可以直接集成到自己的项目.服务器接口如果是用Java写的话.整个框架都完美了.如果是.NET编写的后台接口的话.得改造一下哦 IOS加密 /*加密方法*/ (NSString *)AES256EncryptWithPlainText:(NSString

PHP中加密解密函数与DES加密解密

例子,php加密解密的例子  代码如下 复制代码 加密函数 /* *功能:对字符串进行加密处理 *参数一:需要加密的内容 *参数二:密钥 */ function passport_encrypt($str,$key){ //加密函数  srand((double)microtime() * 1000000);  $encrypt_key=md5(rand(0, 32000));  $ctr=0;  $tmp='';  for($i=0;$i<strlen($str);$i++){   $ctr=

aes对称加密解密-求解一个 单表替代密码 和aes加密解密 c++代码

问题描述 求解一个 单表替代密码 和aes加密解密 c++代码 如题 要用vs2015做 最好一天内搞定 简单易懂 小白急用 解决方案 AES加密算法(C++实现,附源码) http://download.csdn.net/detail/cleopard/7245981 单表置换密码的C++代码实现 http://download.csdn.net/detail/zjj7188/9301155 解决方案二: http://www.tuicool.com/articles/rMzuQrhttp:/

gruntfile.js中的一句代码,求大虾解释下什么意思

问题描述 gruntfile.js中的一句代码,求大虾解释下什么意思 require('load-grunt-tasks')(grunt, {scope: 'devDependencies'}); 请问一下这串代码是什么意思,在有些项目的Gruntfile.js中没有这串require代码也可以 解决方案 Only load from devDependencies 参考:http://npm.taobao.org/package/load-grunt-tasks

在C#中自己写程序代码合并两个ACCESS数据库,如表a1.姓名插入a2.姓名里,我是这样写的,可就是不对

问题描述 在C#中自己写程序代码合并两个ACCESS数据库,如表a1.姓名插入a2.姓名里,我是这样写的,可就是不对if(this.openFileDialog1.ShowDialog()==DialogResult.OK){this.textBox2.Text=openFileDialog1.FileName.ToString();}try{if(textBox2.Text!=null){stringlink_tex0="Provider=Microsoft.Jet.OLEDB.4.0;Dat