revert encrypt.py
new obfs header
This commit is contained in:
parent
928c26e4f2
commit
61959945c3
3 changed files with 21 additions and 8 deletions
|
@ -21,7 +21,7 @@ from __future__ import absolute_import, division, print_function, \
|
|||
import socket
|
||||
import struct
|
||||
import logging
|
||||
|
||||
import binascii
|
||||
|
||||
def compat_ord(s):
|
||||
if type(s) == int:
|
||||
|
@ -160,6 +160,21 @@ def pre_parse_header(data):
|
|||
'encryption method')
|
||||
return None
|
||||
data = data[rand_data_size + 3:]
|
||||
elif datatype == 0x88:
|
||||
if len(data) <= 7 + 7:
|
||||
return None
|
||||
data_size = struct.unpack('>H', data[1:3])[0]
|
||||
ogn_data = data
|
||||
data = data[:data_size]
|
||||
crc = binascii.crc32(data) & 0xffffffff
|
||||
if crc != 0xffffffff:
|
||||
logging.warn('uncorrect CRC32, maybe wrong password or '
|
||||
'encryption method')
|
||||
return None
|
||||
start_pos = 3 + ord(data[3])
|
||||
data = data[start_pos:-4]
|
||||
if data_size < len(ogn_data):
|
||||
data += ogn_data[data_size:]
|
||||
return data
|
||||
|
||||
def parse_header(data):
|
||||
|
|
|
@ -21,7 +21,6 @@ import os
|
|||
import sys
|
||||
import hashlib
|
||||
import logging
|
||||
import random
|
||||
|
||||
from shadowsocks import common
|
||||
from shadowsocks.crypto import rc4_md5, openssl, sodium, table
|
||||
|
@ -35,10 +34,7 @@ method_supported.update(table.ciphers)
|
|||
|
||||
|
||||
def random_string(length):
|
||||
try:
|
||||
return os.urandom(length)
|
||||
except (AttributeError, NotImplementedError):
|
||||
return ''.join(chr(random.randrange(255)) for _ in range(length))
|
||||
|
||||
|
||||
cached_keys = {}
|
||||
|
|
|
@ -341,6 +341,8 @@ class TCPRelayHandler(object):
|
|||
logging.error('unknown command %d', cmd)
|
||||
self.destroy()
|
||||
return
|
||||
if False and ord(data[0]) != 0x88: # force new header
|
||||
raise Exception('can not parse header')
|
||||
data = pre_parse_header(data)
|
||||
if data is None:
|
||||
raise Exception('can not parse header')
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue