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


Python tcp.tcp方法代碼示例

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


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

示例1: test_parser

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def test_parser(self):
        res, ptype, _ = self.ip.parser(self.buf)

        eq_(res.version, self.version)
        eq_(res.header_length, self.header_length)
        eq_(res.tos, self.tos)
        eq_(res.total_length, self.total_length)
        eq_(res.identification, self.identification)
        eq_(res.flags, self.flags)
        eq_(res.offset, self.offset)
        eq_(res.ttl, self.ttl)
        eq_(res.proto, self.proto)
        eq_(res.csum, self.csum)
        eq_(res.src, self.src)
        eq_(res.dst, self.dst)
        eq_(ptype, tcp) 
開發者ID:lagopus,項目名稱:ryu-lagopus-ext,代碼行數:18,代碼來源:test_ipv4.py

示例2: parse_pckt

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def parse_pckt(pkt):
    pkt = packet.Packet(array.array('B', pkt))
    try:
        eth = pkt.get_protocol(ethernet.ethernet)
        _ipv4 = pkt.get_protocol(ipv4.ipv4)
    
        if _ipv4.proto == 6:
            _tcp = pkt.get_protocol(tcp.tcp)
            src_port, dst_port = _tcp.src_port, _tcp.dst_port
        elif _ipv4.proto == 17:
            _udp = pkt.get_protocol(udp.udp)
            src_port, dst_port = _udp.src_port, _udp.dst_port
        return [_ipv4.proto, _ipv4.src, src_port, _ipv4.dst, dst_port]
    except Exception as err:
        print "Error"
        raise err 
開發者ID:cchliu,項目名稱:SDN-Defense,代碼行數:18,代碼來源:alert_parser.py

示例3: getProtocol

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def getProtocol(self, pkt):
	pkt_ipv4 = pkt.get_protocol(ipv4.ipv4)
	tp = pkt.get_protocol(tcp.tcp)
	port = 0
	if tp:
		port = tp.dst_port
	ud = pkt.get_protocol(udp.udp)
	if ud:
		port = ud.dst_port
	#print "PORTA: %s" % port
	if pkt_ipv4:
		protocol = pkt_ipv4.proto
		if protocol==1:
			return "ICMP"
		if protocol==6:
			if port==80:
				return "HTTP"
			if port==443:
				return "HTTPS"
			return "TCP"
		if protocol==17:
			if port==53:
				return "DNS"
			if port==67:
				return "DHCP"
			return "UDP"
	return "Unknown. If you confirm, you will add a general traffic rule (= every type of traffic) between src and dst" 
開發者ID:iFedix,項目名稱:FirewallController,代碼行數:29,代碼來源:live.py

示例4: getMatch

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def getMatch(self, pkt, parser, in_port, dst):
	pkt_ipv4 = pkt.get_protocol(ipv4.ipv4)
	tp = pkt.get_protocol(tcp.tcp)
	port = 0
	if tp:
		port = tp.dst_port
	ud = pkt.get_protocol(udp.udp)
	if ud:
		port = ud.dst_port
	#print "PORTA: %s" % port
	if pkt_ipv4:
		protocol = pkt_ipv4.proto
		if protocol==1:
			return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=1)
		if protocol==6:
			if port==80:
				return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=6, tcp_dst=80)
			if port==443:
				return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=6, tcp_dst=443)
			return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=6)
		if protocol==17:
			if port==53:
				parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=17, udp_dst=53)
			if port==67:
				parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=17, udp_dst=67)
			return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=17)
	return parser.OFPMatch(in_port=in_port, eth_dst=dst)

    #metodo per filtrare mac address in ingresso (=passano dal controller senza conferma dell'utente) 
開發者ID:iFedix,項目名稱:FirewallController,代碼行數:31,代碼來源:live.py

