Python精简代码实现循环左移循环右移
Python实现循环左移右移
一丶Python实现循环左移 右移 原理
1.1 Python实现循环左移
1.1.1 文字原理介绍
循环左移原理
拿一个32位的数(4个字节)来说 进行移动八位
如:
0x12345678 rol 8 之后 = 0x34567812
其原理如下:
1.首先左移八位得到 0x345678
2.然后右移24位得到 0x12
最后 0x345678 | 0x12 = 0x34567812
鉴于Python的特殊性.我们只需要32bit数即可. 也就是最后要 & 0xFFFFFFFF
其它移位同理
1.2 Python实现循环右移
1.2.1 右移位原理介绍
设你要移动的数 是一个 4字节(32bit)的数 要移动八位
则原理如下:
0x12345678 ror 8(bit) = 0x78123456
1.首先得到 123456 也就是 >> 8位即可得到
2.然后得到 78 也就是 << 24位即可得到
得到的两个值进行|运算
也就是 0x78 | 0x 123456 = 0x78123456
0x78
| 0x 123456
= 0x78123456
但是python的特殊性 你移位之后数值不会溢出,所以我们只需要相应位数的字节即可. 也就是我们只要32位(4个字节) 最后&0xFFFFFFFF 就可以
得到我们想要的数值的
二丶代码示例
2.1 代码介绍
上面说了下移位的原理那么这里介绍下Python代码的使用
以循环右移为例子 总共就分为下类三个函数
rorCustomByte 自定义定制字节移位
rorCustomBit 自定义Bit移位
ror8bit 按照8位数值 进行移位
下面说下什么意思
-
rorCustomByte 自定义定制字节移位
总共三个参数
参数1: 你想移动的数值
参数2: 字节分组 按照4bit一个分组 说明一下参数1 是多少个分组组成 如 0x12345678 有8个分组 每组4个bit
参数3: 你要移动多少个字节
使用代码如下
v = 0x12345678 有一个数值是0x12345678 是一个四字节表示的值 也就是32位 print(hex(ror.rorCustomByte(v, 8, 4))) 这个函数的作用则是 这个V值有8个分组,每组分为4bit (合起来是32bit) 然后循环移位4个分组(16位) 输出结果如下: >>> 0x56781234 继续使用 v = 0x1234 print(hex(ror.rorCustomByte(v, 4, 2))) >>> 0x3412
-
rorCustomBit 按照bit来进行移位
这个移位很明白了.
参数1: 你要移动的数值
参数2: 你移动的这个数值是多少位
参数3: 你要移动多少位
使用代码如下:
v = 0x12345678 print(hex(ror.rorCustomBit(v,32,4))) 参数2指明了你要移动的v值是一个32bit的值. 你要移动4位. v = 0x1234 print(hex(ror.rorCustomBit(v, 16, 4))) 同上 输出值: >>> 0x81234567 >>> 0x4123
-
ror8bit 是一个分类函数.是说明你要把一个一个数按照8bit的方式来进行移位 当然也有ror4bit ror16bit .....
参数1: 你要移动的数值
参数2: 你要移动多少位
其实rorCustomBit 就是根据此类函数改造的.可以定制移动.
使用如下:
v = 0xC print(hex(ror.ror4Bit(v, 1))) v = 0x12 print(hex(ror.ror8Bit(v, 4))) v = 0x1234 print(hex(ror.ror16Bit(v, 4))) v = 0x12345 print(hex(ror.ror20Bit(v, 4))) v = 0x123456 print(hex(ror.ror24Bit(v, 4))) v = 0x1234567 print(hex(ror.ror28Bit(v, 4))) v = 0x12345678 print(hex(ror.ror32Bit(v, 4))) 分别输出: 0x6 0x21 0x4123 0x51234 0x612345 0x7123456 0x81234567
实现循环左移同理. 都是三类函数
from LearnPy.Py1.RorOpt import AsmUtils ror = AsmUtils.RorObj() rol = AsmUtils.RolObl() v = 0xC print(hex(rol.rol4Bit(v, 1))) v = 0x12 print(hex(rol.rol8Bit(v, 4))) v = 0x1234 print(hex(rol.rol16Bit(v, 4))) v = 0x12345 print(hex(rol.rol20Bit(v, 4))) v = 0x123456 print(hex(rol.rol24Bit(v, 4))) v = 0x1234567 print(hex(rol.rol28Bit(v, 4))) v = 0x12345678 print(hex(rol.rol32bit(v, 4)))
2.2 完成Python代码
__author__ = 'IBinary blob https://www.cnblogs.com/ibinary/'
class RorObj():
def __init__(self):
pass
#字节循环移位
#参数1 要移动的值
#参数2 值是多少个字节
#参数3 要移动的字节位数
def rorCustomByte(self,v, Byte, shiftByte):
shiftByte = (shiftByte * 4) & (Byte * 4 - 1) # 按照bit值 来进行设置移动位数
if shiftByte == 0:
return v
a1 = (v >> (shiftByte)) # 右移shift位 空出高位shift位
a2 = (v << ((Byte * 4) - shiftByte)) # 计算出剩下要移动的位数
_ = '0x' + 'F' * Byte
FfValue = int(_, 16)
value = (a2 | a1) & FfValue
return value
# 循环右移n位
# 参数1 要移动的值
# 参数2 你的这个是是多少位的. 比如 0x12345678 就是32位
# 参数3 你要移动多少位 比如 4位 那么移动之后就是 0x81234567
def rorCustomBit(self, v, Bytebit, shift):
shift &= (Bytebit - 1) # 按照bit值 来进行设置移动位数
if shift == 0:
return v
a1 = (v >> shift) # 右移shift位 空出高位shift位
a2 = (v << ((Bytebit) - shift)) # 计算出剩下要移动的位数
l = [x for x in range(4, Bytebit + 1) if x % 4 == 0]
LCount = len(l)
_ = '0x' + 'F' * LCount
FfValue = int(_, 16)
value = (a2 | a1) & FfValue
return value
def ror4Bit(self, v, shift):
shift &= 3
if shift == 0:
return v
return ((v >> shift) | (v << (4 - shift))) & 0xF
def ror8Bit(self,v, shift):
shift &= 7
if shift == 0:
return v
return ((v >> shift) | (v << (8 - shift))) & 0xFF
def ror12Bit(self,v, shift):
shift &= 11
if shift == 0:
return v
return ((v >> shift) | (v << (12 - shift))) & 0xFFF
def ror16Bit(self,v, shift):
shift &= 15
if shift == 0:
return v # value 右移shift位
return ((v >> shift) | (v << (16 - shift))) & 0xFFFF
def ror20Bit(self,v, shift):
if shift == 0:
return v # value 右移shift位
return ((v >> shift) | (v << (20 - shift))) & 0xFFFFF
def ror24Bit(self,v, shift):
shift &= 23
if shift == 0:
return v # value 右移shift位
return ((v >> shift) | (v << (24 - shift))) & 0xFFFFFF
def ror28Bit(self,v, shift):
if shift == 0:
return v # value 右移shift位
return ((v >> shift) | (v << (28 - shift))) & 0xFFFFFFF
def ror32Bit(self,v, shift):
shift &= 0x1F # 设置要移动的位数
if shift == 0:
return v # value 右移shift位
return ((v >> shift) | (v << (32 - shift))) & 0xFFFFFFFF
class RolObl():
def __init__(self):
pass
# 循环左移原理
# 拿一个32位的数(4个字节)来说 进行移动八位
# 如:
# 0x12345678 rol 8 之后 = 0x34567812
# 其原理如下:
# 1.首先左移八位得到 0x345678
# 2.然后右移24位得到 0x12
# 最后 0x345678 | 0x12 = 0x34567812
# 鉴于Python的特殊性.我们只需要32bit数即可. 也就是最后要 & 0xFFFFFFFF
# 其它移位同理
def rolCustomBit(self,v,bit,shift):
shift &= (bit-1)
if shift == 0:
return v
HightBit = v >> (bit - shift)
LowBit = v << shift
l = [x for x in range(4, bit + 1) if x % 4 == 0]
LCount = len(l)
_ = '0x' + 'F' * LCount
FfValue = int(_, 16)
Value = (HightBit | LowBit) & FfValue
return Value
#按照字节移位
def rolCustomByte(self,v,Byte,shiftByte):
shiftByte = (shiftByte * 4) & (Byte * 4 - 1) # 按照bit值 来进行设置移动位数
if shiftByte == 0:
return v
Low = (v << (shiftByte)) #左移shift位
Hight = (v >> ((Byte * 4) - shiftByte)) # 计算出剩下要移动的位数
_ = '0x' + 'F' * Byte
FfValue = int(_, 16)
value = (Hight | Low) & FfValue
return value
def rol4Bit(self,v,shift):
shift &= 3
if shift == 0:
return v
HightBit = v >> (4 - shift)
LowBit = v << shift
Value = (HightBit | LowBit) & 0xF
return Value
def rol8Bit(self,v,shift):
shift &= 7
if shift == 0:
return v
HightBit = v >> (8 - shift)
LowBit = v << shift
Value = (HightBit | LowBit) & 0xFF
return Value
def rol12Bit(self, v, shift):
shift &= 11
if shift == 0:
return v
HightBit = v >> (12 - shift)
LowBit = v << shift
Value = (HightBit | LowBit) & 0xFFF
return Value
def rol16Bit(self, v, shift):
shift &= 15
if shift == 0:
return v
HightBit = v >> (16 - shift)
LowBit = v << shift
Value = (HightBit | LowBit) & 0xFFFF
return Value
def rol20Bit(self, v, shift):
if shift == 0:
return v
HightBit = v >> (20 - shift)
LowBit = v << shift
Value = (HightBit | LowBit) & 0xFFFFF
return Value
def rol24Bit(self, v, shift):
shift &= 23
if shift == 0:
return v
HightBit = v >> (24 - shift)
LowBit = v << shift
Value = (HightBit | LowBit) & 0xFFFFFF
return Value
def rol28Bit(self, v, shift):
if shift == 0:
return v
HightBit = v >> (28 - shift)
LowBit = v << shift
Value = (HightBit | LowBit) & 0xFFFFFFF
return Value
def rol32bit(self,v,shift):
shift &= 0x1F
if shift == 0:
return v
HightBit = v >> (32 - shift)
LowBit = v << shift
value = (HightBit | LowBit) & 0xFFFFFFFF
return value
坚持两字,简单,轻便,但是真正的执行起来确实需要很长很长时间.当你把坚持两字当做你要走的路,那么你总会成功. 想学习,有问题请加群.群号:725864912(收费)群名称: 逆向学习小分队 群里有大量学习资源. 以及定期直播答疑.有一个良好的学习氛围. 涉及到外挂反外挂病毒 司法取证加解密 驱动过保护 VT 等技术,期待你的进入。
详情请点击链接查看置顶博客 https://www.cnblogs.com/iBinary/p/7572603.html
本文来自博客园,作者:iBinary,未经允许禁止转载 转载前可联系本人.对于爬虫人员来说如果发现保留起诉权力.https://www.cnblogs.com/iBinary/p/14163500.html
欢迎大家关注我的微信公众号.不定期的更新文章.更新技术. 关注公众号后请大家养成 不白嫖的习惯.欢迎大家赞赏. 也希望在看完公众号文章之后 不忘 点击 收藏 转发 以及点击在看功能. QQ群: