Discuz_X 에서 비교적 실 용적 인 함수 [전재]

2703 단어 PHP직장레저
전재 하 다http://blog.panzhibiao.com/index.php/archives/331  
버 전: x2Beta
로봇 여 부 를 판단 하고 모 바 일 기기 여 부 를 판단 하 다.
이 거 는 직접 모 으 는 게 귀 찮 은 것 같 아 요.
/ / 로봇, 파충류 function checkrobot ($useragent = ') {static $kw spiders =' Bot | Crawl | Spider | slurp | sohu - search | lycos | robozilla '; static $kw browsers =' MSIE | Netscape | Opera | Konqueror | Mozilla '; $useragent = empty ($useragent)? $SERVER [' HTTP USER AGENT ']: $useragent; if (! strexists ($useragent,' http: / ') & preg match ("/ / / /")($kw browsers) / i ", $useragent) {return false;} elseif (preg match (" / ($kw spiders) / i ", $useragent)) {return true;} else {return false;} / / 모 바 일 장치 function checkmobile () {global $G; $mobile = array () 여 부 를 판단 합 니 다.; static $mobilebrowser_list ='iPhone|Android|phone|WAP|NetFront|JAVA|Opera\sMini|UCWEB|Windows\sCE|Symbian|Series|webOS|SonyEricsson|Sony|BlackBerry|IEMobile|dopod|Nokia|samsung|PalmSource|Xda|PIEPlus|MEIZU|MIDP|CLDC'; if(preg_match("/$mobilebrowser_list/i", $_SERVER['HTTP_USER_AGENT'], $mobile)) { $_G['mobile'] = $mobile[0]; return true; } else { if(preg_match('/(mozilla|chrome|safari|opera|m3gate|winwap|openwave|myop)/i', $_SERVER['HTTP_USER_AGENT'])) { return false; } else { $_G['mobile'] = 'unknown'; if($_GET['mobile'] === 'yes') { return true; } else { return false; } } } }
 
XSS 크로스 사이트 주입 방지
왼쪽 괄호 '<', 작은 따옴표 가 있 는 지 확인 하여 이 문 자 를 발견 하면 즉시 exit. 베타 버 전 작은 bug.
function _xss_check() { $temp = strtoupper(urldecode(urldecode($_SERVER['REQUEST_URI']))); if(strpos($temp, '<') !== false || strpos($temp, '"') !== false || strpos($temp,'CONTENT-TRANSFER-ENCODING')!==false) { system_error('request_tainting'); } return true; }
 

클 라 이언 트 IP 주소 가 져 오기
정규 / ^ ([0 - 9] {1, 3} \.) {3} [0 - 9] {1, 3} $/ 를 사용 하여 합 법 여 부 를 판단 하지만 엄격 하지 않 습 니 다. 함수 ip2long () 을 직접 사용 하면 됩 니 다. 여 기 는 모두 IPV 4 입 니 다.
function _get_client_ip() { $ip = $_SERVER['REMOTE_ADDR']; if (isset($_SERVER['HTTP_CLIENT_IP']) && preg_match('/^([0-9]{1,3}\.){3}[0-9]{1,3}$/', $_SERVER['HTTP_CLIENT_IP'])) { $ip = $_SERVER['HTTP_CLIENT_IP']; } elseif(isset($_SERVER['HTTP_X_FORWARDED_FOR']) AND preg_match_all('#\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}#s', $_SERVER['HTTP_X_FORWARDED_FOR'], $matches)) { foreach ($matches[0] AS $xip) { if (!preg_match('#^(10|172\.16|192\.168)\.#', $xip)) { $ip = $xip; break; } } } return $ip; }
 

좋은 웹페이지 즐겨찾기