资源简介
用于js加密加密算法,采用js加密,c#可以解密加密算法,采用js加密,c#可以解密
代码片段和文件信息
//***************************************************************************************
// Autor:Tecky
// Date:2008-06-03
// Desc:xxtea 算法的C#加密实现
// e-mail:likui318@163.com
//
//
//***************************************************************************************
using System;
class XXTEA
{
public static string Encrypt(string source string key)
{
System.Text.Encoding encoder = System.Text.Encoding.UTF8;
//UTF8==>base64==>XXTEA==>base64
byte[] bytData = encoder.GetBytes(base64Encode(source));
byte[] bytKey = encoder.GetBytes(key);
if (bytData.Length == 0)
{
return ““;
}
return System.Convert.Tobase64String(ToByteArray(Encrypt(ToUInt32Array(bytData true) ToUInt32Array(bytKey false)) false));
}
public static string Decrypt(string source string key)
{
if (source.Length == 0)
{
return ““;
}
// reverse
System.Text.Encoding encoder = System.Text.Encoding.UTF8;
byte[] bytData = System.Convert.Frombase64String(source);
byte[] bytKey = encoder.GetBytes(key);
return base64Decode(encoder.GetString(ToByteArray(Decrypt(ToUInt32Array(bytData false) ToUInt32Array(bytKey false)) true)));
}
private static UInt32[] Encrypt(UInt32[] v UInt32[] k)
{
Int32 n = v.Length - 1;
if (n < 1)
{
return v;
}
if (k.Length < 4)
{
UInt32[] Key = new UInt32[4];
k.CopyTo(Key 0);
k = Key;
}
UInt32 z = v[n] y = v[0] delta = 0x9E3779B9 sum = 0 e;
Int32 p q = 6 + 52 / (n + 1);
while (q-- > 0)
{
sum = unchecked(sum + delta);
e = sum >> 2 & 3;
for (p = 0; p < n; p++)
{
y = v[p + 1];
z = unchecked(v[p] += (z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[p & 3 ^ e] ^ z));
}
y = v[0];
z = unchecked(v[n] += (z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[p & 3 ^ e] ^ z));
}
return v;
}
private static UInt32[] Decrypt(UInt32[] v UInt32[] k)
{
Int32 n = v.Length - 1;
if (n < 1)
{
return v;
}
if (k.Length < 4)
{
UInt32[] Key = new UInt32[4];
k.CopyTo(Key 0);
k = Key;
}
UInt32 z = v[n] y = v[0] delta = 0x9E3779B9 sum e;
Int32 p q = 6 + 52 / (n + 1);
sum = unchecked((UInt32)(q * delta));
while (sum != 0)
{
e = sum >> 2 & 3;
for (p = n; p > 0; p--)
{
z = v[p - 1];
y = unchecked(v[p] -= (z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[p & 3 ^ e] ^ z));
}
z = v[n];
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 8084 2008-09-01 16:13 xxtea.js
文件 5154 2008-09-01 16:15 xxtea.cs
文件 4980 2008-07-23 11:52 jsPoint.htm
----------- --------- ---------- ----- ----
18218 3
- 上一篇:c#连接sql,简易增删改查
- 下一篇:源代码行数统计工具含C#源码
相关资源
- VS插件源码JSLint(JS辅助工具)
- C#有界面局域网DES UDP加密通讯程序
- JSON C#与服务器通讯
- Json实用类
- 各种方式对excel导出导入
- C# JSON解析(Newtonsoft.Json)
- C#加密、安全与软件注册(9例).rar
- 配置文件内容加密工具源码(基于b
- 基于RSA和DES加密以及哈希校验的点对
- C# AES加密解密小工具
- Rony.DotNetCore.Solution.zip
- C#RSA加密解密签名和验证签名的小
- 网页js与本地C#程序 websocket通讯实现打
- AES文件加密.rar
- C#使用pem格式的密钥对文件来做RSA加解
- c#文件加密解密工具含源码及工程文件
- 图像加密算法与实践
- ASP.NET微信支付接口调用Demo JSAPI
- Newtonsoft.Json dll
- C# MVC 封装百度的EChart完整
- Photoshop for 脚本生成插件(JS/VB/C#)
- 企业设备管理系统
- C#加密、安全与软件注册
- C#Json文件读写修改类附带操作程序.
-
Json、xm
l、CSV数据互转工具 - C#文件加密解密及备份恢复工具
- 基于html5、JS实现的二维码扫码
- C#作的文件加密器很不错的
- C#操作TrueCrypt加密解密
- asp.net网上书店
评论
共有 条评论