當前位置: 首頁>>代碼示例>>Python>>正文


Python dot11.Dot11方法代碼示例

本文整理匯總了Python中scapy.layers.dot11.Dot11方法的典型用法代碼示例。如果您正苦於以下問題:Python dot11.Dot11方法的具體用法?Python dot11.Dot11怎麽用?Python dot11.Dot11使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在scapy.layers.dot11的用法示例。


在下文中一共展示了dot11.Dot11方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: packet_handler

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def packet_handler(packet):
    if packet.haslayer(Dot11) and packet.type == 0 and packet.subtype == 8:
        try:
            ssid = packet.info.decode("utf-8")
            mac_address = str(packet.addr2)
            channel = int(ord(packet[Dot11Elt:3].info))
            if not endpoints.get(mac_address) and not ssid == "":
                if CONFIG.print_all:
                    print_endpoint(ssid, mac_address, channel)
                if is_tp_link(ssid):
                    password = get_password(mac_address)
                    print_endpoint(ssid, mac_address,
                                   channel, password=password)
                    add_endpoint(ssid, mac_address, password=password)
                else:
                    add_endpoint(ssid, mac_address)
        except (UnicodeDecodeError, AttributeError, TypeError, IndexError, AttributeError):
            pass 
開發者ID:thehappydinoa,項目名稱:TP-Link-defaults,代碼行數:20,代碼來源:scan.py

示例2: enBuilder

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def enBuilder(self, pkt, stream, iVal):

        ## Remove the LLC layer
        del pkt[LLC]

        ## Add the Dot11WEP layer
        encodedPacket = pkt/Dot11WEP(iv = iVal, keyid = 0, wepdata = stream)

        ## Flip FCField bits accordingly
        if encodedPacket[Dot11].FCfield == 1:
            encodedPacket[Dot11].FCfield = 65
        elif encodedPacket[Dot11].FCfield == 2:
            encodedPacket[Dot11].FCfield = 66

        ## Add the ICV
        #encodedPacket[Dot11WEP].icv = int(self.pt.endSwap(hex(crc32(str(encodedPacket[Dot11])[0:-4]) & 0xffffffff)), 16)
        encodedPacket[Dot11WEP].icv = int(self.pt.fcsGen(encodedPacket[Dot11], end = -4), 16)
        return encodedPacket 
開發者ID:ICSec,項目名稱:pyDot11,代碼行數:20,代碼來源:wep.py

示例3: ap_call

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def ap_call(self):
		# Main Network Place
		for pkt in self.pkts:
			if pkt.haslayer(Dot11Beacon):
				bssid = pkt.getlayer(Dot11).addr2
				essid = pkt.getlayer(Dot11Elt).info
				essid = re.sub(r'[^\w]', '', essid)
				cap = pkt.sprintf("{Dot11Beacon:%Dot11Beacon.cap%}").split('+')
				elem_layers = pkt.getlayer(Dot11Elt)
				crypto = set()
				if pkt.getlayer(Dot11).addr2 not in self.counter_:
					self.counter_.append(bssid)
					self.ap_call_[str(bssid)] = [essid, 0, 0, '', 0, '', '', ''] # essid[0], beacon[1], data[2], security[3], channel[4], cipher[5], auth[6]
					self.ap_call_[bssid][1] += 1
					self.ap_call_[bssid][5] = maccom(bssid)
				elif pkt[Dot11].addr2 in self.counter_:
					self.ap_call_[bssid][1] += 1
				self.ap_call_ext(elem_layers, bssid, crypto, cap) 
開發者ID:hash3liZer,項目名稱:airpydump,代碼行數:20,代碼來源:airpydump.py

示例4: ap_data_call

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def ap_data_call(self):
		for pkt in self.pkts:
			if pkt.haslayer(Dot11) and pkt.getlayer(Dot11).type == 2L:
				st = pkt.getlayer(Dot11).addr2
				rv = pkt.getlayer(Dot11).addr1
				for dev in self.counter_:
					if dev == st:
						try:
							self.ap_call_[st][2] += 1
						except KeyError:
							pass
					elif dev == rv:
						try:
							self.ap_call_[rv][2] += 1
						except KeyError:
							pass
		return 
開發者ID:hash3liZer,項目名稱:airpydump,代碼行數:19,代碼來源:airpydump.py

