记录 制作校园网登陆脚本 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()

猜你喜欢

转载自www.cnblogs.com/lianfeng132/p/10767838.html