一、java实例

1.下载与安装thrift工具

http://thrift.apache.org/download/

、服务器代码

服务Test实现类

package com.zychen.thrift;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import org.apache.thrift.TException;

public class TestImpl implements Test.Iface {

	public void Init(){
		int n = 0;
		for(n=0; n<10; n++){
			User user = new User();
			user.setId(n+1);
			user.setName(String.format("name_%d", n+1));
			user.setAge(18+n+1);
			user.setVip(true);
			listUser.add(user);
		}
	}

	@Override
	public int add(int a, int b) throws TException {
		return a+b;
	}

	@Override
	public User getById(long id) throws TException {
		User userObj = null;
		Iterator<User> iter = listUser.iterator();
		while(iter.hasNext()){
			userObj = iter.next();
			if(userObj.getId() == id){
				return userObj;
			}
		}

		return null;
	}

	//插入用户信息
	void InsertUser(User user){
		listUser.add(user);
	}

	protected List<User> listUser = new ArrayList<User>();
}

//服务端代码

package com.zychen.test;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TBinaryProtocol.Factory;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.server.TNonblockingServer;
import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TThreadPoolServer;
import org.apache.thrift.server.TThreadPoolServer.Args;
import org.apache.thrift.transport.TFramedTransport;
import org.apache.thrift.transport.TNonblockingServerSocket;
import org.apache.thrift.transport.TServerSocket;
import org.apache.thrift.transport.TTransportException;

import com.zychen.thrift.Test;
import com.zychen.thrift.Test.Processor;
import com.zychen.thrift.TestImpl;

public class Server {
	//阻塞式IO
	public void startOIOServer() {
        try {
            TServerSocket serverTransport = new TServerSocket(1234);
            TestImpl testImpl = new TestImpl();
            testImpl.Init();
            Test.Processor process = new Processor(testImpl);
            Factory portFactory = new TBinaryProtocol.Factory(true, true);
            Args args = new Args(serverTransport);
            args.processor(process);
            args.protocolFactory(portFactory);
            TServer server = new TThreadPoolServer(args);
            System.out.println("init...");
            server.serve();
        } catch (TTransportException e) {
            e.printStackTrace();
        }
    }

	//使用非阻塞式IO,服务端和客户端需要指定TFramedTransport数据传输的方式。
	public void startNIOServer() {
        try {
            TestImpl testImpl = new TestImpl();
            testImpl.Init();
            Test.Processor tprocessor = new Processor(testImpl);
            TNonblockingServerSocket tnbServerTransport = new TNonblockingServerSocket(1234);
            TNonblockingServer.Args tArgs = new TNonblockingServer.Args(tnbServerTransport);
            tArgs.processor(tprocessor);
            tArgs.transportFactory(new TFramedTransport.Factory());
            tArgs.protocolFactory(new TCompactProtocol.Factory());
            TServer server = new TNonblockingServer(tArgs);
            System.out.println("init...");
            server.serve();
        }catch(TTransportException e) {
        	e.printStackTrace();
        }
    }

	/**
	 * @param args
	 */
	public static void main(String[] args) {
	     Server server = new Server();
	     //server.startOIOServer();
	     server.startNIOServer();
	}

}

依赖jar包

5、客户端代码

package com.zychen.test;

import org.apache.thrift.TApplicationException;
import org.apache.thrift.TException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TCompactProtocol;
import org.apache.thrift.protocol.TProtocol;
import org.apache.thrift.transport.TFramedTransport;
import org.apache.thrift.transport.TSocket;
import org.apache.thrift.transport.TTransport;
import org.apache.thrift.transport.TTransportException;

import com.zychen.thrift.Test;
import com.zychen.thrift.User;

public class Client {

	 //阻塞io
	 public void startOIOClient() {
	        TTransport transport;
	        try {
	            transport = new TSocket("localhost", 1234);
	            TProtocol protocol = new TBinaryProtocol(transport);
	            Test.Client client = new Test.Client(protocol);
	            transport.open();
	            int nResult = client.add(100, 200);
	            String strTemp = String.format("client.add(100, 200) = %d", nResult);
	            System.out.println(strTemp);
	            User u1 = client.getById(1);
	            if(u1 != null){
	            	System.out.println(u1.getName());
	            }
	            User u2 = client.getById(11);
	            if(u2 == null){
	            	System.out.println("null");
	            }
	            u2 = client.getById(9);
	            transport.close();
	        } catch (TTransportException e) {
	            e.printStackTrace();
	        } catch (TException e) {
	        	if(e instanceof TApplicationException && ((TApplicationException) e).getType() == TApplicationException.MISSING_RESULT){
	        		System.out.println("Theresult of Method function is NULL");
	        	}else{
		            e.printStackTrace();
	        	}
	        }
	    }

	 //非阻塞io
	 public void startNIOClient() {
	        TTransport transport;
	        try {
	            transport = new TFramedTransport(new TSocket("localhost", 1234,30000));
	            TProtocol protocol = new TCompactProtocol(transport);
	            Test.Client client = new Test.Client(protocol);
	            transport.open();
	            int nResult = client.add(100, 200);
	            String strTemp = String.format("client.add(100, 200) = %d", nResult);
	            System.out.println(strTemp);
	            User u1 = client.getById(1);
	            if(u1 != null){
	            	System.out.println(u1.getName());
	            }
	            User u2 = client.getById(11);
	            if(u2 == null){
	            	System.out.println("null");
	            }
	            u2 = client.getById(9);
	            transport.close();
	        } catch (TTransportException e) {
	            e.printStackTrace();
	        } catch (TException e) {
	        	if(e instanceof TApplicationException && ((TApplicationException) e).getType() == TApplicationException.MISSING_RESULT){
	        		System.out.println("Theresult of Method function is NULL");
	        	}else{
		            e.printStackTrace();
	        	}
	        }
	    }

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
        Client client = new Client();
        //client.startOIOClient();
        client.startNIOClient();
	}

}

