Browse Source

fix issue in auth_chain_c: cannot find payload data issue which case by not re-init random object

akkariiin/master
Akkariiin 8 years ago
parent
commit
a6c1f6952b
  1. 3
      shadowsocks/obfsplugin/auth_chain.py

3
shadowsocks/obfsplugin/auth_chain.py

@ -765,6 +765,8 @@ class auth_chain_c(auth_chain_b):
def rnd_data_len(self, buf_size, last_hash, random): def rnd_data_len(self, buf_size, last_hash, random):
other_data_size = buf_size + self.server_info.overhead other_data_size = buf_size + self.server_info.overhead
# 一定要在random使用前初始化,以保证服务器与客户端同步,保证包大小验证结果正确
random.init_from_bin_len(last_hash, buf_size)
# final_pos 总是分布在pos~(data_size_list0.len-1)之间 # final_pos 总是分布在pos~(data_size_list0.len-1)之间
# 除非data_size_list0中的任何值均过小使其全部都无法容纳buf # 除非data_size_list0中的任何值均过小使其全部都无法容纳buf
if other_data_size >= self.data_size_list0[-1]: if other_data_size >= self.data_size_list0[-1]:
@ -778,7 +780,6 @@ class auth_chain_c(auth_chain_b):
return random.next() % 521 return random.next() % 521
return random.next() % 1021 return random.next() % 1021
random.init_from_bin_len(last_hash, buf_size)
pos = bisect.bisect_left(self.data_size_list0, other_data_size) pos = bisect.bisect_left(self.data_size_list0, other_data_size)
# random select a size in the leftover data_size_list0 # random select a size in the leftover data_size_list0
final_pos = pos + random.next() % (len(self.data_size_list0) - pos) final_pos = pos + random.next() % (len(self.data_size_list0) - pos)

Loading…
Cancel
Save