示例5: shortest_forwarding

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def shortest_forwarding(self, msg, eth_type, ip_src, ip_dst):
		"""
			Calculate shortest forwarding path and Install them into datapaths.
			flow_info = (eth_type, src_ip, dst_ip, in_port)
			or
			flow_info = (eth_type, ip_src, ip_dst, in_port, ip_proto, Flag, L4_port)
		"""
		datapath = msg.datapath
		in_port = msg.match['in_port']
		pkt = packet.Packet(msg.data)
		tcp_pkt = pkt.get_protocol(tcp.tcp)
		udp_pkt = pkt.get_protocol(udp.udp)
		ip_proto = None
		L4_port = None
		Flag = None
		# Get ip_proto and L4 port number.
		ip_proto, L4_port, Flag = self.get_L4_info(tcp_pkt, udp_pkt, ip_proto, L4_port, Flag)
		result = self.get_sw(datapath.id, in_port, ip_src, ip_dst)   # result = (src_sw, dst_sw)
		if result:
			src_sw, dst_sw = result[0], result[1]
			if dst_sw:
				# Path has already been calculated, just get it.
				path = self.get_path(src_sw, dst_sw, weight=self.weight)
				if ip_proto and L4_port and Flag:
					if ip_proto == 6:
						L4_Proto = 'TCP'
					elif ip_proto == 17:
						L4_Proto = 'UDP'
					else:
						pass
					self.logger.info("[PATH]%s<-->%s(%s Port:%d): %s" % (ip_src, ip_dst, L4_Proto, L4_port, path))
					flow_info = (eth_type, ip_src, ip_dst, in_port, ip_proto, Flag, L4_port)
				else:
					self.logger.info("[PATH]%s<-->%s: %s" % (ip_src, ip_dst, path))
					flow_info = (eth_type, ip_src, ip_dst, in_port)
				# Install flow entries to datapaths along the path.
				self.install_flow(self.datapaths,
								  self.awareness.link_to_port,
								  path, flow_info, msg.buffer_id, msg.data)
		else:
			# Flood is not good.
			self.flood(msg) 
開發者ID:Huangmachi,項目名稱:PureSDN,代碼行數:44,代碼來源:PureSDN.py

示例6: initial_event

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def initial_event(self,ev):
        if ev.msg.msg_len < ev.msg.total_len:
            self.logger.debug("packet truncated: only %s of %s bytes",
                              ev.msg.msg_len, ev.msg.total_len)
        #Call <Pkt_Parse> to Build pkt object
        parsPkt = Pkt_Parse()
        pkt = parsPkt.handle_pkt(ev)
        
        # Call appropriate handler for arriving packets (add IPv6,DHCP,etc.)
        if pkt['udp'] != None:
            self.handle_udp(pkt)
        elif pkt['tcp'] != None:
            self.handle_tcp(pkt)
        elif pkt['icmp6'] != None:
            self.handle_icmp6(pkt)
        elif pkt['icmp'] != None:
            self.handle_icmp(pkt)
        elif pkt['ip']!= None:
            self.handle_ip(pkt)
        elif pkt['ip6'] != None:
            self.handle_ip6(pkt)
        elif pkt['arp']!=None:
            self.handle_arp(pkt)
        elif pkt['dhcp']!=None:
            self.handle_dhcp(pkt)
        elif pkt['eth'] != None:
            self.handle_eth(pkt)
        else:
            print "Packet not identified"
            self.handle_unk(pkt)

    # The following functions all must be overridden. Some may be able to be
    # passed, but most will likely be overridden. 
開發者ID:Ryuretic,項目名稱:RyureticLabs,代碼行數:35,代碼來源:Ryuretic.py

示例7: test_serialize

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def test_serialize(self):
        offset = 5
        csum = 0

        src_ip = '192.168.10.1'
        dst_ip = '192.168.100.1'
        prev = ipv4(4, 5, 0, 0, 0, 0, 0, 64,
                    inet.IPPROTO_TCP, 0, src_ip, dst_ip)

        t = tcp.tcp(self.src_port, self.dst_port, self.seq, self.ack,
                    offset, self.bits, self.window_size, csum, self.urgent)
        buf = t.serialize(bytearray(), prev)
        res = struct.unpack(tcp.tcp._PACK_STR, six.binary_type(buf))

        eq_(res[0], self.src_port)
        eq_(res[1], self.dst_port)
        eq_(res[2], self.seq)
        eq_(res[3], self.ack)
        eq_(res[4], offset << 4)
        eq_(res[5], self.bits)
        eq_(res[6], self.window_size)
        eq_(res[8], self.urgent)

        # test __len__
        # offset indicates the number of 32 bit (= 4 bytes)
        # words in the TCP Header.
        # So, we compare len(tcp) with offset * 4, here.
        eq_(offset * 4, len(t))

        # checksum
        ph = struct.pack('!4s4sBBH',
                         addrconv.ipv4.text_to_bin(src_ip),
                         addrconv.ipv4.text_to_bin(dst_ip), 0, 6, offset * 4)
        d = ph + buf
        s = packet_utils.checksum(d)
        eq_(0, s) 
開發者ID:lagopus,項目名稱:ryu-lagopus-ext,代碼行數:38,代碼來源:test_tcp.py