示例5: ap_call_handshake

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def ap_call_handshake(self):
		eapol_list, tabulator__ = [], []
		for pkt in self.pkts:
			if pkt.haslayer(EAPOL):
				sender = pkt.getlayer(Dot11).addr2
				receiver = pkt.getlayer(Dot11).addr1
				for dev in self.counter_:
					if sender == dev and receiver not in eapol_list:
						handshake = receiver
						ap = sender
						eapol_list.append(handshake)
						tabulator__.append([ap.upper(), color.YELLOW+handshake.upper()+color.END])
					elif receiver == dev and sender not in eapol_list:
						handshake = sender
						ap = receiver
						eapol_list.append(handshake)
						tabulator__.append([ap.upper(), color.YELLOW+handshake.upper()+color.END])
					else:
						pass
		if self.has_handshakes():
			return "\n"+tabulate(tabulator__, headers=['BSSID', 'HANDSHAKE'], tablefmt="simple")+"\n"
		return "\n" 
開發者ID:hash3liZer,項目名稱:airpydump,代碼行數:24,代碼來源:airpydump.py

示例6: ap_call_clients

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def ap_call_clients(self):
		for pkt in self.pkts:
			if pkt.haslayer(Dot11) and pkt.getlayer(Dot11).type == 2L and not pkt.haslayer(EAPOL):
				sender = pkt.getlayer(Dot11).addr2
				receiver = pkt.getlayer(Dot11).addr3
				for dev in self.counter_:
					if dev == sender and receiver not in self.cl_counter:
						ap = sender
						cl = receiver
						self.cl_counter.append(cl)
						self.ap_call_2[cl] = [ap, str(pwrCall(pkt)), 1, maccom(cl)]
					elif dev == sender and receiver in self.cl_counter:
						self.ap_call_2[receiver][2] += 1
						self.ap_call_2[receiver][1] = pwrCall(pkt)
					elif dev == receiver and sender not in self.cl_counter:
						ap = receiver
						cl = sender
						self.cl_counter.append(cl)
						self.ap_call_2[cl] = [ap, str(pwrCall(pkt)), 1, maccom(cl)]
					elif dev == receiver and sender in self.cl_counter:
						self.ap_call_2[sender][2] += 1
						self.ap_call_2[sender][1] = pwrCall(pkt)
					else:
						pass 
開發者ID:hash3liZer,項目名稱:airpydump,代碼行數:26,代碼來源:airpydump.py

示例7: call3

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def call3(self, pkt):
		eapol_list, tabulator__ = [], []
		if pkt.haslayer(EAPOL):
			sender = pkt.getlayer(Dot11).addr2
			receiver = pkt.getlayer(Dot11).addr1
			for dev in self.counter_:
				if sender == dev and receiver not in eapol_list:
					handshake = receiver
					ap = sender
					eapol_list.append(handshake)
					tabulator__.append(ap)
					tabulator__.append(handshake)
					self.handshakes += 1
				elif receiver == dev and sender not in eapol_list:
					handshake = sender
					ap = receiver
					eapol_list.append(handshake)
					tabulator__.append(ap)
					tabulator__.append(handshake)
					self.handshakes += 1
				else:
					pass
		return tabulator__ 
開發者ID:hash3liZer,項目名稱:airpydump,代碼行數:25,代碼來源:airpydump.py

示例8: call4

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def call4(self, pkt):
		tabulator = []
		if pkt.haslayer(Dot11) and pkt.getlayer(Dot11).type == 2L and not pkt.haslayer(EAPOL):
			sender = pkt.getlayer(Dot11).addr2
			receiver = pkt.getlayer(Dot11).addr3
			for dev in self.counter_:
				if dev == sender and receiver not in self.cl_counter:
					ap = sender
					cl = receiver
					self.cl_counter.append(cl)
					self.ntwk_call_4[cl] = [ap, str(pwrCall(pkt)), 1, maccom(cl)]
				elif dev == sender and receiver in self.cl_counter:
					self.ntwk_call_4[receiver][2] += 1
					self.ntwk_call_4[receiver][1] = pwrCall(pkt)
				elif dev == receiver and sender not in self.cl_counter:
					ap = receiver
					cl = sender
					self.cl_counter.append(cl)
					self.ntwk_call_4[cl] = [ap, str(pwrCall(pkt)), 1, maccom(cl)]
				elif dev == receiver and sender in self.cl_counter:
					self.ntwk_call_4[sender][2] += 1
					self.ntwk_call_4[sender][1] = pwrCall(pkt)
				else:
					pass 
開發者ID:hash3liZer,項目名稱:airpydump,代碼行數:26,代碼來源:airpydump.py

