USB流量解密


    先执行指令提取有效信息

    1. tshark -r u.pcapng -T fields -e usb.capdata > usbdata.txt

    使用网上的脚本,解密

    1. #!/usr/bin/env python
    2. # -*- coding:utf-8 -*-
    3. normalKeys = {"04":"a", "05":"b", "06":"c", "07":"d", "08":"e", "09":"f", "0a":"g", "0b":"h", "0c":"i", "0d":"j", "0e":"k", "0f":"l", "10":"m", "11":"n", "12":"o", "13":"p", "14":"q", "15":"r", "16":"s", "17":"t", "18":"u", "19":"v", "1a":"w", "1b":"x", "1c":"y", "1d":"z","1e":"1", "1f":"2", "20":"3", "21":"4", "22":"5", "23":"6","24":"7","25":"8","26":"9","27":"0","28":"<RET>","29":"<ESC>","2a":"<DEL>", "2b":"\t","2c":"<SPACE>","2d":"-","2e":"=","2f":"[","30":"]","31":"\\","32":"<NON>","33":";","34":"'","35":"<GA>","36":",","37":".","38":"/","39":"<CAP>","3a":"<F1>","3b":"<F2>", "3c":"<F3>","3d":"<F4>","3e":"<F5>","3f":"<F6>","40":"<F7>","41":"<F8>","42":"<F9>","43":"<F10>","44":"<F11>","45":"<F12>"}
    4. shiftKeys = {"04":"A", "05":"B", "06":"C", "07":"D", "08":"E", "09":"F", "0a":"G", "0b":"H", "0c":"I", "0d":"J", "0e":"K", "0f":"L", "10":"M", "11":"N", "12":"O", "13":"P", "14":"Q", "15":"R", "16":"S", "17":"T", "18":"U", "19":"V", "1a":"W", "1b":"X", "1c":"Y", "1d":"Z","1e":"!", "1f":"@", "20":"#", "21":"$", "22":"%", "23":"^","24":"&","25":"*","26":"(","27":")","28":"<RET>","29":"<ESC>","2a":"<DEL>", "2b":"\t","2c":"<SPACE>","2d":"_","2e":"+","2f":"{","30":"}","31":"|","32":"<NON>","33":"\"","34":":","35":"<GA>","36":"<","37":">","38":"?","39":"<CAP>","3a":"<F1>","3b":"<F2>", "3c":"<F3>","3d":"<F4>","3e":"<F5>","3f":"<F6>","40":"<F7>","41":"<F8>","42":"<F9>","43":"<F10>","44":"<F11>","45":"<F12>"}
    5. output = []
    6. keys = open('usbdata.txt')
    7. for line in keys:
    8. try:
    9. if line[0]!='0' or (line[1]!='0' and line[1]!='2') or line[3]!='0' or line[4]!='0' or line[9]!='0' or line[10]!='0' or line[12]!='0' or line[13]!='0' or line[15]!='0' or line[16]!='0' or line[18]!='0' or line[19]!='0' or line[21]!='0' or line[22]!='0' or line[6:8]=="00":
    10. continue
    11. if line[6:8] in normalKeys.keys():
    12. output += [[normalKeys[line[6:8]]],[shiftKeys[line[6:8]]]][line[1]=='2']
    13. else:
    14. output += ['[unknown]']
    15. except:
    16. pass
    17. keys.close()
    18. flag=0
    19. print("".join(output))
    20. for i in range(len(output)):
    21. try:
    22. a=output.index('<DEL>')
    23. del output[a]
    24. del output[a-1]
    25. except:
    26. pass
    27. for i in range(len(output)):
    28. try:
    29. if output[i]=="<CAP>":
    30. flag+=1
    31. output.pop(i)
    32. if flag==2:
    33. flag=0
    34. if flag!=0:
    35. output[i]=output[i].upper()
    36. except:
    37. pass
    38. print ('output :' + "".join(output))

    易霖博CTF-keyboard - 图1

    在vim中敲入对应的按键得到(Vim):
    易霖博CTF-keyboard - 图2