Heim Backend-Entwicklung Python-Tutorial In Python implementierte Codefreigabe für ein Skript, das die unschuldige IP-Datenbank speichert

In Python implementierte Codefreigabe für ein Skript, das die unschuldige IP-Datenbank speichert

May 21, 2017 pm 01:37 PM

Wir müssen die Daten in der Innocence IP-Datenbank häufig für die Analyse bei der Arbeit verwenden. Der folgende Artikel stellt hauptsächlich vor, wie man Python verwendet, um einen Dump der Innocence IP-Datenbank zu implementieren . Es hat einen gewissen Referenz- und Lernwert. Freunde, die es brauchen, können einen Blick darauf werfen.

Vorwort

Ich habe schon viele Artikel über Scan-Skripte geschrieben, aber ich habe noch nie darüber geschrieben, woher ich mein Scan-IP-Segment habe Ich komme oft, um nach ihrer Scan-Erfahrung zu fragen. Ehrlich gesagt denke ich, dass dieses Tool keinen eigentlichen technischen Inhalt hat, aber es kann die Arbeitseffizienz verbessern, also werde ich es mit allen teilen~

Wenn es um die Scan-Erfahrung geht , I Einzelpersonen wählen normalerweise unterschiedliche Arten von Segmenten für unterschiedliche Geräte und Anwendungen.

Das Ziel, das ich scanne, ist natürlich das IP-Segment von China Telecom. Optische Modems sind im Allgemeinen Heimanwender kann sie gezielt ansprechen.

Als weiteres Beispiel: Wenn ich jetzt ein Unternehmens-Routing--Gerät scannen möchte, dann kann ich ein Segment mit vielen Unternehmen auswählen.

Innocent IP ist wirklich ein gutes Tool. Ich verwende es normalerweise, um nach IP-Segmenten in einer bestimmten Region zu suchen. Dieses Tool hat jedoch einen sehr schwerwiegenden Nachteil, nämlich dass es keine gemeinsame Abfrage, was es sehr nervig macht, und jedes Mal, wenn ich dieses Ding benutze, muss ich wechseln, um zu gewinnen. Für einen Linux-Menschen wie mich ist das natürlich unerträglich, also habe ich einfach einen Weg geschrieben, das Unschuldige zu übertragen IP-to-MySQL-Datenbank-Skript, sodass Sie nicht jedes Mal, wenn Sie eine Abfrage durchführen, die Abfrage durchführen müssen. Das Wichtigste ist um Abfragen mit mehreren Bedingungen zu unterstützen.

Anforderungen

Das Schreiben dieses Skripts in Python ist technisch nicht schwierig. In Bezug auf die

-Installation wird verwendet MySQLdb-Bibliothek Ich werde nicht viel mehr sagen, ich habe bereits verwandte Artikel in meinem Blog geschrieben. Hier müssen wir zunächst die Datendateistruktur der Innocence IP-Datenbank analysieren und feststellen, dass die Struktur jeder Zeile tatsächlich festgelegt ist, sodass das Schreiben einfach ist.

Ich werde nicht näher auf die Codierung eingehen. Dies lässt sich leicht mit ein paar einfachen Methoden erreichen.

#!/usr/bin/env python
# coding=utf-8
# kbdancer@92ez.com

import MySQLdb
import sys

reload(sys)
sys.setdefaultencoding('utf8')


def save_data_to_mysql(mysql_object, ip_line):
 try:
  begin = ip_line[0:16].replace(' ', '')
  end = ip_line[16:32].replace(' ', '')
  try:
   location = line[32:].split(' ')[0]
  except:
   location = ''
  try:
   isp_type = line[32:].replace(' ', ' ').split(' ')[1].replace('\n', '').replace('\r', '')
  except:
   isp_type = ''

  this_line_value = [begin + "-" + end, location, isp_type]
  do_insert(mysql_object, this_line_value)
 except Exception, e:
  print e


def do_insert(mysql_object, row_data):
 try:
  insert_sql = """INSERT INTO `ipdb` (`iprange`,`location`, `type`) VALUES ( %s, %s, %s )"""
  mysql_object.insert(insert_sql, row_data)
 except Exception, e:
  print row_data
  print e