示例9: organizer

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def organizer(self):
		self.ap = binascii.a2b_hex(self.pkt_i.getlayer(Dot11).addr2.replace(':','').lower())
		self.cl = binascii.a2b_hex(self.pkt_i.getlayer(Dot11).addr1.replace(':','').lower())
		self.aNONCE = binascii.a2b_hex(binascii.hexlify(self.pkt_i.getlayer(Raw).load)[26:90])
		self.cNONCE = binascii.a2b_hex(binascii.hexlify(self.pkt_ii.getlayer(Raw).load)[26:90])
		self.key_data = min(self.ap, self.cl) + max(self.ap, self.cl) + min(self.aNONCE, self.cNONCE) + max(self.aNONCE, self.cNONCE)
		self.version = chr(self.pkt_ii.getlayer(EAPOL).version)
		self.type = chr(self.pkt_ii.getlayer(EAPOL).type)
		self.len = chr(self.pkt_ii.getlayer(EAPOL).len)

		self.payload = binascii.a2b_hex(binascii.hexlify(self.version\
					+self.type\
					+self.__NULL_\
					+self.len\
					+binascii.a2b_hex(binascii.hexlify(self.pkt_ii.getlayer(Raw).load)[:154])\
					+self.__NULL_*16\
					+binascii.a2b_hex(binascii.hexlify(self.pkt_ii.getlayer(Raw).load)[186:])))

		self.data = self.version\
					+self.type\
					+self.__NULL_\
					+self.len\
					+self.pkt_ii.getlayer(Raw).load 
開發者ID:hash3liZer,項目名稱:WiFiBroot,代碼行數:25,代碼來源:cracker.py

示例10: get_auth_resp

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def get_auth_resp(self, pkt):
		if pkt.haslayer(RadioTap):
			if pkt.haslayer(Dot11Auth):
				sn = pkt.getlayer(Dot11).addr2.replace(':', '')
				rc = pkt.getlayer(Dot11).addr1.replace(':', '')
				if rc == self.cl.replace(':', '') and sn == self.ap.replace(':', ''):
					if self.verbose:
						self.pull.info("Received %s (%s) %s<%s %s (%s) %s[Open Authentication]%s" % \
											(self.cl.replace(':', '').upper(), self.pull.DARKCYAN+org(self.cl).org+self.pull.END, self.pull.RED, self.pull.END, self.ap.replace(':', '').upper(),\
											self.pull.DARKCYAN+org(self.ap).org+self.pull.END, self.pull.YELLOW, self.pull.END))
						self.pull.info("Authentication %s (%s) %s>%s %s (%s) %s[SuccessFull]%s" % \
											(self.ap.replace(':', '').upper(), self.pull.DARKCYAN+org(self.ap).org+self.pull.END, self.pull.RED, self.pull.END, self.cl.replace(':', '').upper(),\
											self.pull.DARKCYAN+org(self.cl).org+self.pull.END, self.pull.GREEN, self.pull.END))
					else:
						self.pull.info("Received %s %s<%s %s %s[Open Authentication]%s" % (self.cl.replace(':', '').upper(), self.pull.RED, self.pull.END,\
													 self.ap.replace(':', '').upper(), self.pull.YELLOW, self.pull.END))
						self.pull.info("Authentication %s %s>%s %s %s[SuccessFull]%s" % \
											(self.ap.replace(':', '').upper(), self.pull.RED, self.pull.END, self.cl.replace(':', '').upper(),\
											self.pull.GREEN, self.pull.END))

					self.__AUTH_STEP = bool(1)
					raise ValueError 
開發者ID:hash3liZer,項目名稱:WiFiBroot,代碼行數:24,代碼來源:pmkid.py

示例11: clients_garbage

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def clients_garbage(self, pkt):
		if pkt.haslayer(Dot11) and pkt.getlayer(Dot11).type == 2L and not pkt.haslayer(EAPOL):
			_sn = pkt.getlayer(Dot11).addr2
			_rc = pkt.getlayer(Dot11).addr1

			_tgt = None

			if _sn in self.bss_counter:
				_tgt, _ap = _rc, _sn
			elif _rc in self.bss_counter:
				_tgt, _ap = _sn, _rc

			if _tgt and _tgt not in self.clients:
				for cell in self.cells:
					for _key, _val in cell.items():
						if _key == 'bssid' and _val == _ap:
							if not (_tgt.replace(':','').lower() in self.__BLACKLIST):
								cell['clients'] += 1; self.clients.append(_tgt)
								self.__ALSA_CLIENTS[_val].append( (_tgt, self.dBM_sig(pkt)) ) 
開發者ID:hash3liZer,項目名稱:WiFiBroot,代碼行數:21,代碼來源:shifter.py

