黑帽联盟

 找回密码
 会员注册
查看: 1607|回复: 0
打印 上一主题 下一主题

[php] PHP限制页面只能在微信自带浏览器访问的代码

[复制链接]

895

主题

38

听众

3323

积分

管理员

Rank: 9Rank: 9Rank: 9

  • TA的每日心情
    无聊
    5 天前
  • 签到天数: 1644 天

    [LV.Master]伴坛终老

    为了防止自己辛辛苦苦做的webapp被人copy,我们都想限制程序只能在微信里面浏览,虽然下面实现了这个功能,单都是小菜,没什么技术含量,懂代码的伪造下就破了。下面是PHP限制页面只能在微信自带浏览器访问的代码。
    1. <!--?php
    2. $useragent = $_SERVER['HTTP_USER_AGENT'];
    3. if (strpos($useragent, 'MicroMessenger') === false) {
    4. echo " 非微信浏览器禁止访问";
    5. } else {
    6. echo "微信浏览器允许访问";
    7. }
    复制代码
    上面这个代码还不完善,Windows phone的微信就不能用了,于是修改下:
    1. <!--?php
    2. $useragent = addslashes($_SERVER['HTTP_USER_AGENT']);
    3. if(strpos($useragent, 'MicroMessenger') === false && strpos($useragent, 'Windows Phone') === false ){
    4. echo " 非微信浏览器禁止访问bbs.cnblackhat.com";
    5. }else{
    6. echo "微信浏览器允许访问bbs.cnblackhat.com";
    7. }
    复制代码
    大家可以通过获取 HTTP_USER_AGEN,判断。

    但是你觉得上面的方法能阻止别人去偷窃你的界面,你就错了,只要伪造一下HTTP_USER_AGEN还是能正常访问。
    在谷歌浏览器上面装个User-Agent Switcher,还是能随便访问。于是我还想到用JS来判断是不是手机访问,但是只要浏览器禁止JS运行,还是能正常访问。。不过或许这样能难到一些新手吧。
    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    勿忘初心,方得始终!
    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部