ctf經(jīng)常遇到進制轉(zhuǎn)換的問題,就正好做一個進制轉(zhuǎn)換總結(jié),分享出來供大家參考學習,下面來一起看看詳細的介紹:
創(chuàng)新互聯(lián)公司服務項目包括鲅魚圈網(wǎng)站建設、鲅魚圈網(wǎng)站制作、鲅魚圈網(wǎng)頁制作以及鲅魚圈網(wǎng)絡營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,鲅魚圈網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務的客戶以成都為中心已經(jīng)輻射到鲅魚圈省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!
字符串與十六進制轉(zhuǎn)換
例如百度ctf 12月的第二場第一個misc
?
1
666C61677B65633862326565302D336165392D346332312D613031322D3038616135666137626536377D
比較簡單的一種做法就是直接調(diào)用字符串的.decode('hex')解密即可, 但如果不用這個函數(shù)你會怎么解呢?
一種思路就是先2個分組,解出每組的ascii值,合并下字符串即可得到,具體代碼如下
?
1234567
import res='666C61677B65633862326565302D336165392D346332312D613031322D3038616135666137626536377D's = re.findall(r'.{2}',s)s = map(lambda x:chr(int(x,16)),s)print ''.join(s)flag{ec8b2ee0-3ae9-4c21-a012-08aa5fa7be67}
前面說了字符串的decode('hex')函數(shù),另外還有兩個轉(zhuǎn)16進制的函數(shù),這里都總結(jié)一下
內(nèi)置函數(shù)hex()
只能轉(zhuǎn)換10進制整數(shù)為十六進制,不能轉(zhuǎn)字符串
binascii庫的hexlify()和b2a_hex()
這兩個函數(shù)的功能是將字符串轉(zhuǎn)換成十六進制,對應的解密函數(shù)分別為 unhexlify()和a2b_hex()
進制互轉(zhuǎn)
二進制,八進制,十六進制轉(zhuǎn)10進制比較簡單,直接調(diào)用
int函數(shù)
?
1
int(str,base) //返回十進制整數(shù),但注意此時第一個參數(shù)為字符串
對應的解密函數(shù)分別是
?
12345
bin() //10進制轉(zhuǎn)二進制 oct() //十進制轉(zhuǎn)八進制 hex() //十進制轉(zhuǎn)十六進制
但二進制直接轉(zhuǎn)16進制就需要多走一步了,先用int轉(zhuǎn)十進制,在用上面提到的hex()函數(shù)將十進制轉(zhuǎn)換成十六進制,比較精簡的寫法是
?
1
map(lambda x:hex(int(x,2)),['0011']) //lambda表達式
或者是
?
1
[hex(int(x,2)) for x in ['0011']] //列表解析
對應的解密函數(shù)就是
?
1
map(lambda x:bin(int(x,16)),['ef'])
最后在附上自己用python寫的一個進制轉(zhuǎn)換小工具,主要功能是對一組二進制,或者ascii,或十六進制轉(zhuǎn)換成字符串,想必ctf上也經(jīng)常會遇到這類題型吧
?
1234567891011121314151617181920212223242526272829303132333435363738394041424344
# make by 江sir#coding:utf-8import reimport argparse def bintostr(text): text = text.replace(' ','') text = re.findall(r'.{8}',text) s = map(lambda x:chr(int(x,2)),text) #批量二進制轉(zhuǎn)十進制 flag = ''.join(s) return flag def asciitostr(text): if ' ' in text: text = text.split(' ') elif ',' in text: text = text.split(',') s = map(lambda x:chr(int(x)),text) flag = ''.join(s) return flag def hextostr(text): text = re.findall(r'.{2}',text) #print text s = map(lambda x:chr(int(x,16)),text) #print s flag = ''.join(s) return flag if __name__ == '__main__': parser = argparse.ArgumentParser() parser.add_argument("-b") parser.add_argument("-a") parser.add_argument("-x") argv = parser.parse_args() #print argv if argv.b: res = bintostr(argv.b) elif argv.a: res = asciitostr(argv.a) elif argv.x: res = hextostr(argv.x) print res
用法:
十六進制轉(zhuǎn)字符串:
666C61677B65633862326565302D336165392D346332312D613031322D3038616135666137626536377D
?
12
bintostr.py -x "666C61677B65633862326565302D336165392D346332312D613031322D3038616135666137626536377D"flag{ec8b2ee0-3ae9-4c21-a012-08aa5fa7be67}
二進制轉(zhuǎn)字符串:
可以有空格,也可以無空格
00101111 01100110 00110110 00110111 00110011 00110010 00110100 00110001 00110000 01100001 01100001 01100100 01100011 00110000 00110011 00110111 01100110 01100010 00110000 01100011 01100010 01100001 01100001 00110000 00110000 01100011 00110111 00110101 00110011 00110001 00110011 00110111 00110011 00101110 01110100 01111000 01110100
?
12
bintostr.py -b "00101111 01100110 00110110 00110111 00110011 00110010 00110100 00110001 00110000 01100001 01100001 01100100 01100011 00110000 00110011 00110111 01100110 01100010 00110000 01100011 01100010 01100001 01100001 00110000 00110000 01100011 00110111 00110101 00110011 00110001 00110011 00110111 00110011 00101110 01110100 01111000 01110100"/f6732410aadc037fb0cbaa00c7531373.txt
ascii轉(zhuǎn)字符串
可以是空格分隔,也可以是,分隔
s='45 46 45 46 32 45 32 46 46 45 46 32 46 45 46 46 32 46 46 46 32 45 46 46 46 32 46 46 45 45 46 45 32 45 46 46 46 32 46 46 46 32 46 45 46 46 32'
?
12
bintostr.py -a "45 46 45 46 32 45 32 46 46 45 46 32 46 45 46 46 32 46 46 46 32 45 46 46 46 32 46 46 45 45 46 45 32 45 46 46 46 32 46 46 46 32 46 45 46 46 32"-.-. - ..-. .-.. ... -... ..--.- -... ... .-..
以上實例均來自某些ctf賽題
總結(jié)
#!/usr/bin/python# -*- coding:utf-8 -*-# @Time : 2018/6/19 10:20# @Author : # @File : Dec_To_Bin.py"""十進制轉(zhuǎn)二進制""" # 定義一個十進制轉(zhuǎn)二進制的函數(shù)def dec2bin(string_num): num = int(string_num) # 將傳入的字符串數(shù)字轉(zhuǎn)換成整型 mid = [] # 定義一個空列表 while True: # 循環(huán),條件為真時執(zhí)行 if num == 0: # 當輸入值是0時,直接跳出循環(huán) break num, rem = divmod(num, 2) # 調(diào)用函數(shù)divmod,得到商num,和余數(shù)rem mid.append(rem) # 將余數(shù)存入列表 return ''.join([str(x) for x in mid[::-1]]) # 返回結(jié)果,列表取反后拼接成字符串 if __name__ == '__main__': anum = raw_input(u'請輸入要轉(zhuǎn)換的數(shù)字:') print u'該數(shù)字轉(zhuǎn)換為二進制后是:{}'.format(dec2bin(anum))
二進制數(shù)轉(zhuǎn)換成十進制數(shù):二進制數(shù)從右向左每位數(shù)乘以2的次方(從0開始,從右向左依次+1),然后相加求和即可
如:0101轉(zhuǎn)成十進制為:1*20+0*21+1*22+0*23=1+0+4+0=5
算法實現(xiàn):
#coding=utf-8
b=raw_input("請輸入一個二進制數(shù):".decode("utf-8").encode("gbk"))
sum=0
for i in range(len(b)):
sum+=int(b[len(b)-1-i])*pow(2,i)
print u"轉(zhuǎn)換成十進制數(shù)是:",sum
二進制數(shù)轉(zhuǎn)換成十進制數(shù)
由二進制數(shù)轉(zhuǎn)換成十進制數(shù)的基本做法是,把二進制數(shù)首先寫成加權(quán)系數(shù)展開式,然后按十進制加法規(guī)則求和。這種做法稱為"按權(quán)相加"法。 例1105 把二進制數(shù)110.11轉(zhuǎn)換成十進制數(shù)。
十進制數(shù)轉(zhuǎn)換為二進制數(shù)時,由于整數(shù)和小數(shù)的轉(zhuǎn)換方法不同,所以先將十進制數(shù)的整數(shù)部分和小數(shù)部分分別轉(zhuǎn)換后,再加以合并。
以上內(nèi)容參考:百度百科-十進制
從二進制轉(zhuǎn)換為十進制有幾種方式
第一種是在二進制數(shù)前加上0b,顯示時會自動轉(zhuǎn)換為十進制,注意這并不是字符串
x = 0b1010print(x)
如果是字符串可以利用eval求值
x = eval('0b1010')
第二種是利用int函數(shù),字符串可以以0b為前綴,也可以不使用
int('1010',base=2)int('0b1010',2)
函數(shù)會將輸入base進制的字符串轉(zhuǎn)換為十進制