依赖jar包

二、Thrift-0.9.3 jar包编译生成。

1、myeclipse新建一个java工程。

2、打开thrift目录,查找到thrift-0.9.3\thrift-0.9.3\lib\java\src,将这个src目录下的代码拷贝到工程目录下。

3、引入httpClient、httpcore、javax.servlet、slf4j.api jar包。如图:

4、编译,导出thrift-0.9.3jar包,导出时选择Exportall output folders for checked projects,否则scheme类无法导出到jar包中。

Thrift之java实例的更多相关文章

  1. Thrift-java实例

    ➠更多技术干货请戳:听云博客 Thrift实例1 功能描述:客户端与服务器端分别是两个应用,先启动服务器端,再启动客户端,实现执行客户端运行服务器端的加法方法. 源码截图(源码在附件中): 客户端: ...

  2. Thrift入门及Java实例演示<转载备用>

    Thrift入门及Java实例演示 作者: Michael 日期: 年 月 日 •概述 •下载配置 •基本概念 .数据类型 .服务端编码基本步骤 .客户端编码基本步骤 .数据传输协议 •实例演示(ja ...

  3. Apache Thrift学习之一(入门及Java实例演示)

    目录: 概述 下载配置 基本概念 数据类型 服务端编码基本步骤 客户端编码基本步骤 数据传输协议 实例演示(java) thrift生成代码 实现接口Iface TSimpleServer服务模型 T ...

  4. Apache Thrift with Java Quickstart(thrift入门及Java实例)

    thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ruby, Erlang, Perl ...

  5. Protocol Buffer技术详解(Java实例)

    Protocol Buffer技术详解(Java实例) 该篇Blog和上一篇(C++实例)基本相同,只是面向于我们团队中的Java工程师,毕竟我们项目的前端部分是基于Android开发的,而且我们研发 ...

  6. 吐槽net下没有靠谱的FastDFS的sdk之使用thrift实现JAVA和C#互通

    事情是这样的,在一个新项目中引入了fastdfs,用这玩意做一些小数据的存储还是很方便的,然后在nuget上就找一个对接FastDFS的sdk,如下图: 一眼就看到了这个top1的sdk,应该会比较靠 ...

  7. JAVA实例

     JAVA实例1  1 package Demo3; import java.io.File; import java.io.FileReader; import java.io.IOExceptio ...

  8. Java 实例 - 如何执行指定class文件目录(classpath) Java 实例 J

    Java 实例 - 如何执行指定class文件目录(classpath)  Java 实例 如果我们 Java 编译后的class文件不在当前目录,我们可以使用 -classpath 来指定class ...

  9. Java-Runoob-高级教程-实例-方法:15. Java 实例 – 重载(overloading)方法中使用 Varargs

    ylbtech-Java-Runoob-高级教程-实例-方法:15. Java 实例 – 重载(overloading)方法中使用 Varargs 1.返回顶部 1. Java 实例 - 重载(ove ...

随机推荐

  1. 格式化字符串--format用法

    print("hello {leon}".format(leon="world!")) #format 是一个格式化字符穿的方法. print("he ...

  2. Linux系统启动管理 系统启动流程

    概述 linux启动时我们会看到许多启动信息,其过程可以分为5个阶段: BIOS自检 读取MBR 通过Boot Loader引导系统加载 加载initramfe虚拟文件系统 加载内核 运行system ...

  3. 使用Vue.js初次真正项目开发-2018/07/14

    一.组件化 使用Vue.js进行开发,按照MVVM模式,围绕数据为核心,进行开发. 开发过程根据业务和功能组件化,组件化一方面让我们开发思路更加清晰,另一方面对于数据的处理和控制变得更加简单,毕竟一个 ...

  4. [Usaco2008 Open]Word Power 名字的能量

    1622: [Usaco2008 Open]Word Power 名字的能量 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 408  Solved: 19 ...

  5. Metasploit – 内网连接

    0x00 问题描述 在渗透测试时,metasploit往往作为后渗透工具,(因为远程溢出越来越少).我一般都是在获得一个webshell后,来使用metasploit进行信息采集,或者内网扫描等操作. ...

  6. SSD: Single Shot MultiBox Detector 编译方法总结

    SSD是一个基于单网络的目标检测框架,它是基于caffe实现的,所以下面的教程是基于已经编译好的caffe进行编译的. caffe的编译可以参考官网 caffe Installation Instal ...

  7. 数组排序array_multisort

    array_multisort --对多个数组或者多维数组进行排序[参考:secure.php.net] 说明: bool array_multisort ( array &$array1 [ ...

  8. 分布式技术 webapi 路由追加html、aspx、shtml 适用于 对接 安卓、IOS

    首先是这样,在对接安卓和IOS或者是第三方调用的接口,我需要在服务端返回一个带.html/.aspx这样后缀的接口. 例子如下图:http://localhost:64131/api/UsersInf ...

  9. Android -- UI布局管理,相对布局,线性布局,表格布局,绝对布局,帧布局

    1. 相对布局 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmln ...

  10. Spring -- spring 中使用jdbc, c3p0连接池, dao概念

    1. 示例代码 CustomerDao.java  ,dao接口 public interface CustomerDao { public void insertCustomer(Customer ...