在前文(Thrift的java和php數據交互http://my.oschina.net/penngo/blog/489311)中只介紹了java做服務器端,可是「php是最好的語言」,天然少了php開發的thrift服務器端。php
使用的業務例子,仍是之前文的登陸和註冊爲例java
服務器端由php代碼編寫,客戶端由php和java編寫。web
PhpMulServer.php (注意須要使用apache或其它web服務器來運行,因爲thrift自身沒有提供負載均衡,可考慮用LVS、HAProxy、 Nginx等等對HTTP請求作負載均衡處理)apache
<?php namespace com\penngo; error_reporting(E_ALL); require_once __DIR__.'/../lib/Thrift/ClassLoader/ThriftClassLoader.php'; use Thrift\ClassLoader\ThriftClassLoader; $GEN_DIR = realpath(dirname(__FILE__).'/..').'/gen-php'; $loader = new ThriftClassLoader(); $loader->registerNamespace('Thrift', __DIR__ . '/../lib'); $loader->registerDefinition('com', $GEN_DIR); $loader->register(); if (php_sapi_name() == 'cli') { ini_set("display_errors", "stderr"); } use Thrift\Protocol\TBinaryProtocol; use Thrift\Transport\TPhpStream; use Thrift\Transport\TBufferedTransport; use Thrift\TMultiplexedProcessor; use com\penngo\User; class RegisterServiceHandler implements \com\penngo\RegisterServiceIf { public function createUser($name, $psw){ $user = new User(); $user->id = 2; $user->name = $name; $user->password = $psw; return $user; } }; class LoginServiceHandler implements \com\penngo\LoginServiceIf { public function login($name, $psw){ $user = new User(); if($name == 'penngo' && $psw == '123'){ $user->id = 1; $user->name = 'penngo'; } return $user; } }; header('Content-Type', 'application/x-thrift'); if (php_sapi_name() == 'cli') { echo "\r\n"; } $transport = new TBufferedTransport(new TPhpStream(TPhpStream::MODE_R | TPhpStream::MODE_W)); $protocol = new TBinaryProtocol($transport, true, true); $tMultiplexedProcessor = new TMultiplexedProcessor(); $handler = new LoginServiceHandler(); $loginServiceProcessor = new LoginServiceProcessor($handler); $tMultiplexedProcessor->registerProcessor("LoginService", $loginServiceProcessor); $registerService = new RegisterServiceHandler(); $registerServiceProcessor = new RegisterServiceProcessor($registerService); $tMultiplexedProcessor->registerProcessor("RegisterService", $registerServiceProcessor); $transport->open(); $tMultiplexedProcessor->process($protocol, $protocol); $transport->close();
php客戶端調用api
PhpMulClient.php服務器
<?php namespace com\penngo; error_reporting(E_ALL); require_once __DIR__.'/../lib/Thrift/ClassLoader/ThriftClassLoader.php'; use Thrift\ClassLoader\ThriftClassLoader; $GEN_DIR = realpath(dirname(__FILE__).'/..').'/gen-php'; $loader = new ThriftClassLoader(); $loader->registerNamespace('Thrift', __DIR__ . '/../lib'); $loader->registerDefinition('com', $GEN_DIR); $loader->register(); use Thrift\Protocol\TBinaryProtocol; use Thrift\Protocol\TMultiplexedProtocol; use Thrift\Transport\THttpClient; use Thrift\Transport\TBufferedTransport; use Thrift\Exception\TException; try { $socket = new THttpClient('localhost', 80, '/thrift/penngo/PhpMulServer.php'); // $socket = new THttpClient('localhost', 8090, '/thrift/penngo/PhpMulServer.php'); $transport = new TBufferedTransport($socket); $protocol = new TBinaryProtocol($transport); $loginProtocol = new TMultiplexedProtocol($protocol, 'LoginService'); $loginService = new LoginServiceClient($loginProtocol); $user = $loginService->login('penngo', '123'); var_dump($user); $registerProtocol = new TMultiplexedProtocol($protocol, 'RegisterService'); $registerService = new RegisterServiceClient($registerProtocol); $user = $registerService->createUser('penngo', '123'); var_dump($user); // $transport->close(); } catch (TException $tx) { print 'TException: '.$tx->getMessage()."\n"; } ?>
java客戶端app
HttpClient.java負載均衡
package com.penngo.main; import org.apache.thrift.*; import org.apache.thrift.protocol.*; import org.apache.thrift.transport.*; import com.penngo.LoginService; import com.penngo.RegisterService; import com.penngo.User; public class HttpClient { public static void main(String[] args) { try { THttpClient transport = new THttpClient("http://localhost:80/thrift/penngo/PhpMulServer.php"); TProtocol protocol = new TBinaryProtocol(transport); TMultiplexedProtocol mp1 = new TMultiplexedProtocol(protocol, "LoginService"); LoginService.Client loginClient = new LoginService.Client(mp1); TMultiplexedProtocol mp2 = new TMultiplexedProtocol(protocol, "RegisterService"); RegisterService.Client registerClient = new RegisterService.Client( mp2); // transport.open(); User user = loginClient.login("penngo", "123"); if (user != null) { System.out.println("登陸成功:" + user.getId() + " " + user.getName()); } else { System.out.println("登陸失敗"); } User user2 = registerClient.createUser("test", "123"); if (user2 != null) { System.out.println("建立用戶成功:" + user2.getId() + " " + user2.getName()); } else { System.out.println("建立用戶失敗"); } // transport.close(); } catch (TException x) { x.printStackTrace(); } } }