class Database:
 host = 'localhost'
 user = 'ipdb'
 password = '3u9whrpcEUBTnNNn'
 db = 'ipinfo'
 charset = 'utf8'

 def init(self):
  self.connection = MySQLdb.connect(self.host, self.user, self.password, self.db, charset=self.charset)
  self.cursor = self.connection.cursor()

 def insert(self, query, params):
  try:
   self.cursor.execute(query, params)
   self.connection.commit()
  except Exception, e:
   print e
   self.connection.rollback()

 def query(self, query, params):
  cursor = self.connection.cursor(MySQLdb.cursors.DictCursor)
  cursor.execute(query, params)
  return cursor.fetchall()

 def del(self):
  self.connection.close()


if name == 'main':
 mysql = Database()
 ip_file = open(sys.path[0] + "/ip.txt")
 print 'Start save to mysql ...'
 for line in ip_file:
  save_data_to_mysql(mysql, line)
 ip_file.close()
 print 'Save complete.'
Nach dem Login kopieren

Hinweis

Hier liegt ein Leistungsproblem vor, das heißt, beim Durchlaufen aller Daten müssen Sie den Vorgang des

Einfügens von Daten in die -Bibliothek ausführen ist sehr niedrig. Es wird empfohlen, mehrzeilige Einfügungen zu verwenden, z. B. das Schreiben von CacheArray, wenn das Cache-Array beispielsweise 100 erreicht 100 Elemente werden gleichzeitig in der Datenbank gespeichert. Diese Geschwindigkeit ist viel schneller als das Speichern eines einzelnen Elements. Blogger, ich werde hier ein Loch graben. Ich hoffe, dass Freunde, die Skripte verwenden, es selbst ändern können.

Da es sich bei der aus der Innocence IP-Datenbank exportierten TXT-Datei nicht um eine standardmäßige BOM-freie UTF8-Kodierung handelt, wird die direkte Analyse definitiv fehlschlagen. Es wird empfohlen, sie zuerst mit Notepad++ zu transkodieren

Wirkung

Originaldaten


Daten nach Übertragung


Um

zu verwenden, müssen Sie zunächst die unschuldige IP-Datenbank als TXT-Dokument exportieren. Hier exportiere ich sie als ip.txt


Dann legen Sie es in das gleiche Verzeichnis des Py-Skripts


Übrigens müssen Sie zuerst eine MySQL-Datenbank haben


und dann

importieren Sie die Datenbankstruktur , also die SQL-Datei

Dann müssen Sie das MySQL-Verbindungspasswort im Skript usw. ändern.


Zum Schluss führen Sie einfach das Py-Skript aus

Erklärung

Das obige ist der detaillierte Inhalt vonIn Python implementierte Codefreigabe für ein Skript, das die unschuldige IP-Datenbank speichert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP und Python: Code Beispiele und Vergleich PHP und Python: Code Beispiele und Vergleich Apr 15, 2025 am 12:07 AM

PHP und Python haben ihre eigenen Vor- und Nachteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1.PHP eignet sich für eine schnelle Entwicklung und Wartung großer Webanwendungen. 2. Python dominiert das Gebiet der Datenwissenschaft und des maschinellen Lernens.

Python gegen JavaScript: Community, Bibliotheken und Ressourcen Python gegen JavaScript: Community, Bibliotheken und Ressourcen Apr 15, 2025 am 12:16 AM

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Detaillierte Erklärung des Docker -Prinzips Detaillierte Erklärung des Docker -Prinzips Apr 14, 2025 pm 11:57 PM

Docker verwendet Linux -Kernel -Funktionen, um eine effiziente und isolierte Anwendungsumgebung zu bieten. Sein Arbeitsprinzip lautet wie folgt: 1. Der Spiegel wird als schreibgeschützte Vorlage verwendet, die alles enthält, was Sie für die Ausführung der Anwendung benötigen. 2. Das Union File System (UnionFS) stapelt mehrere Dateisysteme, speichert nur die Unterschiede, speichert Platz und beschleunigt. 3. Der Daemon verwaltet die Spiegel und Container, und der Kunde verwendet sie für die Interaktion. 4. Namespaces und CGroups implementieren Container -Isolation und Ressourcenbeschränkungen; 5. Mehrere Netzwerkmodi unterstützen die Containerverbindung. Nur wenn Sie diese Kernkonzepte verstehen, können Sie Docker besser nutzen.

