############################################################
# #
# The implementation of PHPRPC Protocol 3.0 #
# #
# xxtea.py #
# #
# Release 3.0.0 #
# Copyright (c) 2005-2008 by Team-PHPRPC #
# #
# WebSite: http://www.phprpc.org/ #
# http://www.phprpc.net/ #
# http://www.phprpc.com/ #
# http://sourceforge.net/projects/php-rpc/ #
# #
# Authors: Ma Bingyao <andot@ujn.edu.cn> #
# #
# This file may be distributed and/or modified under the #
# terms of the GNU Lesser General Public License (LGPL) #
# version 3.0 as published by the Free Software Foundation #
# and appearing in the included file LICENSE. #
# #
############################################################
#
# XXTEA encryption arithmetic library.
#
# Copyright (C) 2005-2008 Ma Bingyao <andot@ujn.edu.cn>
# Version: 1.0
# LastModified: Oct 5, 2008
# This library is free. You can redistribute it and/or modify it.
import struct
_DELTA = 0x9E3779B9
def _long2str(v, w):
n = (len(v) - 1) << 2
if w:
m = v[-1]
if (m < n - 3) or (m > n): return ''
n = m
s = struct.pack('<%iL' % len(v), *v)
return s[0:n] if w else s
def _str2long(s, w):
n = len(s)
m = (4 - (n & 3) & 3) + n
s = s.ljust(m, "\0")
v = list(struct.unpack('<%iL' % (m >> 2), s))
if w: v.append(n)
return v
def encrypt(str, key):
if str == '': return str
v = _str2long(str, True)
k = _str2long(key.ljust(16, "\0"), False)
n = len(v) - 1
z = v[n]
y = v[0]
sum = 0
q = 6 + 52 // (n + 1)
while q > 0:
sum = (sum + _DELTA) & 0xffffffff
e = sum >> 2 & 3
for p in xrange(n):
y = v[p + 1]
v[p] = (v[p] + ((z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[p & 3 ^ e] ^ z))) & 0xffffffff
z = v[p]
y = v[0]
v[n] = (v[n] + ((z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[n & 3 ^ e] ^ z))) & 0xffffffff
z = v[n]
q -= 1
return _long2str(v, False)
def decrypt(str, key):
if str == '': return str
v = _str2long(str, False)
k = _str2long(key.ljust(16, "\0"), False)
n = len(v) - 1
z = v[n]
y = v[0]
q = 6 + 52 // (n + 1)
sum = (q * _DELTA) & 0xffffffff
while (sum != 0):
e = sum >> 2 & 3
for p in xrange(n, 0, -1):
z = v[p - 1]
v[p] = (v[p] - ((z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[p & 3 ^ e] ^ z))) & 0xffffffff
y = v[p]
z = v[n]
v[0] = (v[0] - ((z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[0 & 3 ^ e] ^ z))) & 0xffffffff
y = v[0]
sum = (sum - _DELTA) & 0xffffffff
return _long2str(v, True)
if __name__ == "__main__":
print decrypt(encrypt('Hello XXTEA!', '16bytelongstring'), '16bytelongstring')
分享到:
相关推荐
Python社区为了方便开发者使用XXTEA加密算法,开发了对应的库,这就是"Python的XXTEA加密算法库"。 XXTEA加密算法的核心在于它的轮函数,该函数通过一系列复杂的加法、异或和位移操作来混淆输入数据,使得破解变得...
python库。 资源全名:xxtea-2.0.0.post0-cp38-cp38-win_amd64.whl
总的来说,这个压缩包提供的内容是Cocos2dx V3.x项目中实现XXTEA加密的关键部分,通过Python脚本加密数据并在C++代码中解密,为游戏资源提供了一层安全保护。了解XXTEA的工作原理和如何在Cocos2dx中应用这些知识,...
一个用python制作的xxtea对称加密解密的批处理图片资源工具,带源码。用于网页,页游资源图片资源加密处理
本资源是一个名为"xxtea-2.0.0.post0-cp35-cp35m-win_amd64.whl"的Python库文件,适用于Python 3.5版本,并且是为64位Windows系统设计的。该库主要用于加密和解密数据,特别适合那些需要在Python项目中进行数据安全...
**Python库xxtea-1.3.0-cp35-cp35m-manylinux1_x86_64.whl详解** `xxtea-1.3.0-cp35-cp35m-manylinux1_x86_64.whl` 是一个针对Python编程语言的扩展库,其主要功能是提供了XXTEA加密算法的实现。XXTEA(eXtended ...
资源来自pypi官网。 资源全名:xxtea-1.3.0-cp36-cp36m-win32.whl
XXTEA算法是一种高效、简洁的微积分加密算法,由David Wheeler和Roger Needham于1994年提出,主要用于短数据块的加密。在给定的“xxtea.rar_XXTEA”压缩包中,我们可以看到一个名为“hello”的文件,这可能是用XXTEA...
XXTEA(Extreme eXtended TEA,极度扩展的TEA)是一种简单的加密算法,由David Wheeler和Roger Needham在1994年提出。它是对Tiny Encryption Algorithm(TEA)的一种改进,旨在解决TEA存在的微小弱点。XXTEA在保持...
在游戏开发,特别是Cocos2d-x与Cocos2d-lua项目中,XXTEA加密常用于保护资源文件和代码,防止未授权访问和破解。以下是关于XXTEA加密以及如何在C++和Cocos2d-x环境中应用的详细知识: 1. XXTEA加密算法: - XXTEA...
“微型加密算法(TEA)及其相关变种(XTEA,Block TEA,XXTEA)都是分组加密算法,它们很容易被描述,实现也很简单(典型的几行代码)。 TEA 算法最初是由剑桥计算机实验室的 David Wheeler 和 Roger Needham 在 ...
XXtea和AES是两种常用的加密算法,用于保护数据的安全性,尤其在软件开发和网络通信中广泛应用。在本文中,我们将深入探讨这两种加密算法以及如何使用它们进行加密和解密。 1. **XXtea加密算法**: XXtea,全称...
XXTEA(Extreme eXtended TEA)是一种块加密算法,由David Wheeler和Roger Needham在1994年提出。它是在TEA(Tiny Encryption Algorithm)的基础上改进的,提高了安全性和性能。XXTEA算法是面向小整数序列的,通常...
xxtea-java, Java的XXTEA加密算法库 用于 Java 的 XXTEA 简介XXTEA是一种快速安全的加密算法。 这是一个用于Java的XXTEA库。它与原始的XXTEA加密算法不同。 它加密和解密字节 [] 而不是 32bit 整数 array,键也
TEA(Tiny Encryption Algorithm)是一种小型的对称加密解密算法,支持128位密码,与BlowFish一样TEA每次只能加密/解密8字节数据。...由于针对TEA的攻击不断出现,所以TEA也发展出几个版本,分别是XTEA、Block TEA和XXTEA
XXTEA(Extreme eXtended eXtremely Fast Data Encryption Algorithm)是一种快速且高效的块密码算法,由David Wheeler和Ross J. Anderson于1998年提出。它主要用于小型数据块加密,如网络传输中的小数据包或者内存...
XXtea加密算法是一种轻量级的加密算法,主要用于保护数据的隐私性和安全性。该算法由David Wheeler和Roger Needham在1998年提出,原名为“Simple Encryption Algorithm”(SEA),后更名为XXtea,是“eXtended Xor ...
XXTEA(Extreme eXtended TEA,极度扩展的TEA)是一种对称加密算法,由David Wheeler和Roger Needham在1994年提出,是对Tiny Encryption Algorithm(TEA)的改进版本。它提供了更好的安全性和效率,被广泛用于软件和...
XXTea加密是一种广泛应用在软件保护、数据安全传输中的轻量级加密算法。它是由David Wang(网名“打不死的小强”)设计的一种改进版的TEA(Tiny Encryption Algorithm)加密算法,主要解决了TEA算法的安全性和效率...