Thrift 实现 JAVA,PHP,C#,Python 互相通信

Thrift介绍   https://www.ibm.com/developerworks/cn/java/j-lo-apachethrift/index.html

 首先需要下载 Thrift.exe 和Thrift的源码包,C# Thrift.dll  java Thrift jar包   

全部放在码云上面了 https://gitee.com/bandung/Allthrift.git

 

 

 定义一个thrift文件

namespace java com.penngo
namespace php com.penngo
namespace py com.penngo
struct User {             定义的是一个结构体,用于同一的放回结果
    1: i64 id,
    2: string name,
    3: string password
}
 
service LoginService{    定义服务,服务先可以有多个方法,方法返回值为上面定义的结果User
    User login(1:string name, 2:string psw);
} 

service FaceService{     方法的返回值为 string类型
    string getFace(1:string name, 2:string psw);
}
 
service RegisterService{
    User createUser(1:string name, 2:string psw);
}

 

生成Python 版本的代码

.\thrift-0.9.3.exe -gen  py .\test.thrift   //python
.\thrift-0.9.3.exe -gen  csharp.\test.thrift  //C#
.\thrift-0.9.3.exe -gen  java.\test.thrift    //java
.\thrift-0.9.3.exe -gen  php.\test.thrift   //php

 

 

就生成了这些代码

就简单举拿JAVA 做服务端,其他都是客户端的例子把,启动之后监听了8848端口,多线程模式的,单线程IO阻塞的在git 里面有

        try {
            TServerSocket serverTransport = new TServerSocket(8848);
            // 用户登录
            LoginService.Processor loginProcessor = new LoginService.Processor(
                    new LoginServiceImpl());
            //人脸识别
            FaceService.Processor faceProcessor=new FaceService.Processor(new FaceServiceImpl());
            // 用户注册
            RegisterService.Processor registerProcessor = new RegisterService.Processor(
                    new RegisterServiceImpl());
            
            
             
            TMultiplexedProcessor processor = new TMultiplexedProcessor();
            
            processor.registerProcessor("LoginService", loginProcessor);
            processor.registerProcessor("RegisterService", registerProcessor);
            processor.registerProcessor("FaceService", faceProcessor);
            TServer server = new TThreadPoolServer(new TThreadPoolServer.Args(
                    serverTransport).processor(processor));
            System.out.println("Starting server on port 8848 ...");
            server.serve();
        } catch (TTransportException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        }



public static void main(String args[]) {

Server srv = new Server();

srv.TMstart();
 
}
 

 

PHP客户端连接

 

<?php
namespace com\penngo;

require_once __DIR__.'/../../php/lib/Thrift/ClassLoader/ThriftClassLoader.php';        //按照自己的目录来,不能导入错了
//echo __DIR__.'/../../lib/Thrift/ClassLoader/ThriftClassLoader.php';
use Thrift\ClassLoader\ThriftClassLoader;

$GEN_DIR = realpath(dirname(__FILE__)).'/../../../gen-php';   //按照自己的目录来,不能导入错了



$loader = new ThriftClassLoader();
$loader->registerNamespace('Thrift', __DIR__ . '/../../php/lib');  //按照自己的目录来,不能导入错了,注册命名空间
//$loader->registerDefinition('shared', $GEN_DIR);
$loader->registerDefinition('com', $GEN_DIR);
$loader->register();

if (php_sapi_name() == 'cli') {
    ini_set("display_errors", "stderr");
}

use Thrift\Protocol\TBinaryProtocol;
use Thrift\Protocol\TMultiplexedProtocol;
use Thrift\Transport\TSocket;
use Thrift\Transport\THttpClient;
use Thrift\Transport\TBufferedTransport;
use Thrift\Exception\TException;
use com\penngo\RegisterServiceClient;
use com\penngo\LoginServiceClient;

try {

    $socket = new TSocket('127.0.0.1', 8848);
    $socket->setSendTimeout(100000);   //设置超时时间
    $socket->setRecvTimeout(100000);

    $transport = new TBufferedTransport($socket, 1024, 1024);
    $protocol = new TBinaryProtocol($transport);
//    $loginProtocol = new TMultiplexedProtocol($protocol, "LoginService");
    $faceProtocol = new TMultiplexedProtocol($protocol, "FaceService");
    // $registerProtocol = new TMultiplexedProtocol($protocol, "RegisterService");
    $faceClient = new FaceServiceClient($faceProtocol);
    // $registerClient = new RegisterServiceClient($registerProtocol);
    $transport->open();

    $faceinfo = $faceClient->getFace("123","asdasd");

    print_r($faceinfo);

    $transport->close();
} catch (TException $tx) {
    print 'TException: '.$tx->getMessage()."\n";
    print 'TException: '.$tx->getTraceAsString()."\n";
}

 

Python 客户端

安装Python 插件

pip install thrift

 

# -*- coding:utf-8 -*-  
import sys
sys.path.append('..')

from thrift.TMultiplexedProcessor import TMultiplexedProcessor
from thrift.protocol.TMultiplexedProtocol import TMultiplexedProtocol
from thrift.transport import TSocket
from thrift.transport import TTransport
from thrift.protocol import TBinaryProtocol
from thrift.server import TServer
#根据实际的包结构去引入
import FaceService



    

def client():
    transport = TSocket.TSocket(host='localhost', port=8848) 
    transport = TTransport.TBufferedTransport(transport) 
    protocol = TBinaryProtocol.TBinaryProtocol(transport) 
    face_protocol = TMultiplexedProtocol(protocol, "FaceService") #如果服务端使用TMultiplexedProcessor接收处理,客户端必须用TMultiplexedProtocol并且指定serviceName和服务端的一致 
        
    face_client = FaceService.Client(face_protocol)#msg客户端 
        
    transport.open() 
    
    print face_client.getFace("123","啊实打实多")
        
    transport.close()


 
if __name__ == '__main__':
    client()
    

 

C# 客户端

https://gitee.com/bandung/Allthrift/raw/master/gen-csharp/gen-csharp/bin/Debug/Thrift.dll

dll 下载,然后引用

using Thrift.Protocol;
using Thrift.Server;
using Thrift.Transport;

public void TMclient() { TSocket transport = new TSocket("127.0.0.1",8848); TBinaryProtocol protocol = new TBinaryProtocol(transport); TMultiplexedProtocol tprocessor = new TMultiplexedProtocol(protocol, "FaceService"); FaceService.Client faceclient = new FaceService.Client(tprocessor); transport.Open(); String info=faceclient.getFace("PHP","JAVA"); Console.WriteLine(info); transport.Close(); }

 

结束

 

 

 

 

 

 

!!

posted @ 2019-01-30 17:34  万隆  阅读(614)  评论(0编辑  收藏  举报