欧美日韩精品在线,国内精品久久久久久久久,一级毛片恃级毛片直播,清纯唯美亚洲综合欧美色

基于php socket(fsockopen)的應用實例分析_PHP教程

編輯Tag賺U幣

推薦:獲取用戶Ip地址通用方法與常見安全隱患(HTTP_X_FORWARDED_FOR)
這個來自一些項目中,獲取用戶Ip,進行用戶操作行為的記錄,是常見并且經常使用的。 一般朋友,都會看到如下通用獲取IP地址方法

fsockopen函數能夠運用,首先要開啟php.ini中的allow_url_open=on;
fsockopen是對socket客戶端代碼的封裝,該函數中封裝了socket_create,socket_connect。
服務器端代碼:server.php
復制代碼 代碼如下:m.dounai2.com

<?php
error_reporting(E_ALL);
set_time_limit(0);
$address = '127.0.0.1';
$port = 10008;
//創(chuàng)建端口
if (($sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) === false) {
echo "socket_create() failed:reason:" . socket_strerror(socket_last_error()) . "\n";
}
//綁定
if (socket_bind($sock, $address, $port) === false) {
echo "socket_bind() failed :reason:" . socket_strerror(socket_last_error($sock)) . "\n";
}
//監(jiān)聽
if (socket_listen($sock, 5) === false) {
echo "socket_bind() failed :reason:" . socket_strerror(socket_last_error($sock)) . "\n";
}
while (true) {
//得到一個鏈接
if (($msgsock = socket_accept($sock)) === false) {
echo "socket_accepty() failed :reason:".socket_strerror(socket_last_error($sock)) . "\n";
break;
}
//welcome 發(fā)送到客戶端
$msg = "1.<font color='red'>server send:welcome</font><br/>";
socket_write($msgsock, $msg, strlen($msg)); //返回信息給客戶端
echo 'read client message\n';
$buf = socket_read($msgsock, 8192); //獲取客戶端發(fā)送過來的信息
$talkback = "2.received message:$buf\n";
echo $talkback;
if (false === socket_write($msgsock, $talkback, strlen($talkback))) { //返回信息給客戶端
echo "socket_write() failed reason:" . socket_strerror(socket_last_error($sock)) ."\n";
} else {
echo 'send success';
}
socket_close($msgsock);
}
socket_close($sock);

客戶端代碼:fsocket.php
復制代碼 代碼如下:m.dounai2.com

<?php
$fp = fsockopen("127.0.0.1", 10008, &$errno, &$errstr, 10);
if (!$fp) {
echo $errstr . " (". $errno . ")<br>n";
} else {
$in = "HEAD / http/1.1\r\n";
$in .= "HOST: localhost \r\n";
$in .= "Connection: close\r\n\r\n";
fputs($fp, $in);
while (!feof($fp)) {
echo fgets($fp, 128);
}
fclose($fp);
}

分享:web站點獲取用戶IP的安全方法 HTTP_X_FORWARDED_FOR檢驗
通過上一篇,獲取用戶Ip地址通用方法常見安全隱患(HTTP_X_FORWARDED_FOR) ,我們已經意 識到直接從http_x_forwarded_for中讀取用戶IP,跟我們直接從一個get,post值中讀取其實沒有兩樣。web參數檢測里面一個基本原則:“一切輸入都是有害的”,因此,只要是輸入我們就需

來源:模板無憂//所屬分類:PHP教程/更新時間:2013-06-03
相關PHP教程