随笔分类 - CTF
CTF
摘要:原理 php中serialize(),unserialize()这两个函数。 序列化serialize() 序列化说通俗点就是把一个对象变成可以传输的字符串,比如下面是一个对象: class S{ public $test="pikachu"; } $s=new S(); //创建一个对象 seri
阅读全文
摘要:水平越权 查看到其他用户的信息或者通过其他用户去编辑或修改其他用户的信息 1. 用lucy/123456登录 2. 点击查看信息 3. 使用burpsuite拦截请求 GET /vul/overpermission/op1/op1_mem.php?username=lucy&submit=%E7%8
阅读全文
摘要:1. 反射型XSS(get) 输入<script>alert("test")</script> 发现有长度限制(maxlength), F12 修改对输入框的长度限制,或者直接改url并encode(url为:http://localhost:8080/vul/xss/xss_reflected_g
阅读全文
摘要:宽字节注入原理 什么是宽字节? 如果一个字符的大小是一个字节的,称为窄字节; 如果一个字符的大小是两个字节的,成为宽字节; 像GB2312、GBK、GB18030、BIG5、Shift_JIS等这些编码都是常说的宽字节,也就是只有两字节 英文默认占一个字节,中文占两个字节 什么是宽字节注入? 原理:
阅读全文
摘要:输入框输入任何消息返回内容都是一样的 那么可以考虑插入sleep函数来观察响应时长来判断是否有注入点 输入 kobe' and sleep(3) # 发现页面缓冲3秒才响应,说明确实是注入点 通过if 判断条件为true,来执行sleep五秒,来判断if的条件是否正确 kobe' and if((s
阅读全文
摘要:输入框中输入 已知用户名 kobe 显示了用户信息 your uid:3 your email is: kobe@pikachu 输入kobe'看一下情况 显示 您输入的username不存在,请重新输入! 这还不能确定是否存在注入点,换一种方式 kobe' and 1=1 # 可以显示出kobe的
阅读全文
摘要:使用admin登录 显示以下内容 朋友,你好,你的信息已经被记录了:点击退出 你的ip地址:172.17.0.1 你的user agent:Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:105.0) Gecko/20100101 Firefox/105.0 你
阅读全文
摘要:留言板输入几条信息 出现删除按钮,点他 通过burpsuite拦截请求,请求报文如下 GET /vul/sqli/sqli_del.php?id=57 HTTP/1.1 Host: 192.168.1.9:8080 User-Agent: Mozilla/5.0 (X11; Ubuntu; Linu
阅读全文
摘要:insert 注入 (修改信息处是update注入,和此处同理) 注册页面,用户处输入 1' 发现报错信息 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server ver
阅读全文
摘要:由于level 是 high 1.代码审计 <?php if( isset( $_POST[ 'Upload' ] ) ) { // Where are we going to be writing to? $target_path = DVWA_WEB_PAGE_TO_ROOT . "hackab
阅读全文
摘要:level low 可以看到查询请求为 http://192.168.31.xxx/vulnerabilities/sqli/?id=1&Submit=Submit# ##### id 改为 `id=1' or '1'='1` 用来闭合单引号,实现注入 http://192.168.31.xxx/v
阅读全文
摘要:1 试玩 apk # 安装APK到真机 adb install AliCrackme_1.apk 打开apk,投石问路,输入123试一下 2 将apk 拖入androidKiller,得到反编译的smali文件项目 smali目录地址在androidkiller目录下的projects/AliCra
阅读全文
摘要:#include <stdio.h> class aclass{ private: int m; char c; public: aclass(int i, char ch) { printf("Constructor called.\n"); this->m = i; this->c = ch;
阅读全文
摘要:#include <stdio.h> int switch1(int a, int b, int i){ switch (i){ case 1: return a + b; break; case 2: return a - b; break; case 3: return a * b; break
阅读全文
摘要:#include <stdio.h> int dowhile(int n){ int i = 1; int s = 0; do{ s += i; }while(i++ < n); return s; } int whiledo(int n){ int i = 1; int s = 0; while(
阅读全文
摘要:#include <stdio.h> void if1(int n){ //if else语句 if(n < 10){ printf("the number less than 10\n"); } else { printf("the number greater than or equal to
阅读全文
摘要:C源码 #include <stdio.h> int nums[5] = {1, 2, 3, 4, 5}; int for1(int n){ //普通for循环 int i = 0; int s = 0; for (i = 0; i < n; i++){ s += i * 2; } return s
阅读全文
摘要:JAVA 源码 ... String str1 = packedSwitch(1); ... private String packedSwitch(int i) { String str = null; switch (i) { case 0: str = "she is a baby"; bre
阅读全文
摘要:1.首先将crackme0502 拖入模拟器。打开应用,随意输出字符串 2. 将APK 拖入AndroidKiller 反编译 3.先查看androidmanifest.xml <?xml version="1.0" encoding="utf-8" standalone="no"?> <manif
阅读全文
摘要:编写Hello.smali文件 .class public LHelloWorld; .super Ljava/lang/Object; .method public static main([Ljava/lang/String;)V .registers 4 .parameter .prologu
阅读全文