示例8: test_serialize_option

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def test_serialize_option(self):
        # prepare test data
        offset = 0
        csum = 0
        option = [
            tcp.TCPOptionMaximumSegmentSize(max_seg_size=1460),
            tcp.TCPOptionSACKPermitted(),
            tcp.TCPOptionTimestamps(ts_val=287454020, ts_ecr=1432778632),
            tcp.TCPOptionNoOperation(),
            tcp.TCPOptionWindowScale(shift_cnt=9),
        ]
        option_buf = (
            b'\x02\x04\x05\xb4'
            b'\x04\x02'
            b'\x08\x0a\x11\x22\x33\x44\x55\x66\x77\x88'
            b'\x01'
            b'\x03\x03\x09'
        )
        prev = ipv4(4, 5, 0, 0, 0, 0, 0, 64,
                    inet.IPPROTO_TCP, 0, '192.168.10.1', '192.168.100.1')

        # test serializer
        t = tcp.tcp(self.src_port, self.dst_port, self.seq, self.ack,
                    offset, self.bits, self.window_size, csum, self.urgent,
                    option)
        buf = t.serialize(bytearray(), prev)
        r_option_buf = buf[tcp.tcp._MIN_LEN:tcp.tcp._MIN_LEN + len(option_buf)]
        eq_(option_buf, r_option_buf)

        # test parser
        (r_tcp, _, _) = tcp.tcp.parser(buf)
        eq_(str(option), str(r_tcp.option)) 
開發者ID:lagopus,項目名稱:ryu-lagopus-ext,代碼行數:34,代碼來源:test_tcp.py

示例9: test_malformed_tcp

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def test_malformed_tcp(self):
        m_short_buf = self.buf[1:tcp.tcp._MIN_LEN]
        tcp.tcp.parser(m_short_buf) 
開發者ID:lagopus,項目名稱:ryu-lagopus-ext,代碼行數:5,代碼來源:test_tcp.py

示例10: test_json

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def test_json(self):
        jsondict = self.t.to_jsondict()
        t = tcp.tcp.from_jsondict(jsondict['tcp'])
        eq_(str(self.t), str(t)) 
開發者ID:lagopus,項目名稱:ryu-lagopus-ext,代碼行數:6,代碼來源:test_tcp.py

示例11: getProtocol

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def getProtocol(self, pkt):
        pkt_ipv4 = pkt.get_protocol(ipv4.ipv4)
        tp = pkt.get_protocol(tcp.tcp)
        port = 0
        if tp:
            port = tp.dst_port
        ud = pkt.get_protocol(udp.udp)
        if ud:
            port = ud.dst_port
        # print "PORTA: %s" % port
        if pkt_ipv4:
            protocol = pkt_ipv4.proto
            if protocol == 1:
                return "ICMP"
            if protocol == 6:
                if port == 80:
                    return "HTTP"
                if port == 443:
                    return "HTTPS"
                return "TCP"
            if protocol == 17:
                if port == 53:
                    return "DNS"
                if port == 67:
                    return "DHCP"
                return "UDP"
        return "Unknown. If you confirm, you will add a general traffic rule (= every type of traffic) between src and dst" 
開發者ID:MrOverflOOw,項目名稱:TurnoutController,代碼行數:29,代碼來源:turnout.py

示例12: getMatch

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def getMatch(self, pkt, parser, in_port, dst):
        pkt_ipv4 = pkt.get_protocol(ipv4.ipv4)
        tp = pkt.get_protocol(tcp.tcp)
        port = 0
        if tp:
            port = tp.dst_port
        ud = pkt.get_protocol(udp.udp)
        if ud:
            port = ud.dst_port
        # print "PORTA: %s" % port
        if pkt_ipv4:
            protocol = pkt_ipv4.proto
            if protocol == 1:
                return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=1)
            if protocol == 6:
                if port == 80:
                    return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=6, tcp_dst=80)
                if port == 443:
                    return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=6, tcp_dst=443)
                return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=6)
            if protocol == 17:
                if port == 53:
                    parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=17, udp_dst=53)
                if port == 67:
                    parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=17, udp_dst=67)
                return parser.OFPMatch(in_port=in_port, eth_dst=dst, eth_type=0x0800, ip_proto=17)
        return parser.OFPMatch(in_port=in_port, eth_dst=dst) 
開發者ID:MrOverflOOw,項目名稱:TurnoutController,代碼行數:29,代碼來源:turnout.py

