• 基于php socket(fsockopen)的应用实例分析


    fsockopen函数能够运用,首先要开启php.ini中的allow_url_open=on;
    fsockopen是对socket客户端代码的封装,该函数中封装了socket_create,socket_connect。
    服务器端代码:server.php

    . 代码如下:

    <?php
    error_reporting(E_ALL);
    set_time_limit(0);
    $address = '127.0.0.1';
    $port = 10008;
    //创建端口
    if (($sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) === false) {
    echo "socket_create() failed:reason:" . socket_strerror(socket_last_error()) . " ";
    }
    //绑定
    if (socket_bind($sock, $address, $port) === false) {
    echo "socket_bind() failed :reason:" . socket_strerror(socket_last_error($sock)) . " ";
    }
    //监听
    if (socket_listen($sock, 5) === false) {
    echo "socket_bind() failed :reason:" . socket_strerror(socket_last_error($sock)) . " ";
    }
    while (true) {
    //得到一个链接
    if (($msgsock = socket_accept($sock)) === false) {
    echo "socket_accepty() failed :reason:".socket_strerror(socket_last_error($sock)) . " ";
    break;
    }
    //welcome 发送到客户端
    $msg = "1.<font color='red'>server send:welcome</font><br/>";
    socket_write($msgsock, $msg, strlen($msg)); //返回信息给客户端
    echo 'read client message ';
    $buf = socket_read($msgsock, 8192); //获取客户端发送过来的信息
    $talkback = "2.received message:$buf ";
    echo $talkback;
    if (false === socket_write($msgsock, $talkback, strlen($talkback))) { //返回信息给客户端
    echo "socket_write() failed reason:" . socket_strerror(socket_last_error($sock)) ." ";
    } else {
    echo 'send success';
    }
    socket_close($msgsock);
    }
    socket_close($sock);


    客户端代码:fsocket.php

    . 代码如下:


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

  • 相关阅读:
    Flink--Table和DataStream和DataSet的集成
    flink-SQL
    Flink的容错
    Flink--基于mysql的sink和source
    Flink--sink到kafka
    Flink在流处理上常见的Source和sink操作
    【计算机网络】-传输层-传输服务的要素
    【计算机网络】-传输层-传输服务
    文件系统-文件的逻辑结构与存取方法
    文件系统-概念
  • 原文地址:https://www.cnblogs.com/lemon66/p/4102735.html
Copyright © 2020-2023  润新知