示例12: is_valid_handshake_frame

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def is_valid_handshake_frame(packet):
        """
        Check if the Dot11 packet is a valid EAPOL KEY frame
        :param self: Handshakeverify object
        :param packet: A scapy.layers.RadioTap object
        :type self: Handshakeverify
        :type packet: scapy.layers.RadioTap
        :return True if this is an EAPOL KEY frame
        :rtype: bool
        """
        # pkt is Dot11 nad packet is not retried
        if packet.haslayer(dot11.Dot11) and not packet.FCfield & (1 << 3):
            # check it is key type eapol
            if packet.haslayer(EAPOL) and packet[EAPOL].type == 3:
                return True
        return False 
開發者ID:wifiphisher,項目名稱:wifiphisher,代碼行數:18,代碼來源:handshakeverify.py

示例13: test_single_extension

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def test_single_extension(self):
        # We need a NM to init EM
        nm = interfaces.NetworkManager()
        # Init an EM and pass some shared data
        em = extensions.ExtensionManager(nm)
        em.set_extensions(constants.DEFAULT_EXTENSIONS)
        shared_data = {"one": 1, "two": 2, "is_freq_hop_allowed": True}
        em.init_extensions(shared_data)
        # A deauth packet appears in the air
        packet = (
            dot11.RadioTap() /
            dot11.Dot11(
                type=0,
                subtype=12,
                addr1="00:00:00:00:00:00",
                addr2="00:00:00:00:00:00",
                addr3="00:00:00:00:00:00") /
            dot11.Dot11Deauth())
        em._process_packet(packet)
        # The extension1.py sent packet "1" and returned output
        # "one", "two". Validate with get_packet(), send_output()
        assert em._packets_to_send["1"] == [1]
        assert em._packets_to_send["2"] == []
        assert em.get_output() == ["one", "two"] 
開發者ID:wifiphisher,項目名稱:wifiphisher,代碼行數:26,代碼來源:test_extensions.py

示例14: wpaEncrypt

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def wpaEncrypt(encKey, origPkt, decodedPkt, PN, genFCS = True):
    """Encompasses the steps needed to encrypt a WPA packet
    No structure for TKIP has been done as of yet
    """

    ## Increment the PN positively per IEEE spec
    PN[5] += 1

    ## Grab the payload of the decoded packet
    dEverything = decodedPkt[LLC]

    ## Remove the FCS from the original packet
    newPkt = RadioTap((pt.byteRip(origPkt.copy(),
                                  chop = True,
                                  order = 'last',
                                  output = 'str',
                                  qty = 4)))
    del newPkt[Dot11WEP]

    ## The data is ready for encryption
    newPkt = newPkt/dEverything
    encodedPkt = ccmpCrypto.encryptCCMP(newPkt, encKey, PN, genFCS)

    ## Flip FCField bits accordingly
    if encodedPkt[Dot11].FCfield == 1:
        encodedPkt[Dot11].FCfield = 65
    elif encodedPkt[Dot11].FCfield == 2:
        encodedPkt[Dot11].FCfield = 66

    return encodedPkt

### Instantiations 
開發者ID:ICSec,項目名稱:pyDot11,代碼行數:34,代碼來源:__init__.py

示例15: decoder

# 需要導入模塊: from scapy.layers import dot11 [as 別名]
# 或者: from scapy.layers.dot11 import Dot11 [as 別名]
def decoder(self, pkt, tk):
        """Decrypt the packet"""

        ## If the packet has FCS, it should be removed and added later on.
        if self.hasFCS(pkt):
            pload = self.pt.byteRip(pkt[Dot11WEP],
                                   order = 'last',
                                   qty = 4,
                                   chop = True,
                                   output = 'str')
        else:
            pload = str(pkt[Dot11WEP])

        ## The minimum valid TKIP packet has 21 bytes
        if(len(pload) <= 20):
            return

        ## Address required to calculate RC4 key
        addr = bytearray(re.sub(':','', pkt[Dot11].addr2).decode("hex"))
        #print bytearray(pload)
        #print addr
        #print tk
        key = self.generateRC4Key(bytearray(pload), addr, tk)

        ## Decrypt packet
        stream = self.rc4(bytearray(str(pload)), key)

        ## Check if decrypted CRC is correct. If it's not, ignore the packet.
        dlen = len(stream)
        crc = crc32(str(stream[:-12]))

        ### This is an issue, work it out later
        #if (stream[dlen - 12] != (crc & 0xff) or
            #stream[dlen - 11] != ((crc >> 8) & 0xff) or
            #stream[dlen - 10] != ((crc >> 16) & 0xff) or
            #stream[dlen - 9] != ((crc >> 24) & 0xff)):
            #return

        return stream 
開發者ID:ICSec,項目名稱:pyDot11,代碼行數:41,代碼來源:tkip.py


注:本文中的scapy.layers.dot11.Dot11方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。