def login(user, passwd, target, port, timeout_sec, log_in_file, language, retries, time_sleep,
thread_tmp_filename, socks_proxy):
_HOST = messages(language, 53)
_USERNAME = messages(language, 54)
_PASSWORD = messages(language, 55)
_PORT = messages(language, 56)
_TYPE = messages(language, 57)
_DESCRIPTION = messages(language, 58)
exit = 0
flag = 1
if socks_proxy is not None:
socks_version = socks.SOCKS5 if socks_proxy.startswith('socks5://') else socks.SOCKS4
socks_proxy = socks_proxy.rsplit('://')[1]
socks.set_default_proxy(socks_version, str(socks_proxy.rsplit(':')[0]), int(socks_proxy.rsplit(':')[1]))
socket.socket = socks.socksocket
socket.getaddrinfo = getaddrinfo
while 1:
try:
paramiko.Transport((target, int(port)))
paramiko_logger = logging.getLogger("paramiko.transport")
paramiko_logger.disabled = True
flag = 0
exit = 0
break
except:
exit += 1
if exit is retries:
warn(messages(language, 76).format(target, str(port), user, passwd))
return 1
time.sleep(time_sleep)
if flag is 0:
try:
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
if timeout_sec is not None:
ssh.connect(hostname=target, username=user, password=passwd, port=int(port), timeout=timeout_sec)
else:
ssh.connect(hostname=target, username=user, password=passwd, port=int(port))
info(messages(language, 70).format(user, passwd, target, port))
save = open(log_in_file, 'a')
save.write(
json.dumps({_HOST: target, _USERNAME: user, _PASSWORD: passwd, _PORT: port, _TYPE: 'ssh_brute',
_DESCRIPTION: messages(language, 66)}) + '\n')
save.close()
thread_write = open(thread_tmp_filename, 'w')
thread_write.write('0')
thread_write.close()
except:
pass
else:
pass
return flag
评论列表
文章目录