diff --git a/src/change_url/change_url.py b/src/change_url/change_url.py index 0647255..b1b5f1d 100644 --- a/src/change_url/change_url.py +++ b/src/change_url/change_url.py @@ -1,10 +1,16 @@ import re +import requests +from sqlalchemy import create_engine +from sqlalchemy import text as sql_text -hth_keywords = ["华体会", "hth", "HTH", "代理WEB", "代理web"] -ky_keywords = ["开云"] -jy_keywords = ["九游"] - +try: + engine = create_engine("mysql+mysqlconnector://ky_tools:HJQY35seXen8patn@1panel.stupidpz.com:3306/ky_tools") + connection = engine.connect() + print('链接成功') +except: + print('连接失败!') +ky_base64 = '' def read_file(filename): try: with open(filename, 'r') as file: @@ -65,8 +71,8 @@ def get_url_mapping(urls_with_context, template_type): "{{jyApp}}": categories.get("全站", [""])[0], "{{jyQp}}": categories.get("棋牌", [""])[0], "{{jyDz}}": categories.get("电子", [""])[0], - "{{jyFljPc}}": categories.get("WEB", [""])[1], - "{{jyFljH5}}": categories.get("H5", [""])[1], + "{{jyFljPc}}": categories.get("WEB", [""])[1] if len(categories.get("WEB", [""])) == 2 else '', + "{{jyFljH5}}": categories.get("H5", [""])[1] if len(categories.get("H5", [""])) == 2 else '', } else: print('未知模板') @@ -79,56 +85,76 @@ def extract_urls(text): # seo_part_index = text.find("SEO 防拦截域名") # relevant_text = text[:seo_part_index] if seo_part_index != -1 else text pattern = r'(?:\n|^)\s*([^\n]*?)\s*(https?://[^\s]+)' - matches = re.findall(pattern, text) - return [(context.strip(), url) for context, url in matches] + #查找到所有的url + url_type = 'unknown' + is_agent = False + url_list = re.findall(pattern, text) + for context, url in url_list: + try: + response = requests.get(url,headers={'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36'}) + if response.status_code == 200: + if "开云" in response.text or ky_base64 in response.text or "开云" in text: + url_type = 'ky' + elif '华体会' in response.text: + url_type = 'hth' + elif '九游' in response.text: + url_type = 'jy' + # 判断是后台代理连接 + if '马甲包' in response.text: + is_agent = True + if url_type != 'unknown': + update_agent_url(url_list, url_type) + break + except requests.RequestException: + print(f"URL '{url}' 不可用,跳过。") + else: + print(f"未找到匹配的关键词。") + return [(context.strip(), url) for context, url in url_list], url_type, is_agent +def update_agent_url(url_list,url_type): + for context, url in url_list: + if any(keyword in context for keyword in ["代理WEB", "代理web", "代理Web"]): + try: + update_stmt = sql_text(f"UPDATE ky_tools.ky_account SET url = :url WHERE type = :url_type") + connection.execute(update_stmt, {"url": url, "url_type": url_type}) + connection.commit() + except Exception as e: + print(f"执行SQL语句出错:{e}") + finally: + connection.close() + break -def change_url(text, hth_template_path='/www/wwwroot/change_url/hth.js.template', - ky_template_path='/www/wwwroot/change_url/ky.js.template', - jy_template_path='/www/wwwroot/change_url/jy.js.template'): +def change_url(text): try: - urls_with_context = extract_urls(text) + urls_with_context, url_type, is_agent = extract_urls(text) expected_filename = None - if any(keyword in text for keyword in hth_keywords): - template_path = hth_template_path - template_type = 'hth' - elif any(keyword in text for keyword in ky_keywords): - template_path = ky_template_path - template_type = 'ky' - elif any(keyword in text for keyword in jy_keywords): - template_path = jy_template_path - template_type = 'jy' - else: + if url_type == 'unknown': return False, 'unknown.js' + if not is_agent: + template_path = f'/www/wwwroot/change_url/{url_type}.js.template' + js_content = read_file(template_path) + url_mapping = get_url_mapping(urls_with_context, url_type) + updated_content = replace_urls(js_content, url_mapping) + expected_filename = template_path.replace('.template', '') + write_file(expected_filename, updated_content) - js_content = read_file(template_path) - url_mapping = get_url_mapping(urls_with_context, template_type) - updated_content = replace_urls(js_content, url_mapping) - expected_filename = template_path.replace('.template', '') - write_file(expected_filename, updated_content) - - return True, expected_filename + return True, expected_filename + return True, '代理更新' except Exception as e: print(f"An error occurred: {e}") return False, expected_filename if expected_filename else 'unknown.js' if __name__ == '__main__': - text = '''#域名更换通知 -通知:以下是最新域名: + text = '''代理web https://www.hfh3u.com:9015   +代理web https://www.8fxf6.com:9073 +代理web https://www.6weff.com:9553 +代理H5 https://www.ewnv0x.com:9019 +代理H5 https://www.esoojr.com:9962  +代理H5 https://www.ehqu1z.com:8663''' + # res = requests.get("https://www.e5vj65s.com:9961") + # print(res) + # print("华体会" in res.text) + # print("开云" in res.text) + # print("九游" in res.text) -web - https://www.e5vj65s.com:9961 【新】 -h5 -https://www.g81mly.com:8553       -全站APP -https://www.9n3nhg.vip:9017     -体育APP -https://www.c9jngo.vip:6004   -代理web -https://www.kvvgv.com:9043 -代理H5 -https://www.lt08m.com:9960 - - -备注:域名后面的数字为正常,请勿删除''' - change_url(text,hth_template_path='template/hth.js.template',ky_template_path='template/ky.js.template',jy_template_path='template/jy.js.template') \ No newline at end of file + change_url(text) \ No newline at end of file