本文整理匯總了Python中impacket.smb3.py方法的典型用法代碼示例。如果您正苦於以下問題:Python smb3.py方法的具體用法?Python smb3.py怎麽用?Python smb3.py使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類impacket.smb3
的用法示例。
在下文中一共展示了smb3.py方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: request_SMBv23
# 需要導入模塊: from impacket import smb3 [as 別名]
# 或者: from impacket.smb3 import py [as 別名]
def request_SMBv23(host, port=445):
# start client
smb_client = smb3.SMB3(host, host, sess_port=port)
# start: modified from login()
# https://github.com/SecureAuthCorp/impacket/blob/master/impacket/smb3.py
session_setup = smb3.SMB2SessionSetup()
if smb_client.RequireMessageSigning is True:
session_setup['SecurityMode'] = smb3.SMB2_NEGOTIATE_SIGNING_REQUIRED
else:
session_setup['SecurityMode'] = smb3.SMB2_NEGOTIATE_SIGNING_ENABLED
session_setup['Flags'] = 0
## NTLMSSP
blob = smb3.SPNEGO_NegTokenInit()
blob['MechTypes'] = [smb3.TypesMech['NTLMSSP - Microsoft NTLM Security Support Provider']]
auth = ntlm.getNTLMSSPType1(smb_client._Connection['ClientName'], '',
smb_client._Connection['RequireSigning'])
blob['MechToken'] = auth.getData()
session_setup['SecurityBufferLength'] = len(blob)
session_setup['Buffer'] = blob.getData()
packet = smb_client.SMB_PACKET()
packet['Command'] = smb3.SMB2_SESSION_SETUP
packet['Data'] = session_setup
packet_id = smb_client.sendSMB(packet)
smb_response = smb_client.recvSMB(packet_id)
if smb_client._Connection['Dialect'] == smb3.SMB2_DIALECT_311:
smb_client.__UpdatePreAuthHash(smb_response.rawData)
## NTLM challenge
if smb_response.isValidAnswer(smb3.STATUS_MORE_PROCESSING_REQUIRED):
session_setup_response = smb3.SMB2SessionSetup_Response(smb_response['Data'])
resp_token = smb3.SPNEGO_NegTokenResp(session_setup_response['Buffer'])
return resp_token['ResponseToken']
else:
return None