Maison  >  Article  >  développement back-end  >  Exemple d'explication de l'obtention automatique d'une adresse IP publique en Python

Exemple d'explication de l'obtention automatique d'une adresse IP publique en Python

黄舟
黄舟original
2017-10-09 10:40:141612parcourir

L'éditeur suivant vous apportera un exemple de la façon d'obtenir automatiquement une IP publique en Python. L'éditeur le trouve plutôt bon, je vais donc le partager avec vous maintenant et le donner comme référence pour tout le monde. Venez jeter un œil avec l'éditeur

0.1 SQL. Installation de base

ubuntu, série Debian :

Redhat, série Centos Installation :


root@raspberrypi:~/python-script# apt-get install mysql-server

Connectez-vous à la base de données


 [root@localhost ~]# yum install mysql-server
où se trouve MySQL la commande client -u est l'utilisateur spécifié -p est le mot de passe -h est l'hôte

Créer une base de données et créer une table de données


La syntaxe de création d'une base de données est la suivante

pi@raspberrypi:~ $ mysql -uroot -p -hlocalhost
Enter password: 
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 36
Server version: 10.0.30-MariaDB-0+deb8u2 (Raspbian)

Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]>

La syntaxe pour créer une table de données est la suivante


MariaDB [(none)]> help create database
Name: 'CREATE DATABASE'
Description:
Syntax:
CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name
 [create_specification] ...

create_specification:
 [DEFAULT] CHARACTER SET [=] charset_name
 | [DEFAULT] COLLATE [=] collation_name

CREATE DATABASE creates a database with the given name. To use this
statement, you need the CREATE privilege for the database. CREATE
SCHEMA is a synonym for CREATE DATABASE.

URL: https://mariadb.com/kb/en/create-database/


MariaDB [(none)]>
Créer une base de données ServiceLogs


MariaDB [(none)]> help create table
Name: 'CREATE TABLE'
Description:
Syntax:
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
 (create_definition,...)
 [table_options]
 [partition_options]

Or:

CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
 [(create_definition,...)]
 [table_options]
 [partition_options]
 select_statement
Créer une table de données


MariaDB [(none)]> CREATE DATABASE `ServiceLogs`
Requête du contenu de la table


