跨平台

Rpc的请求响应通过tcp协议,服务广播使用udp协议,我们只需要实现网络协议即可

PHP示例代码

<?php
/**
 * Created by PhpStorm.
 * User: xcg
 * Date: 2019/2/27
 * Time: 16:02
 */
/**
 * 原生php调用
 */
$data = [
    'action' => 'call1',//行为名称
    'arg' => [
        'args1' => 'args1',
        'args2' => 'args2'
    ]
];

$raw = serialize($data);//注意序列化类型,需要和RPC服务端约定好协议 $serializeType

$fp = stream_socket_client('tcp://127.0.0.1:9527');
fwrite($fp, pack('N', strlen($raw)) . $raw);//pack数据校验

$data = fread($fp, 65533);
//做长度头部校验
$len = unpack('N', $data);
$data = substr($data, '4');
if (strlen($data) != $len[1]) {
    echo 'data error';
} else {
    $data = unserialize($data);
//    //这就是服务端返回的结果,
    var_dump($data);//默认将返回一个response对象 通过$serializeType修改
}
fclose($fp);

其他语言只需要实现tcp协议即可

results matching ""

    No results matching ""