您的位置:首页 > 其它

Bugkuctf web 秋名山

2019-05-06 00:14 302 查看


新知识又来啦!!!
题目链接
看到这个题,有点懵,这个玩意儿啷个计算呢?
2秒,怕是在开玩笑哦
没啥路子,就不要脸的去找了一下writeup

附上一个他滴链接
链接如下

好了,还是要有自己的干货
又学到不少知识,比如python,花了一天去撸了一遍基础知识!

附上使用的py代码

import requests
import re
url='http://120.24.86.145:8002/qiumingshan/'
r=requests.session()#获取session保持与网页连接
requestpage = r.get(url)
ans=re.findall('<div>(.*?)=?;</div>',requestpage.text)#以文本格式打开并匹配
ans="".join(ans)#列表转为字符串
ans=ans[:-2]#去掉最后的?;
post=eval(ans)#计算表达式的值
data={'value':post}#构造post的data部分
flag=r.post(url,data=data)
print(flag.text)

ps :跑不出来的,看看是不是URL有问题哦!

re 模块 -----正则表达式模块
要去熟悉一下,稍不注意就是正则表达式!

介绍一下 findall()
反正我是不知道这个东西
进入正题!!!

findall(pattern, string, flags=0)
第一个参数,正则表达式

第二个参数,搜索的是那些字符串

第三个参数,匹配的模式,其中re.S使匹配包括换行在内的所有字符。findall()函数是逐行匹配的。

返回string中所有与pattern相匹配的全部字串,返回形式为列表

request模块

附上链接
如果有点看不懂呢,就看这个链接

学习一下内容

一个网络访问模块
从官网找到的简介

  1. Requests 是使用 Apache2 Licensed 许可证的 HTTP 库。用 Python 编写,真正的为人类着想。
  2. Requests 使用的是 urllib3,因此继承了它的所有特性。Requests 支持 HTTP 连接保持和连接池,支持使用 cookie 保持会话,支持文件上传,支持自动确定响应内容的编码,支持国际化的 URL 和 POST 数据自动编码。现代、国际化、人性化。

来了一个新名词urllib3,好吧又不知道是啥,百度一波

附上链接

好像内容特别多。然后和本题没啥关系,那就后面需要的时候 再来用吧,感兴趣滴可以撸上一撸

好的,回到我们的requests来,感觉是比较重要的

安装略。。。(自行解决哈)

还是盘点一下这里用到的吧

#get类型
r = requests.get('https://github.com/timeline.json')
#post类型
r = requests.post("http://m.ctrip.com/post")
#URL传递参数
payload = {'key1': 'value1', 'key2': 'value2'}
r = requests.get("http://pythontab.com/justTest", params=payload)

#获取响应内容
print r.content #以字节的方式去显示,中文显示为字符
print r.text #以文本的方式去显示
其他知识点

join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串。

str = "-";
seq = ("a", "b", "c"); # 字符串序列
print str.join( seq );

结果:a-b-c
eval() 函数用来执行一个字符串表达式,并返回表达式的值。

GET!!!

希望对大家有帮助哦!

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: