50行代码搞定模拟登陆

前言

        近日心情郁闷,随手写了个模拟登陆的小脚本,大多数登陆网站都一样,在这抛砖引玉。

        以NIIT培训网站为例,因为报了一个培训,每日登陆可送积分,老师上课不咋地还弄个头在那,搞得看视频整个尴尬症都犯了(要是放个美女帅哥还差不多,偷笑),话不多说,以下放干货。

正文

一、看本文前,我默认大家都知道http 的post、get请求、cookie、session等

1.打开网站首页,建议大家可以使用fidder抓包工具,可以很方便地看出所有请求和头信息。

50行代码搞定模拟登陆_第1张图片

2.启用fidder,可以看到网址的请求已被监听,接下来,我们开始看登陆需要提交的参数

50行代码搞定模拟登陆_第2张图片
3.

3.点击登陆,输入用户名和密码,登陆

50行代码搞定模拟登陆_第3张图片

注意以上几个地方,action 提交实际的地址,需要输入的用户名和密码的ID,以下在fidder里面均可得到验证

50行代码搞定模拟登陆_第4张图片

二、接下来我们使用约50行python代码完整模拟登陆

1.声明一些网站变量


        self.session = requests.Session()

        self.home_url="http://www.training-china.com/index.html"

        self.user_url = "http://www.training-china.com/setting/basic"

        self.loginurl = 'http://www.training-china.com/loginvalidate.html'


2.伪造http头协议和post数据<代码格式好乱>


    headers = {

    'Proxy-Connection': 'Keep-Alive',         '

    Accept-Language': 'en,zh-CN;q=0.9,zh;q=0.8',

'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',

'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36',

'Accept-Encoding': 'gzip, deflate',

'Host': 'http://www.training-china.com',

'Referer': 'http://www.training-china.com/login.html?from=http://www.trainingchina.com/index.html'

}

postdata:

# post form data


        data = {

            "login_username": username,

            "login_password": password,

            "rememberMe": "on",

            "from": self.home_url,

        }


3.登陆,使用python3 requests可以说十分简便,一行代码搞定


response = self.session.post(url=self.loginurl, data=data, headers=self.headers)


4.把登陆信息存储为cookie,在cookie失效之前都可以直接读取cookie登陆


self.session.cookies = http.cookiejar.LWPCookieJar(filename='NIITCookies')

self.session.cookies.save()

三、以上基本完成了登陆过程,核心代码不过20行,接下来优化一些问题,封装过程,写一个判断登陆方法

1.是否登陆


def isLogin(self):

        """

        通过查看用户个人信息来判断是否已经登录

        禁止重定向,否则登录失败重定向到首页也是响应200

        :param url: 需要登陆的固定url

        :return: 是否登陆bool值

        """

        login_code = self.session.get(self.user_url, headers=self.headers, allow_redirects=False).status_code

        if login_code == 200:

            return True

        else:

            return False


2.封装完整过程

具体代码已上传github:niit模拟登陆

四、设置自动任务自动登陆

1.使用Linux的crontab命令,详情请看crontab使用

简单脚本niit.sh

date

python3.6 /home/leal/Public/fuck-login/022-NIIT/niit.py

date

echo "#########################################"


设置定时任务,每天12:00执行登陆一次


# 每天12:00自动登陆

00 12 * * * sh /home/leal/Public/fuck-login/022-NIIT/niit.sh >>/home/leal/Public/fuck-login/022-NIIT/niitlogin.log

更新,可以通过关注加好友和加入学团获得积分,遍历所有用户和学团并加入。


后记

        此外登陆之后还可以设置视频自动播放获取积分,感兴趣的朋友可以试试。

你可能感兴趣的:(50行代码搞定模拟登陆)