MariaDB [(none)]> CREATE TABLE `python_ip_logs` (
 `serial_number` bigint(20) NOT NULL AUTO_INCREMENT,
 `time` datetime DEFAULT NULL,
 `old_data` varchar(50) DEFAULT NULL,
 `new_data` varchar(50) DEFAULT NULL,
 PRIMARY KEY (`serial_number`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1

Opération de connexion python 0.2 MySQL


 MariaDB [ServiceLogs]> select * from python_ip_logs;
 Empty set (0.00 sec)
Téléchargement et installation du module

Chemin de téléchargement : https://pypi. python.org/pypi/MySQL-pythonInstallation :

Connecter Mysql


安装:
解压
unzip MySQL-python-1.2.5.zip
进入解压后目录
cd MySQL-python-1.2.5/
安装依赖
apt-get install libmysqlclient-dev
安装
python setup.py install
如果为0则安装OK
echo $?
Si Connect Mysql réussi est affiché, la connexion est OK

Instruction d'insertion Python MySQL


root@raspberrypi:~/python-script# cat p_mysql_3.py 
#!/usr/bin/env python

import MySQLdb

try :
  conn = MySQLdb.connect("主机","用户名","密码","ServiceLogs")
  print ("Connect Mysql successful")
except:
  print ("Connect MySQL Fail")
root@raspberrypi:~/python-script#

Une fois l'exécution terminée, vous pouvez voir les résultats avec l'instruction SELECT du client MySQL


1.1 Exigences

root@raspberrypi:~/python-script# cat p_mysql1.py 
#!/usr/bin/env python

import MySQLdb

db = MySQLdb.connect("localhost","root","root","ServiceLogs")

cursor = db.cursor()

sql = "insert INTO python_ip_logs VALUES (DEFAULT,'2017-09-29 22:46:00','123','456')"

cursor.execute(sql)
db.commit()

db.close()
root@raspberrypi:~/python-script#

1.1 Exigences<.>Étant donné que le haut débit obtiendra une nouvelle IP à chaque redémarrage, alors dans cet état, il y aura beaucoup d'inconvénients lors de l'établissement d'une connexion SSH. Heureusement, il existait auparavant le logiciel Peanut Shell, qui. peut trouver votre adresse IP via le nom de domaine et y accéder. C'est le meilleur, mais récemment, Peanut Shell nécessite également de vrais noms. Il ne peut être utilisé qu'après authentification, cela m'a donc incité à écrire un script python pour obtenir l'adresse IP publique.

Effet de réussite : lorsque l'adresse IP change, une notification peut être envoyée par e-mail et les données peuvent être écrites dans la base de données 1.2

Idée générale

1.3

Organigramme

Les autres codes ne sont rien à dessiner

2.

Écriture de codes

2.1.1 Écrire du code python

getnetworkip.pysavedb .py


send_mail.py
root@raspberrypi:~/python-script# cat getnetworkip.py 
#!/usr/bin/env python
# coding:UTF-8

import requests
import send_mail
import savedb

def get_out_ip() :
  url = r&#39;http://www.trackip.net/&#39;
  r = requests.get(url)
  txt = r.text
  ip = txt[txt.find(&#39;title&#39;)+6:txt.find(&#39;/title&#39;)-1]
  return (ip)

def main() :
  try:
    savedb.general_files()

    tip = get_out_ip()
    cip = savedb.read_files()


    if savedb.write_files(cip,tip) :
      send_mail.SamMail(get_out_ip())
  except :
    return False

if __name__=="__main__" :
  main()
root@raspberrypi:~/python-script#


root@raspberrypi:~/python-script# cat savedb.py
#!/usr/bin/env python

import MySQLdb
import os
import time

dirname = "logs"
filename = "logs/.ip_tmp"

def general_files(Default_String="Null") :

  var1 = Default_String

  if not os.path.exists(dirname) :
    os.makedirs(dirname)

  if not os.path.exists(filename) :
    f = open(filename,&#39;w&#39;)
    f.write(var1)
    f.close()

def read_files() :
  f = open(filename,&#39;r&#39;)
  txt = f.readline()
  return (txt)

def write_files(txt,new_ip) :
  if not txt == new_ip :
    NowTime = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
    old_ip = read_files()
    os.remove(filename)
    general_files(new_ip)
    write_db(NowTime,old_ip,new_ip)
    return True
  else:
    return False


def write_db(NowTime,Old_ip,New_ip) :
  db = MySQLdb.connect("主机","用户名","密码","库名")

  cursor = db.cursor()

  sql = """
    INSERT INTO python_ip_logs 
    VALUES
    (DEFAULT,"%s","%s","%s")
  """ %(NowTime,Old_ip,New_ip)

  try:
    cursor.execute(sql)
    db.commit()
  except:
    db.rollback()

  db.close()
root@raspberrypi:~/python-script#

3 .Le effet


L'email reçu est le suivant :
root@raspberrypi:~/python-script# cat send_mail.py
#!/usr/bin/env python

import smtplib
import email.mime.text

def SamMail(HtmlString) :
 HOST = "smtp.163.com"
 SUBJECT = "主题"
 TO = "对方的邮箱地址"
 FROM = "来自于哪里"
 Remask = "The IP address has been changed"

 msg = email.mime.text.MIMEText("""
  <html>
    <head>
      <meta charset="utf-8" />
    </head>
    <body>
      <em><h1>ip:%s</h1></em>
    </body>
  </html>
  """ %(HtmlString),"html","utf-8")

 msg[&#39;Subject&#39;] = SUBJECT
 msg[&#39;From&#39;] = FROM
 msg[&#39;TO&#39;] = TO

 try:
  server = smtplib.SMTP()
  server.connect(HOST,&#39;25&#39;)
  server.starttls()
  server.login("用户名","密码")
  server.sendmail(FROM,TO,msg.as_string())
  server.quit()
 except:
  print ("Send mail Error")
root@raspberrypi:~/python-script# 
 print ("%s" %(line),end=&#39;&#39;)

Utilisez SELECT pour visualiser le tableau, l'effet est le suivant :

Mettez le script dans crontab et laissez-le exécuter les tâches planifiées

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn