记录 制作校园网登陆脚本 python编写 附源码
‘’‘
首先我们分析一下
1.需要本机的IP
使用 socket 获取
2.需要向服务器提交的数据
构造请求数据 并分析数据可替换
3.检测登陆成功
检测登陆是否成功
’‘’
获取IP 这样会返回 本机IP
def get_ip(self): try: s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) s.connect(('8.8.8.8',80)) ip = s.getsockname()[0] finally: #关闭 s.close() #返回IP return ip
构造请求体
1 b_data = { 2 'DDDDD':',0,'+us+codeinfo, 3 'upass':pa, 4 'para':'00', 5 '0MKKey':'123456' 6 7 } 8 9 #关于发送的请求内容 可以使用浏览器 F12 进行查看发送的数据信息
向服务器发送请求
headers = { 'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.204 Safari/537.36', 'Upgrade-Insecure-Requests': '1', }
#data为请求体 ip 为本机ip url = requests.post('http://172.16.1.38:801/eportal/?c=ACSetting&a=Login&protocol=http:&hostname=172.16.1.38&iTermType=1&wlanuserip={}&wlanacip=null&wlanacname=null&mac=00-00-00-00-00-00&ip={}&enAdvert=0&queryACIP=0&jsVersion=2.4.3&loginMethod=1'.format(ip,ip),headers=headers,data=data)
#这样是一个简单的发送请求 但是如果别人想用的话每次更改不会很麻烦嘛?
更改后的全部源码 1 import requests 2 3 import socket 4
5 import os 6 import re 7 8 class AOA(object): 9 #获取本机IP 10 def get_ip(self): 11 try: 12 s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) 13 s.connect(('8.8.8.8',80)) 14 ip = s.getsockname()[0] 15 finally: 16 #关闭 17 s.close() 18 #返回IP 19 return ip 20 21 22 def open_msg(self,path_dirs): 23 ''' 24 获取外部的text 文档 的账号密码 25 :return: 26 '''
27 if 'login_msg' in os.listdir(path_dirs): #如果login_msg文件 有的话 会 跳过 【如果登陆过一次的话 会生成文件】 28 pass 29 else: #没有login_msg文件的话 证明为第一次登陆 30 username = input('请输入账号') 31 password = input('请输入密码') 32 code = input('请选择运营商 1 = 移动 | 2 = 电信 | 3 = 联通') 33 print('正在进行保存') 34 with open('login_msg','w+',encoding='utf8') as o: 35 o.write('账号={},\r密码={},\r运营商={},\r#注意不要有空格'.format(username,password,code)) #进行保存文件处理 36 37 with open(os.path.join(path_dirs,'login_msg'),'r+',encoding='utf8') as f : #打开文件
38 #获取文件的账号密码和运行商
text = f.read() 39 username = re.findall(r'账号=(\d{10}),',text)[0] if re.findall(r'账号=(\d{10}),',text) else print('账号获取错误') 40 password = re.findall(r'密码=(.*?),',text)[0] if re.findall(r'密码=(.*?),',text) else print('密码获取错误') 41 login_code =re.findall(r'运营商=([1-3]),',text)[0] if re.findall(r'运营商=(.*?),',text)[0] else print('运营商获取错误') 42 msg = { 43 'username':username, 44 'password':password, 45 'login_code':login_code, 46 } 47 return msg #形成字典形式返回数据 48 49 50 def extract_data(self,user_data): #使数据进行组合处理 51 #拿出账号密码 52 us = user_data.get('username') #账号 53 pa = user_data.get('password') #密码 54 code = int(user_data.get("login_code")) #获取的为整数类型 55 56 if code == 1 : 57 codeinfo = "@cmcc" #移动 58 elif code == 2 : 59 codeinfo = "@telecom" #电信 60 elif code == 3: 61 codeinfo = "@unicom" #联通 62 else: 63 raise '请输入正确的' 64 b_data = { 65 'DDDDD':',0,'+us+codeinfo, 66 'upass':pa, 67 'para':'00', 68 '0MKKey':'123456' 69 70 } 71 return b_data 72 #进行登陆处理 73 def login(self,data,ip): 74 75 headers = { 76 'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.204 Safari/537.36', 77 'Upgrade-Insecure-Requests': '1', 78 } 79 url = requests.post('http://172.16.1.38:801/eportal/?c=ACSetting&a=Login&protocol=http:&hostname=172.16.1.38&iTermType=1&wlanuserip={}&wlanacip=null&wlanacname=null&mac=00-00-00-00-00-00&ip={}&enAdvert=0&queryACIP=0&jsVersion=2.4.3&loginMethod=1'.format(ip,ip),headers=headers,data=data) 80 81 def if_get(self): 82 code = requests.get('http://www.baidu.com') 83 if code.status_code ==200: 84 print('登陆成功') 85 else: 86 print('登陆失败') 87 88 89 def main(self,): 90 #获取路径 91 LOCAL_PATH = os.path.abspath('') 92 ip = self.get_ip() #获取本机IP 93 user_data_str = self.open_msg(path_dirs=LOCAL_PATH) #获取账号密码信息 不做判断 和 数据整合 94 header_text = self.extract_data(user_data_str) #进行数据整合 95 self.login(data=header_text,ip=ip) 96 self.if_get() 97 98 99 100 j = AOA() 101 j.main()