Blog
-
apc.use_request_time
发现 Ubuntu 下的 PHP 里的 apcu 的 cache 始终不过期,结果查了半天,cli 模式下, apc.use_request_time 是被开启的状态。
-
WordPress Extra Authentication
Nginx snippets adding extra basic auth to wordpress.
location ~ ^/(xmlrpc|wp-.+)/?.*\.php$ { auth_basic "hahaha"; auth_basic_user_file "/etc/nginx/sskaje.auth"; fastcgi_split_path_info ^(.+\.php)(/.+)$; fastcgi_pass unix:/run/php/php-fpm.sock; fastcgi_index index.php; include fastcgi.conf; fastcgi_intercept_errors on; }
Create Password File
htpasswd -c /etc/nginx/sskaje.auth sskaje
Add User
htpasswd /etc/nginx/sskaje.auth sskaje
-
iOS HTTPS 抓包工具
介绍一些用过的好用的 iOS 下 HTTPS 的抓包工具。
这些工具的实现原理都是使用 Network Extension 实现VPN,设置路由规则到 VPN 的设备里,再进行流量筛选,例如筛 TCP Port 443 的,转发到内部实现的一个代理服务上,通过中间人攻击的方式,实现 HTTPS 的协议解密甚至劫持。
这些工具的操作步骤大都如下:
- 安装 App。
- 安装并信任证书。最近的 iOS 安装自定义 CA 证书,会需要用户自己到设置里安装描述文件,再去关于本机的证书信任设置里手动启用 CA 证书。
- 创建 VPN。App 里有明确的引导,将用户跳转到 VPN 添加页面。但是这里的VPN 在 App 卸载的时候不会自动删除。
- 配置规则或者默认全部TCP 443
- 启用并解析
这里有个风险,如果使用者不能确认 App 安装的证书完全是本机现生成的私钥及证书且都没有上传到服务器上,那请在使用完相关App 后,至少是取消掉对该 CA 的信任。
以下对比仅限于被对比的对象,优点和缺点不是绝对的。
1. Stream,一款免费的 iOS 程序,看简介应该是中国开发者开发的,可以在 IAP 里赞助开发者。
- 优点:免费,功能直观,而且还算比较完整,可以构造请求。
- 缺点:用户引导做得不够好,如果不懂原理,可能配置不成功。
2. Charles for iOS,Charles Proxy 的 iOS版,功能很简单,就是小贵。
- 优点:功能简单,用户体验好,支持阻断连接(Block List)
- 缺点:付费(不是坏事),而且功能还是稍微少了点,不支持构造请求。
上述两款软件都支持的功能有:
- DNS Spoofing 劫持 DNS 解析
- 记录的黑白名单
都缺的功能
- 修改请求 (Charles 电脑版的 Rewrite 和 Breakpoint)
- 回放请求。
还有个对比项没有去验证,但是大多数情况应该用不到,就是直接的SSL/TLS 请求的记录和解析。
其他软件就太夸张了,要不贵的要死,要不不可理喻。
-
MITM 与 HTTPS 流量劫持
VPS 硬盘挂之前,blog 里留了一篇文章,如何使用 redsocks + linux policy based routing 实现对手机 HTTPS 流量的劫持。具体方案懒得再写了。简单描述一下原理,后边的文章会需要引用。
上图是引用自 Wikipedia 的中间人攻击的页面。
最古老的年代,通信缺少加密,所以中间传信的人可能能看到并篡改内容。后来,从算法保密,到算法公开密钥保密,再到后来 PKI 的出现,逐渐实现了相对安全的加密通信。
但是,从开发、调试和安全研究的角度看,在拿不到 SSL/TLS 通信密钥的情况下,中间人攻击是协议调试的一个重要手段。(当然,如果能拿到 SSL/TLS 通信密钥,例如可以修改 SSL/TLS 握手的库,记录下来,就可以直接 tcpdump/wireshark 抓包,再用 wireshark 填入密钥就可以解密了。)
加密通讯的中间人攻击,第一个典型场景的必要手段是让客户端信任中间人的证书,常见的手段:
- 例如客户端不校验证书(签发者,时间,Common Name等),
- 或者当客户端使用系统的方法和系统的 CA 库去校验的时候,安装自签的 CA 证书再用这个 CA 去签发被劫持的证书,
- 甚至 Patch 的方式替换原有程序里写死的证书或证书策略(例如 Android)。
第二个典型的必要手段是劫持流量,或者信道。常见的做法:
- 如果被劫持的目标对象使用系统的代理,或者有代理设置的选项,修改这个选项。
- 如果该目标不使用代理,但是系统平台有方法劫持,例如 proxifier(一个值得买的 win/mac 代理工具),使用 proxifier 可以按通讯地址端口或者进程名称将应用的流量。
- 如果是不认代理设置的运行在封闭系统(iOS / Android)下的程序,就可以考虑网络设备上 NAT + redsocks 的方案将流量转到 Charles Proxy 或者 Fiddler 的 socks 代理上。
- 其他的,例如 iOS/mac 的 Network Extension。。。
近些年有些麻烦,一个是 Certificate Pinning,一个是 TLS 1.3。遇到自己实现的 Certificate Pinning,时间成本会上去,这里在越狱的 iOS 设备上推荐 https://github.com/nabla-c0d3/ssl-kill-switch2,可能大部分程序的检查都能绕过,FB 家的不行。TLS 1.3,如果自己实现的客户端不接受降级到 TLS 1.2或者更低,目前我无解,不知道有没有best practice。
-
iodine on Ubuntu/macOS
iodine 是一个比较著名(但是好久没更新版本)的DNS Tunnel,所谓 IP over DNS,用 DNS 的协议来承载 IP 包,所以特点是慢,但是针对某些 DNS 可用的场景,可以凑合解决上网的问题。
(more…)