So führen Sie Programme in der terminalen VSCODE aus So führen Sie Programme in der terminalen VSCODE aus Apr 15, 2025 pm 06:42 PM

Im VS -Code können Sie das Programm im Terminal in den folgenden Schritten ausführen: Erstellen Sie den Code und öffnen Sie das integrierte Terminal, um sicherzustellen, dass das Codeverzeichnis mit dem Terminal Working -Verzeichnis übereinstimmt. Wählen Sie den Befehl aus, den Befehl ausführen, gemäß der Programmiersprache (z. B. Pythons Python your_file_name.py), um zu überprüfen, ob er erfolgreich ausgeführt wird, und Fehler auflösen. Verwenden Sie den Debugger, um die Debugging -Effizienz zu verbessern.

Kann Visual Studio -Code in Python verwendet werden Kann Visual Studio -Code in Python verwendet werden Apr 15, 2025 pm 08:18 PM

VS -Code kann zum Schreiben von Python verwendet werden und bietet viele Funktionen, die es zu einem idealen Werkzeug für die Entwicklung von Python -Anwendungen machen. Sie ermöglichen es Benutzern: Installation von Python -Erweiterungen, um Funktionen wie Code -Abschluss, Syntax -Hervorhebung und Debugging zu erhalten. Verwenden Sie den Debugger, um Code Schritt für Schritt zu verfolgen, Fehler zu finden und zu beheben. Integrieren Sie Git für die Versionskontrolle. Verwenden Sie Tools für die Codeformatierung, um die Codekonsistenz aufrechtzuerhalten. Verwenden Sie das Lining -Tool, um potenzielle Probleme im Voraus zu erkennen.

Python: Automatisierung, Skript- und Aufgabenverwaltung Python: Automatisierung, Skript- und Aufgabenverwaltung Apr 16, 2025 am 12:14 AM

Python zeichnet sich in Automatisierung, Skript und Aufgabenverwaltung aus. 1) Automatisierung: Die Sicherungssicherung wird durch Standardbibliotheken wie OS und Shutil realisiert. 2) Skriptschreiben: Verwenden Sie die PSUTIL -Bibliothek, um die Systemressourcen zu überwachen. 3) Aufgabenverwaltung: Verwenden Sie die Zeitplanbibliothek, um Aufgaben zu planen. Die Benutzerfreundlichkeit von Python und die Unterstützung der reichhaltigen Bibliothek machen es zum bevorzugten Werkzeug in diesen Bereichen.

Kann gegen Code in Windows 8 ausgeführt werden Kann gegen Code in Windows 8 ausgeführt werden Apr 15, 2025 pm 07:24 PM

VS -Code kann unter Windows 8 ausgeführt werden, aber die Erfahrung ist möglicherweise nicht großartig. Stellen Sie zunächst sicher, dass das System auf den neuesten Patch aktualisiert wurde, und laden Sie dann das VS -Code -Installationspaket herunter, das der Systemarchitektur entspricht und sie wie aufgefordert installiert. Beachten Sie nach der Installation, dass einige Erweiterungen möglicherweise mit Windows 8 nicht kompatibel sind und nach alternativen Erweiterungen suchen oder neuere Windows -Systeme in einer virtuellen Maschine verwenden müssen. Installieren Sie die erforderlichen Erweiterungen, um zu überprüfen, ob sie ordnungsgemäß funktionieren. Obwohl VS -Code unter Windows 8 möglich ist, wird empfohlen, auf ein neueres Windows -System zu upgraden, um eine bessere Entwicklungserfahrung und Sicherheit zu erzielen.

Ist die VSCODE -Erweiterung bösartig? Ist die VSCODE -Erweiterung bösartig? Apr 15, 2025 pm 07:57 PM

VS -Code -Erweiterungen stellen böswillige Risiken dar, wie das Verstecken von böswilligem Code, das Ausbeutetieren von Schwachstellen und das Masturbieren als legitime Erweiterungen. Zu den Methoden zur Identifizierung böswilliger Erweiterungen gehören: Überprüfung von Verlegern, Lesen von Kommentaren, Überprüfung von Code und Installation mit Vorsicht. Zu den Sicherheitsmaßnahmen gehören auch: Sicherheitsbewusstsein, gute Gewohnheiten, regelmäßige Updates und Antivirensoftware.

See all articles