示例13: packet_in_handler

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def packet_in_handler(self, ev):
        msg = ev.msg
        dp = msg.datapath
        dpid = dp.id
        ofproto = dp.ofproto

        pkt = packet.Packet(msg.data)
        tcp_header = pkt.get_protocol(tcp.tcp)

        if tcp_header is None or (tcp_header.src_port is not 179 and
           tcp_header.dst_port is not 179):
            # ignore non-BGP packet
            return

        ipv4_header = pkt.get_protocol(ipv4.ipv4)
        src_ip = ipv4_header.src
        dst_ip = ipv4_header.dst
        self.logger.info("BGP from %s to %s", src_ip, dst_ip)

        # create a path from src to dst
        hosts = topo_api.get_all_host(self)
        src_host = None
        dst_host = None

        for host in hosts:
            if src_ip in host.ipv4:
                src_host = host

            elif dst_ip in host.ipv4:
                dst_host = host

        if src_host is None or dst_host is None:
            # can't find src or dst, drop it
            return

        src_port = src_host.port
        dst_port = dst_host.port
        dst_mac = dst_host.mac
        to_dst_match = dp.ofproto_parser.OFPMatch(eth_dst=dst_mac,
                                                  ipv4_dst=dst_ip,
                                                  eth_type=2048)

        port_no = self.fwd.setup_shortest_path(src_port.dpid,
                                               dst_port.dpid,
                                               dst_port.port_no,
                                               to_dst_match)

        if port_no is None:
            # Can't find path to destination, ignore it.
            return

        self.packet_out(dp, msg, port_no) 
開發者ID:sdnds-tw,項目名稱:Ryu-SDN-IP,代碼行數:54,代碼來源:fwd_bgp.py

示例14: test_default_args

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def test_default_args(self):
        prev = ipv4(proto=inet.IPPROTO_TCP)
        t = tcp.tcp()
        buf = t.serialize(bytearray(), prev)
        res = struct.unpack(tcp.tcp._PACK_STR, buf)

        eq_(res[0], 1)
        eq_(res[1], 1)
        eq_(res[2], 0)
        eq_(res[3], 0)
        eq_(res[4], 5 << 4)
        eq_(res[5], 0)
        eq_(res[6], 0)
        eq_(res[8], 0)

        # with option, without offset
        t = tcp.tcp(option=[tcp.TCPOptionMaximumSegmentSize(1460)])
        buf = t.serialize(bytearray(), prev)
        res = struct.unpack(tcp.tcp._PACK_STR + '4s', buf)

        eq_(res[0], 1)
        eq_(res[1], 1)
        eq_(res[2], 0)
        eq_(res[3], 0)
        eq_(res[4], 6 << 4)
        eq_(res[5], 0)
        eq_(res[6], 0)
        eq_(res[8], 0)
        eq_(res[9], b'\x02\x04\x05\xb4')

        # with option, with long offset
        t = tcp.tcp(offset=7, option=[tcp.TCPOptionWindowScale(shift_cnt=9)])
        buf = t.serialize(bytearray(), prev)
        res = struct.unpack(tcp.tcp._PACK_STR + '8s', buf)

        eq_(res[0], 1)
        eq_(res[1], 1)
        eq_(res[2], 0)
        eq_(res[3], 0)
        eq_(res[4], 7 << 4)
        eq_(res[5], 0)
        eq_(res[6], 0)
        eq_(res[8], 0)
        eq_(res[9], b'\x03\x03\x09\x00\x00\x00\x00\x00') 
開發者ID:lagopus,項目名稱:ryu-lagopus-ext,代碼行數:46,代碼來源:test_tcp.py

示例15: redis_flush_request

# 需要導入模塊: from ryu.lib.packet import tcp [as 別名]
# 或者: from ryu.lib.packet.tcp import tcp [as 別名]
def redis_flush_request(self):
        while True:
            hub.sleep(5)
            curr_ts = int(time.time())
            http = self.redis.hgetall("HTTP")
            https = self.redis.hgetall("HTTPS")
            icmp = self.redis.hgetall("ICMP")
            tcp = self.redis.hgetall("TCP")
            udp = self.redis.hgetall("UDP")

            self.logger.warn("RedisFLush @ %s, %s, %s", time.time(), http, icmp)
            """
            port_tags = {
                "dp_name": self.dp.name,
                "port_name": port_name,
            }
            """
            """
                points = [{
                "measurement": "port_state_reason",
                "tags": port_tags,
                "time": int(rcv_time),
                "fields": {"value": reason}}]
            """

            point_http = self.collect_points(http, "HTTP", curr_ts)
            point_https = self.collect_points(https, "HTTPS", curr_ts)
            point_icmp = self.collect_points(icmp, "ICMP", curr_ts)
            point_udp = self.collect_points(udp, "UDP", curr_ts)
            point_tcp = self.collect_points(tcp, "TCP", curr_ts)

            self.ship_points(point_http)
            self.remove_flushed(point_http, "HTTP")
            self.ship_points(point_https)
            self.remove_flushed(point_https, "HTTPS")

            self.ship_points(point_icmp)
            self.remove_flushed(point_icmp, "ICMP")

            self.ship_points(point_udp)
            self.remove_flushed(point_udp, "UDP")

            self.ship_points(point_tcp)
            self.remove_flushed(point_tcp, "TCP") 
開發者ID:onfsdn,項目名稱:noc,代碼行數:46,代碼來源:faucet.py


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