
1 mengskysama 2014-10-26 14:33:25 +08:00 IP是不能伪造的,不要相信 X-FORWARD 和 X-CLIENT-IP直接在前端获取访问者IP。除非他真的有很多真实IP。 |
2 mengskysama 2014-10-26 14:35:38 +08:00 cf cdn有一个黑科技就是能够识别出浏览器UA是伪造的还是真实的。具体原理我没研究过。可能是挂载一个script请求,如果client没有正确回应就是爬虫,这样的,你也可以实现一个。 |
3 holyghost 2014-10-26 14:53:57 +08:00 伪造ip的话,网络层不救直接把包发到伪造的地址去了?。。。 |
4 jookr 2014-10-26 14:57:03 +08:00 获取IP只需要一句话,$_SERVER["REMOTE_ADDR"]这就足够了,没必要也不应该获取代理IP地址,REMOTE_ADDR是服务器和客户端握手后建立的tcp连接的数据帧里的,在应用层是无法修改的。当然,也不是绝对没有办法伪造的,IP协议可以完全自定义传输的数据,路由器这层也能伪造,但对于WEB程序员来说,是底层的东西,无法修改和伪造的。 |
5 haishan 2014-10-26 15:56:27 +08:00 现在googleappengine支持php 了 |
6 lshero 2014-10-27 01:15:43 +08:00 你的意思网站直接被反向代理了? 随机的在页面里面插入一段JS 获取当前页面的URL,并且判断这个URL的域名是不是你自己的,如果不是就强行跳转回你的网站呗。 |
7 esile 2014-10-27 12:58:12 +08:00 nginx挂前端,然后根据url来统计来访ip的次数,每天统计封停一次,包解决。 小偷程序就是图省事的,如果你天天封它ip估计它也没兴趣跟你玩。。。。 |
8 esile 2014-10-27 12:59:10 +08:00 关闭其他url的日志记录,只记录一个特定url即可,这样生成的日志小,便于统计。。。 |
9 hopestar86 OP |
10 lshero 2014-10-27 18:56:29 +08:00 @hopestar86 还是统计某个IP访问的频次吧后端用 redis之类的做一个计数器 如果5分钟之内访问的次数过多,直接返回500或者404就行了,话说你不能用 REMOTE_ADDR获取IP嘛? HTTP头中的 HTTP_CLIENT_IP HTTP_X_FORWARDED_FOR 这些随便伪造但是REMOTE_ADDR想伪造应该不好弄吧 |