ddxiami

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 3145|回复: 0

应用场景04-模拟用户登陆

[复制链接]
发表于 2020-6-7 12:26:14 | 显示全部楼层 |阅读模式
#将php源码放置到www.test.com目录下,底下是python源码


#!/usr/bin/python3
import urllib.request
import http.cookiejar
import urllib.parse

# 登录的主页面
host_url = 'http://www.test.com/php_login/form.php'  # 自己填写
# post数据接收和处理的页面(我们要向这个页面发送我们构造的Post数据)
post_url = 'http://www.test.com/php_login/action.php'  # 从数据包中分析出,处理post请求的url
# 目标地址
target_url = 'http://www.test.com/php_login/main.php'  # 从数据包中分析出,处理post请求的url


#先访问目标地址
h = urllib.request.urlopen(target_url)
print("访问目标地址:")
print(h.read().decode())

# 设置一个cookie处理器,它负责从服务器下载cookie到本地,并且在发送请求时带上本地的cookie
cj = http.cookiejar.LWPCookieJar()
cookie_support = urllib.request.HTTPCookieProcessor(cj)
opener = urllib.request.build_opener(cookie_support, urllib.request.HTTPHandler)
urllib.request.install_opener(opener)
# 打开登录主页面(他的目的是从页面下载cookie,这样我们在再送post数据时就有cookie了,否则发送不成功)
h = urllib.request.urlopen(host_url)
print("访问登陆地址:")
print(h.read().decode())

# 构造header,一般header至少要包含一下两项。这两项是从抓到的包里分析得出的。
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Firefox/52.0',
          'Referer': 'https://www.baidu.com'}
            
# 构造Post数据,他也是从抓大的包里分析得出的。
postData = {"user": 'hzg',
             "pwd": '123456',
             "sub": "sub"}
            
# 需要给Post数据编码
postData = urllib.parse.urlencode(postData).encode('utf-8')
# 通过urllib2提供的request方法来向指定Url发送我们构造的数据,并完成登录过程
request = urllib.request.Request(post_url, postData, headers)
response = urllib.request.urlopen(request)
print(response.read().decode())


#访问目标地址
h = urllib.request.urlopen(target_url)
print("模拟登陆后:")
print(h.read().decode())







php_login.zip

3.31 KB, 下载次数: 608

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|技术文档库 ( 闽ICP备15017263号-2 )|网站地图

GMT+8, 2025-5-18 19:54 , Processed in 0.037306 second(s), 19 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表