from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.chrome.service import Service from selenium.webdriver.chrome.options import Options from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC import requests from PIL import Image import pytesseract import io import time import re import os import tkinter as tk from tkinter import messagebox # 单独导入 messagebox from ftp import set_proxy from ftp import upload_file_to_ftp from ftp import upload_directory_to_ftp from ftp import create_remote_directory import requests # def launch_proxy(): # print("开启代理...") # cmd = "start ./Shadowsocks-4.4.1.0/Shadowsocks.exe" # os.system('chcp 65001') # os.system(cmd) # # def close_proxy(): # print("杀死代理进程") # cmd = "taskkill /f /im Shadowsocks.exe" # os.system('chcp 65001') # os.system(cmd) # cmd = """ # reg add "HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings" /v ProxyEnable /t REG_DWORD /d 0 /f # """ # print(cmd) # os.system(cmd) def shot(chromedriver_path ,chrome_path): options = Options() options.binary_location = chrome_path options.add_argument("--no-sandbox") # 初始化 WebDriver service = Service(chromedriver_path) driver = webdriver.Chrome(service=service, options=options) driver.get("http://125.64.9.222:8022/login_exam.php") try: time.sleep(5) exam_id = name_entry.get() student_id = id_entry.get() password = password_entry.get() try: # 创建文件夹 os.mkdir(folder_path) # 如果目录已存在,则会抛出OSError print(f"文件夹 '{folder_path}' 创建成功!") except FileExistsError: print(f"文件夹 '{folder_path}' 已存在!") except Exception as e: print(f"创建文件夹时发生错误: {e}") # 填写 exam_id, student_id 和 password driver.find_element(By.ID, "exam_id").send_keys(exam_id) # exam_id driver.find_element(By.ID, "student_id").send_keys(student_id) # student_id driver.find_element(By.ID, "password").send_keys(password) # password # 获取验证码图片 captcha_image = driver.find_element(By.CSS_SELECTOR, "img[src='./lib/image_code_1.php']") # 截取验证码图片 captcha = captcha_image.screenshot_as_png # 打开验证码图片 captcha = Image.open(io.BytesIO(captcha)) captcha.save("captcha.png") # 可选,保存图片以供调试 captcha_text = pytesseract.image_to_string(captcha, config="--psm 6") print(f"识别到的验证码: {captcha_text}") # 填写验证码 driver.find_element(By.ID, "imageCode").send_keys(captcha_text.strip()) # 提交表单 driver.find_element(By.ID, "ok").click() # 替换为实际的提交按钮 ID # 获取页面 Cookies cookies = driver.get_cookies() session_cookies = {cookie['name']: cookie['value'] for cookie in cookies} # 用 requests 请求目标 URL url = "http://125.64.9.222:8022/paper/student_server_info.php" response = requests.get(url, cookies=session_cookies) response.raise_for_status() # 确保请求成功 print(response.text) # 打印响应内容 matches = [match.strip() for match in re.findall(r"(?<=:).*?(?=
)", response.text)] print(matches) with open("info.txt", "w", encoding="utf-8") as f: for match in matches: f.write(match + "\n") # 保存结果到文件 # command = "start result.txt" # subprocess.Popen(command, shell=True) # 打开结果文件 # 等待页面加载或处理结果 # WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.ID, "result"))) # 替换为实际的结果 ID # print("登录成功!") exam_config = f"""