Пример #1 Пример сервера Yar
<?php
/* Предположим, что это страница может быть доступна по http://example.com/operator.php */
class Operator {
/**
* Складываем два операнда
* @param interge
* @return interge
*/
public function add($a, $b) {
return $this->_add($a, $b);
}
/**
* Вычитаем
*/
public function sub($a, $b) {
return $a - $b;
}
/**
* Умножаем
*/
public function mul($a, $b) {
return $a * $b;
}
/**
* Защищенный метод
* @param interge
* @return interge
*/
protected function _add($a, $b) {
return $a + $b;
}
}
$server = new Yar_Server(new Operator());
$server->handle();
?>
Пример #2 Обращаемся к серверу из браузера (запрос GET)
Результатом выполнения данного примера будет что-то подобное:
Пример #3 Пример клиента Yar
<?php
$client = new yar_client("http://example.com/operator.php");
/* вызываем напрямую */
var_dump($client->add(1, 2));
/* вызываем через метод call */
var_dump($client->call("add", array(3, 2)));
/* невозможно вызвать __add */
var_dump($client->_add(1, 2));
?>
Результатом выполнения данного примера будет что-то подобное:
int(3) int(5) PHP Fatal error: Uncaught exception 'Yar_Server_Exception' with message 'call to api Operator::_add() failed' in *
Пример #4 Пример конкурирующих клиентов Yar
<?php
function callback($ret, $callinfo) {
echo $callinfo['method'] , " result: ", $ret , "\n";
}
/* регистрируем асинхронные вызовы к удаленным сервисам */
Yar_Concurrent_Client::call("http://example.com/operator.php", "add", array(1, 2), "callback");
Yar_Concurrent_Client::call("http://example.com/operator.php", "sub", array(2, 1), "callback");
Yar_Concurrent_Client::call("http://example.com/operator.php", "mul", array(2, 2), "callback");
/* посылаем все запросы и ждем ответа */
Yar_Concurrent_Client::loop();
?>
Результатом выполнения данного примера будет что-то подобное:
mul result: 4 sub result: 1 add result: 3