「javarpc接口开发」grpc Java
本篇文章给大家谈谈javarpc接口开发,以及grpc Java对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、java rpc框架哪个好 知乎
- 2、如何实现一个简单的RPC框
- 3、Java开发中消息队列和rpc框架都是做什么的?
- 4、关于java
- 5、作为一个JAVA程序员, 应该掌握哪些知识, 目前, 比较流行的java开发框架有哪些,
- 6、java protobuf 定义rpc服务怎么调用
java rpc框架哪个好 知乎
Thrift 是由 Facebook 开源的一个 RPC 框架,现在已经挂在 apache.org 下了。主要的几个好处:
1. 支持非常多语言,包括在 WEB 开发中很常用的 PHP,以及最重要的 C++/Python/Java 等 WEB后端常用语言,当然,还包括很 cool 的 Ruby、Erlang。
2. 完整的 RPC 框架实现,用脚本生成通讯相关的框架代码,开发者只需要集中精力处理好 业务逻辑。比如搭建一个 Hello World Service 只需要几分钟。
3.拥有被 Facebook、Last.fm 等不少大规模互联网应用验证过的性能和可用性。
Hessian是一款基于HTTP协议的RPC框架,采用的是二进制RPC协议,非常轻量级 ,且速度较快。
当然,还有Hetty,它是一款构建于Netty和Hessian基础上的高性能的RPC框架。
如何实现一个简单的RPC框
0,服务接口定义---Echo.java
/*
* 定义了服务器提供的服务类型 */public interface Echo { public String echo(String string);
}
一,客户端代码分析--实现类:MainClient.java
客户端实现包括:获得一个代理对象,并使用该代理对象调用服务器的服务。获取代理对象时,需要指定被代理的类(相当于服务器端提供的服务名),Server IP,Port,这样客户端就能找到服务端的服务了。
延伸:分布式环境下,Client如何打到Server的服务?---因为,在服务器中运行的某些服务不像标准服务有着固定的端口,如HTTP的80端口。
一种解决方法是:在运行服务的每台机器上都运行一个特殊的守护进程,该守护进程负责跟踪位于该机器中每一项服务所使用的端口;此外,守护进程还监听一个特定的已经端口,Client通过这个端口与守护进程联系,请求得到指定服务的端口。
复杂的RPC实现框架中,比如可以把服务注册到ZooKeeper中,Client也从ZooKeeper中查询服务。参考:一个更复杂的RPC框架实现
Echo echo = RPC.getProxy(Echo.class, "127.0.0.1", 20382);
System.out.println(echo.echo("hello,hello"));//使用代理对象调用服务器的服务.并将结果输出
二,服务器端分析--实现类:MainServer.java
服务器实现包括:创建一个服务器对象,将它能提供的服务注册,并启动进程监听客户端的连接
Server server = new RPC.RPCServer(); /*
* server 启动后,需要注册server端能够提供的服务,这样client使用 服务的名字、
* 服务器的IP、以及服务所运行的端口 来调用 server 的服务 */
server.register(Echo.class, RemoteEcho.class);//注册服务的名字
server.register(AnOtherEchoService.class, AnOtherEchoServiceImpl.class);
server.start();//启动server
三,服务器监听Client连接分析----实现类:Listener.java
当server.start()后,它要创建一个Listener对象,这是一个线程类,该线程用来监听Client连接。
public void start() {
System.out.println("启动服务器");
/*
* server 启动时,需要Listener监听是否有client的请求连接
* listener 是一个线程,由它来监听连接 */
listener = new Listener(this); this.isRuning = true;
listener.start();//listener 是一个线程类,start()后会执行线程的run方法
}
其实,监听连接就是JAVA ServerSocket类和Socket类提供的相关功能而已。
/*
* accept()是一个阻塞方法,server_socket 一直等待client 是否有连接到来 */
Socket client = server_socket.accept();//建立一条TCP连接
四,动态代理对象 生成---RPC.java
客户端只需要编写生成代理对象,用代理对象去调用远程服务的代码即可。但是,底层的功能如:建立连接,序列化(本例中也没有考虑),跨语言调用(未考虑)...是由RPC框架完成的。
当MainClient 语句:RPC.getProxy(Echo.class, "127.0.0.1", 20382);执行时,会由
/*
* @param Class[]{} 该参数声明了动态生成的代理对象实现了的接口,即 clazz 所代表的接口类型 .
* 这表明了生成的代理对象它是一个它所实现了的接口类型的对象
* 从而就可以用它来调用它所实现的接口中定义的方法
*
* @param handler 生成代理实例对象时需要传递一个handler参数
* 这样当该 代理实例对象调用接口中定义的方法时,将会委托给InvocationHandler 接口中声明的invoke方法
* 此时,InvocationHandler 的invoke 方法将会被自动调用 */
T t = (T) Proxy.newProxyInstance(RPC.class.getClassLoader(), new Class[] {clazz}, handler); return t;
返回该代理对象,然后就会委托第三个参数 handler 自动执行 invoke(),invoke将客户端调用的所有相关信息封装到Invocation 对象中(后面分析)。然后执行第16行代码发起连接。
1 public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { 2 Invocation invo = new Invocation(); 3 invo.setInterfaces(clazz); 4 5 //利用反射机制将java.lang.reflect.Method 所代表的方法名,参数 封装到 Invocation invo对象中 6 invo.setMethod(new org.jy.rpc.protocal.Method(method.getName(),method.getParameterTypes())); 7 invo.setParams(args); 8 9 /*10 * 当把需要调用的远程server端的方法名和参数封装到invo之后,Client 对象 就可以把 invo 作为参数 传递给服务器了.11 * 为什么需要这样做呢?InvocationHandler 的invoke方法是自动执行的,在该方法里面,它根据生成的代理对象 proxy (第一个参数)12 * 所实现的接口(由 Proxy.newProxyInstance()的第二个参数指定) 就可以知道这个接口中定义了哪些方法13 * InvocationHandler 的 invoke 方法的第二个参数Method method 就可以解析出接口中的方法名和参数了14 * 把它们封装进Invocation invo对象中,再将 invo 作为 client.invoke(invo)的参数 发送到服务器方15 */16 client.invoke(invo);//invoke 先调用init发起一个Socket连接,再将invo 发送至输出流中17 return invo.getResult();18 }
五,“客户端存根”--Client.java
最重要的是它的 invoke方法(注意与InvocationHandler的invoke()区分)。它负责建立连接,打开输入、输出流,向服务器发送字节数据。
1 public void invoke(Invocation invo) throws UnknownHostException, IOException, ClassNotFoundException {2 init();3 System.out.println("写入数据");4 oos.writeObject(invo);//将Client 需要调用的Server的 接口、方法、参数 封装起来 发给服务器5 oos.flush();6 ois = new ObjectInputStream(socket.getInputStream());//用来接收从 server 返回 回来的执行结果 的输入流7 Invocation result = (Invocation) ois.readObject();8 invo.setResult(result.getResult());//将结果 保存到 Invocation result对象中9 }
六,“服务器存根“---实现类:RPCServer.java
上面提到,服务器通过Listener监听客户端连接,当建立客户端连接后,Socket client = server_socket.accept(); 不再阻塞,服务器调用它的call()方法完成客户端请求的功能。也即,客户端请求的结果实际上是在服务器执行生成的。返回的结果是在Client.java 的 invoke() 方法里被读取出来 。call()再一次用到了JAVA反射(第11行) 参考:JAVA动态代理
1 public void call(Invocation invo) { 2 System.out.println(invo.getClass().getName()); 3 Object obj = serviceEngine.get(invo.getInterfaces().getName()); 4 if(obj!=null) { 5 try { 6 Method m = obj.getClass().getMethod(invo.getMethod().getMethodName(), invo.getMethod().getParams()); 7 /* 8 * 利用JAVA反射机制来执行java.lang.reflect.Method 所代表的方法 9 * @param result : 执行实际方法后 得到的 服务的执行结果10 */11 Object result = m.invoke(obj, invo.getParams());12 invo.setResult(result);//将服务的执行结果封装到invo对象中。在后面的代码中,将该对象写入到输出流中13 } catch (Throwable th) {14 th.printStackTrace();15 }16 } else {17 throw new IllegalArgumentException("has no these class");18 }19 }
七,”RPC 编码、解码,协议的定义“---Invocation.java Method.java
其实,这里并不是那种实用的开源RPC框架如Thrift中所指的编码、IDL……上面两个类只是RPC实现过程中辅助完成Java动态代理的实现,说白了就是封装客户端需要调用的方法,然后指定生成的代理对象需要实现的接口(服务).
八,总结:
先运行MainServer.java启动服务器,然后,再运行MainClient.java 启动一个客户端连接服务器就可以看到执行结果。
当需要添加新的服务时:按以下步骤即可:①定义服务接口及其实现类,如:AnOtherEchoService.java ②:在MainServer.java中注册新添加的服务。
③:在MainClient.java中编写获得新服务的代理对象的代码,并用该代理对象调用新服务接口中声明的方法。
这样,在客户端就能够远程地调用服务器上的一个新服务了。
Java开发中消息队列和rpc框架都是做什么的?
一,消息队列服务一般用于设计多系统之间的信息传输,一般这种传输不需要对方对数据做出回应。它最常见的方式是构建异步的生产者-消费者模式。我们在系统开发中,有些业务并不需要及时返回结果,我们可以把这些操作放到队列中,然后另起一个消费者去处理它。比如日志,数据库异步更新。
二,rpc一般是用于服务器与服务器进程之间通信,这种通信有请求和应答。它是建立在底层的socket通信之上的。封装为rpc之后,更加方便建立通信。就像在同一个进程中调用对方的方法一样。它本地的方法名一般和请求到达的服务器的方法名一一对应。这样可以更好的把模块划分。所以它是应对分布式而生的。比如一个网站,一开始可能所有的服务在一个进程中,但是随着业务的增长,一个进程处理不过来,这时就需要把业务拆分成多个,分部到不同的机器上去。
关于java
Java的Sun Microsystems的Java编程语言介绍了1995年5月(以下简称为Java语言)和Java平台的总称的。 HotJava浏览器(Java实现支持Java小程序)Java的魅力:跨平台,动态的Web,Internet计算。从那时起,Java被广泛接受和推广网络的快速发展,常用的浏览器现在支持Java applets。另一方面,Java技术是不断更新的。
Java平台的Java虚拟机(Java虚拟机)和Java应用程序编程接口(应用程序编程接口,或API)构成。独立的操作系统提供一个标准接口,可分为用于Java应用程序的Java应用程序编程接口的基本部分和扩展。 Java应用程序可以运行在Java平台上安装的硬件或操作系统平台。现在Java平台已经嵌入在几乎所有的操作系统。因此,Java程序可以只编译一次,并可以运行在不同的系统。 Java应用编程接口已经发展从1.1倍版本到1.2版本。 Java平台基于Java1.4,最近版本为Java1.7。
Java是分为三个系统JavaSE中(Java2平台标准版(32位x86)的Java平台,标准版),JavaEE服务器(Java 2平台企业版Java平台,企业版),和JavaME(Java 2平台Micro版平台的Java微型版)。
2009年的甲骨文(Oracle)宣布收购的太阳。
[编辑本段] JAVA的名字起源
一天,几个Java组的成员正在讨论如何命名这个新的语言,他们是爪哇(Java)的咖啡馆喝着咖啡,称为Java这项建议已得到别人的想法,Java名称的传播。没有去看看原来的Sun Java徽标认为,现在看,这不就是一杯热气腾腾的咖啡吗?
[编辑本段] Java语言特性
Java是一个简单的,面向对象的,分布式的,解释了安全,可靠的结构中立的,可移植的,高性能的多线程的动态语言。
当SUN的Java语言于1995年推出后,眼中的世界是神奇的语言吸引。 Java中到底有什么神奇的?
Java语言其实出生于1991年,最初称为OAK语言,SUN公司为一些消费性电子产品和通用设计环境。他们最初的目的只是为了开发一种独立于平台的软件技术,可以说是未知的,它几乎夭折,并在网络出现之前,OAK。然而,互联网的出现改变了OAK的命运。
的Java来临之前,在互联网上的信息内容都是一些无聊的刚性HTML文件。这是针对那些痴迷的WEB浏览器的人简直是无法忍受的。他们迫切希望看到的网络互动内容开发创建一个类,不需要考虑硬件和软件平台,可以执行应用程序的WEB是非常可取的,当然,这些程序也有一个很大的安全。对于用户来说,这样的要求,传统的编程语言是无能为力的。 SUN的工程师敏锐地认识到,从1994年起,他们开始OAK在WEB和HotJava的第一个版本所采用的技术。 SUN 1995年正式推出的Java的名义,几乎所有的Web开发人员心中感叹:哦,这正是我想要的!因此,Java已经成为一颗耀眼的明星,丑小鸭变成白天鹅的整个事情。
[编辑本段] Java的主要特点
Java语言是简单的。 Java语言的语法与C语言和C + +语言很接近大多数程序员很容易学习和使用Java。另一方面,Java已经丢弃了C + +中很少使用,这是很难理解的,令人困惑的功能,比如操作符重载,多继承,自动投。特别是,Java语言不使用指针,并提供了自动的废料收集,这样程序员就不必担心内存管理。
2,Java语言是一种面向对象的。 Java语言的类,接口和继承原语,为了简单起见,只支持类之间的单继承,但支持接口之间的多重继承,并支持实施机制之间的类和接口(关键字实现)。 Java语言全面支持动态绑定,而C + +虚函数使用动态绑定。总之,Java语言是一种纯粹的面向对象编程语言。
3,Java语言是分布式的。 Java语言支持开发互联网应用,在基本的Java应用程序编程接口,它提供了网络应用编程的类库,包括URL,URL连接,套接字,ServerSocket的网络应用程序编程接口(java.net)。 Java的RMI(远程方法激活)机制是开发分布式应用程序的重要手段。
4,Java语言是健壮的。 Java的强类型,异常处理,自动垃圾收集的Java程序健壮性的重要保证。指针下降的Java明智的选择。 Java的安全检查机制使得Java更强的鲁棒性。
5,Java语言是安全的。 Java是经常被用来在网络环境中,Java提供了一个安全机制,以防止恶意代码的攻击。除了许多Java语言的安全功能,通过网络下载Java类的安全机制(类加载器)分配一个不同的名称空间,以防止其他本地类相同的名称,字节代码检查,并提供安全管理机制(类SecurityManager的)允许Java应用程序设置安全哨兵。
6,Java语言是体系结构中立的。 Java程序(后缀为java文件)被编译Java平台的体系结构中立的字节码格式的(类文件后缀),然后你就可以在Java平台上运行的任何系统。这种方法适用于异构的网络环境和软件分发。
7,Java语言是可移植的。这种可移植性体系结构中立此外,Java有严格的规定,每个基本数据类型的长度。 Java系统本身具有很强的可移植性,Java编译器是用Java实现的,Java的运行时环境中实现ANSI C.
8,Java语言的解释。正如前面提到的在Java平台上被编译成字节码格式,然后可以运行在任何系统中的Java平台,Java程序。在运行时,Java平台,Java解释器解释执行这些字节码类实施过程中需要加载到操作系统环境的耦合阶段。
9,Java是一种高性能。与解释型的脚本语言相比,Java是确实是一个高性能。事实上,Java的运行速度,搭配-IN-TIME(JIT)编译器技术的发展,越来越多的接近C + +。
10,Java语言是多线程的。线程是Java语言中的一种特殊的对象,它必须创建Thread类的子类(星期日)。通常有两种方法创建一个线程:首先,使用形式的几何结构,主题(可运行)构造函数将一个实现Runnable接口的对象包装成一个线程,第二子类派生从Thread类并重写run方法中,创建使用子类对象的线程。值得注意的是Thread类实现Runnable接口,因此,任何一个线程都有它的run方法,run方法包含的线程中运行的代码。的线程的活动来控制由一组方法。 Java语言支持同时执行多个线程之间的同步机制的多线程(关键字为synchronized)。
11,Java语言是动态的。 Java语言的设计目标之一的是,适于在环境中的动态变化。类的Java程序需要动态加载的经营环境,但也通过网络来加载所需的类。这也有利于软件的升级。此外,Java类的运行时类型检查的运行时表示。
Java语言的优秀功能,使Java应用程序具有无与伦比的耐用性和可靠性,这也降低了应用系统的维护成本。 Java嵌入式对象技术和Java平台API的支持可以缩短应用开发时间并降低成本。 Java编译,到处运行的特性使得它能够提供一个开放的架构可在任何地方,和低成本的方式来传递信息之间的多平台。特别是Java企业应用编程接口(Java企业API)为企业计算及电子商务应用提供相关的技术和丰富的类库。 [编辑本段] Java的相关技术
JDBC(Java数据库连接)提供了一个统一的接口来连接各种关系数据库,可提供统一的访问各种关系数据库,它由一组用JAVA语言编写的类和接口。 JDBC标准的API,JDBC为工具/数据库开发人员,你可以构建更高级的工具和接口,数据库开发人员用纯Java API来编写数据库应用程序,是一个商标名称。
2,EJB(企业JavaBeans)可以让开发人员能够轻松地创建,部署和管理跨平台的基于组件的企业应用程序。
3,用于开发分布式Java应用程序的Java的Java远程方法调用(RMI)。 Java对象,可以远程Java虚拟机调用。在这种方式中,远程方法激活可以发生在对等的两端,也可以发生在客户端和服务器之间,只要这两个应用程序都是用Java编写的。
4,Java的Java接口定义语言IDL()提供CORBA(公共对象请求代理体系结构)的无缝互操作性。这使得Java可以集成异构的业务信息资源。
5,JNDI(Java命名和目录接口)提供了一个统一的Java平台无缝连接。这个接口屏蔽了企业网络中使用的各种命名和目录服务。
6,JMAPI(Java管理API)提供了一套丰富的对象和方法的异构网络系统,网络和服务管理的发展。
7,JMS(Java消息服务),提供企业短信服务,如可靠的消息队列,发布和订阅通信,以及推 - 拉(推/拉)技术。
8,JTS(Java事务服务)提供开放的标准访问事务资源,包括事务处理应用程序,事务处理,管理和监测这些事务处理资源。
关注JavaBean,它是一个开放的标准的组件体系结构,它是独立于平台,但使用Java语言的Java技术,。一个JavaBean,以满足JavaBeans规范的Java类通常定义了一个现实世界的事物或概念。一个JavaBean属性,方法和事件的主要特点。通常情况下,在一个开发环境,支持JavaBeans规范(如Sun的Java Studio和IBM的VisualAge for Java)中,您可以直观地操作的JavaBean,也可以使用JavaBean构建一个新的JavaBean。 JavaBean的优势在于Java的可携性。现在,EJB(企业JavaBeans)的JavaBean概念扩展到Java服务器端组件体系结构,这个模型支持多层的分布式对象应用程序。除了到JavaBean,一个典型的组件体系结构DCOM和CORBA,在这些组件的体系结构的深入讨论超出了本书的范围。
Java的
计算机科学课程列表
JNI(Java本地接口)Java本机接口。
[编辑本段]
[Java开源J2EE框架Spring框架的Java开源项目]
Spring是一个解决方案,许多在J2EE开发功能强大的框架中的常见问题。 Spring提供了一个统一的管理业务对象的方法,并鼓励他们养成良好的生活习惯注入接口编程,而不是编程的类型。 Spring框架的基础是基于使用JavaBean属性控制反转容器。然而,这是完整的图片只是其中的一部分:Spring IoC容器作为一个完成的建筑关注所有架构层的完整解决方案是独一无二的。 Spring提供了唯一的数据访问抽象,包括简单和有效率的JDBC框架,极大地提高了工作效率,并减少了出错的可能性。 Spring的数据访问架构还集成了Hibernate和其他O / R映射解决方案。 Spring还提供了一个唯一的事务管理抽象,它能够在各种底层事务管理技术,例如JTA或者JDBC事务提供一个一致的编程模型。 Spring AOP框架提供了一个标准的Java语言,声明式事务管理和其它企业服务 - 如果你需要 - 还能实现自己的方面的POJO。这个框架足够强大,以使应用程序能够抛开EJB的复杂性,同时享受关键服务和传统EJB。 Spring还提供了集成和IoC容器强大而灵活的MVC Web框架。 [SpringIDE:Eclipse平台支持开发的一个插件。
WebWork的组件化和代码重用【Java开源的Web框架]开发
WebWork是由OpenSymphony组织专门拉出MVC模式J2EE Web框架。 WebWork的最新版本是2.1,现在WebWork2.x的前身,里卡德奥伯格开发的WebWork的WebWork的已经被分成两个项目Xwork1和webwork2的。 Xwork简洁,灵活功能强大,它是一个标准的Command模式,并且完全从web层脱离出来。 XWork之上提供了很多核心功能:前端拦截器(Interceptor)运行时表单属性验证,类型转换,强大的表达式语言(OGNL - 对象图形标记语言)的IoC(控制反转控制反转)容器。在建立XWork的顶部webwork2的处理HTTP的响应和请求。 webwork2的使用的ServletDispatcher HTTP请求转化为行动(业务层Action类)的映射会话(session)的应用范围(应用程序),请求的请求参数映射。 webwork2的支持多视图的视图部分可以使用JSP,速度,FreeMarker的的,JasperReports,XML。在WebWork2.2增加了对AJAX的支持,这种支持是建立的基础上的DWR与Dojo框架【EclipseWork:用于WebWork的一个Eclipse插件,帮助开发人员
的Struts【Java开源的Web框架]
Struts是一个基于J2EE平台的MVC框架,主要是采用Servlet和JSP技术。 Struts应用程序开发人员可以完全满足需求,易于使用,灵活快速乱舞在过去的一年。 Struts的的Servlet,JSP,自定义标签和信息资源(信息资源)整合到一个统一的框架,开发人员可以使用它的发展不再需要自己编码实现全套MVC模式,极大的节约的时间,让是Struts是一个非常不错的应用框架。 StrutsIDE:对Struts协助开发一个Eclipse插件]
休眠[开放源码的Java持久化框架]
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行非常轻量级的对象编程思维对象的封装性,使任意的Java程序员可以使用它来操纵数据库的。 Hibernate可以应用任何场合使用JDBC,无论是客户端程序在Java实用程序也可以使用一个Servlet / JSP的Web应用程序中,最具革命性的,Hibernate可以取代CMP EJB的J2EE架构的应用程序来完成数据持久化的重要任务。 Hibernate在Eclipse平台的辅助开发工具:【使用Hibernate Synchronizer】【MiddlegenIDE
石英[Java的开源作业调度】
Quartz是OpenSymphony的开源组织在该领域的工作安排的一个开源项目,它可以与J2EE,J2SE应用程序相结合也可以单独使用。 Quartz可以用来创建简单或运行十,百,甚至是数以十万计的就业机会,每天的日程是如此复杂。 Jobs可以做成标准的Java组件或EJBs。石英石英1.5.0的最新版本。
速度【Java开源模板引擎
Velocity是一个基于java的模板引擎(模板引擎)。它允许任何人仅仅简单的使用模板语言模板语言来引用由java代码定义的对象。速度应用于web开发时,界面设计和java程序开发人员同步开发遵循MVC架构的网站,也就是说,页面设计人员可以专注于显示的页面,java程序开发人员关注业务逻辑编码。速度java代码从网页中分离出来,便于长期维护的网站,同时也为我们在JSP和PHP提供了另一种解决方案。 Velocity的能力远超过网络网站的发展在这方面,例如,它可以产生SQL和PostScript的,XML模板(模板),它也可以被用来作为一个独立的工具,以产生源代码和报告,或者作为其他系统的集成组零件。速度还提供了模板服务的汽轮机的web开发框架(模板服务)。速度+涡轮机提供一个模板服务,允许Web应用程序开发一个真正的MVC模型。 【VeloEclipse:发展速度的辅助插件Eclipse平台]
IBATIS [开放源码的Java持久化框架
使用的iBatis提供的ORM机制,在人事方面,实现了业务逻辑,面对纯Java对象,这一层通过Hibernate ORM而言基本相同的具体的数据操作,Hibernate会自动生成SQL语句,ibatis的要求开发者编写具体的SQL语句。相对Hibernate的“全自动”ORM机制,ibatis的SQL开发的工作量和数据库移植性上的让步,系统设计提供了更大的自由空间。实现的有益补充,作为“全自动”ORM ibatis的外观显得特别有意义。
Compiere的ERP&CRM【Java开源的ERP和CRM系统
Compiere的ERP&CRM提供全面的解决方案,为全球小型和中小型企业,涵盖所有领域,从客户管理,供应链,财务,管理,支持多组织,多币种,多会计模式,多成本,多语种,多税收国际化的特征。易于安装,易于实施,易于使用。只需要几个小时,你可以用采购 - 采购 - 发票 - 付款报价 - 订单 - 发票 - 收款,产品定价,资产管理,客户关系,供应商关系,员工关系,的运作分析功能强大的结果。
滚子Weblogger【Java开源Blog博客]
网络博客更复杂的设计,源代码是一个很好的学习材料。它应该支持网络博客的功能,如:评论功能,所见即所得的HTML编辑器,引用,提供了页面模板,RSS聚合的blogroll,管理,并提供了一个XML-RPC接口。
Eclipse的Java的开放源代码开发工具]
Eclipse平台的开发框架,IBM捐赠给开放源代码社区,不是因为它是著名的IBM声称-4千万美元投资的发展,总数的资金,但如此巨大的投资,因为结果:一个成熟的,精心设计的,可扩展的体系结构。
的NetBeans【Java开源开发工具]
NetBeans IDE是一个软件开发提供了免费,开源的集成开发环境。你可以得到所有的工具,你需要使用Java,C / C + +甚至是Ruby来创建专业的桌面应用程序,企业应用程序,web和移动应用程序。 IDE可以在多种平台上运行,包括Windows,Linux和Mac OS X中,和Solaris,这是非常易于安装和易于使用的。
XPlanner【Java开源的项目管理
XPlanner一个基于Web的XP团队计划和跟踪工具。 XP独特的开发概念,如迭代,用户故事,,XPlanner提供了相应的管理工具,XPlanner支持XP开发流程,并解决遇到的问题的使用XP想法的开发项目。 XPlanner特点包括:简单的模型规划,虚拟笔记卡(虚拟笔记卡)迭代的用户故事和工作记录的追踪,未完成的故事会自动迭代,工作时间追踪,生成团队效率,个人考勤表,SOAP界面支持。
HSQLDB【Java开源DBMS数据库
HSQLDB(高超声速SQL)是一个纯Java的关系数据库的开发,并提供了一个JDBC驱动程序来访问数据。支持ANSI-92标准SQL语法。而且他占的空间小。大约只有160K,快速的数据库引擎。
Liferay的【Java的开源门户和
代表一个完整的J2EE应用程序,使用Web,EJB以及JMS等技术,特别是在前面部分使用Struts框架技术的接口,XML-基于portlet配置文件可以自由动态扩展,使用Web服务来支持一些远程访问的信息,Apahce Lucene的全文搜索功能。
Jetspeed的?【Java开源的门户门户]
Jetspeed是一个开放源代码的企业信息门户(EIP)的实现,使用的技术是Java和XML。信息门户的用户可以使用浏览器,支持WAP协议的手机或其他设备访问Jetspeed的架设。 Jetspeed的所扮演的角色的信息集中器,它可以把信息一起,很容易地提供给用户。
的JOnAS【Java开源的J2EE服务器]
的JOnAS是一个开放源代码的J2EE实现的ObjectWeb协会开发。集成Tomcat或Jetty成为它的Web容器,以确保符合Servlet 2.3和JSP 1.2规范。 JOnAS服务器的依赖,实现以下的Java API:JCA,JDBC,JTA,JMS,JMX,JNDI,JAAS,JavaMail的。
JFox3.0【Java开源的J2EE服务器使用
JFox是一个开源的Java EE应用服务器,致力于提供一个轻量级的Java EE应用服务器,从3.0开始,JFox提供了一个支持模块化MVC框架,以简化EJB和Web应用程序的开发!如果您正在寻找一个简单,重量轻,高效,全面的Java EE开发平台,JFox正是你需要的。
[编辑本段] Java的IDE
当今最流行的Eclipse,Myeclipse中,Jbuilder2008,Jdeveloper的,Netbeans的。 [编辑本段] Java“一书
Java编程思想(第4版)
:(美)埃克尔,陈薅怦翻译
JAVA编程思想(第四版)出版社:机械工业出版社
出版日期:2007-6-1词:版次:1页数:880印刷时间:2007/06/01开本:印象:纸张:胶版纸ISBN:9,787,111,213,826包装:平装
关于作者
Bruce Eckel的是MindView公司的总裁,该公司提供的软件,其客户的咨询和培训。他的C + +标准委员会的投票成员之一,拥有应用物理学学士和计算机工程硕士学位。除了这本书外,他是一个“C + +编程思想”的人合作撰写的“C + +编程思想,第2卷”(两本书的英文影印版和中国版引入了由机械工业出版社出版)及其他著作。他已发表了150多篇论文,还经常参加世界各地的研讨会并发表演讲。
[编辑本段] Java版本历史
Java语言诞生于1995年,
日,1996年,第一个JDK-JDK1.0出生的
1996年4月,10个最重要的操作系统供应商确认其产品中嵌入JAVA技术
1996年9月,约83,000 Web应用程序的JAVA技术,使
1997年2月18日一天,JDK1.1版本
1997年的JavaOne大会,参与者超过百万人,创下了类似的全球规模的会议记录
1997年,JavaDeveloperConnection社区成员超过10万
1998年,JDK1.1被下载超过200万次
在1998年,JAVA2企业平台发布
1999年,Sun发布了Java J2EE三个版本:标准版(J2SE),企业版(J2EE)和微型版(J2ME)
2000年5月8日,JDK1.3发布 / 2000年5月29日,JDK1.4 2001年,诺基亚公司宣布,2003年将销售100万的Java功能的手机
2月2001年9月24日,2010年,J2EE1.3
2002年, 26日,J2SE1.4,因为Java的计算能力已显着增加
9月30日,2004 18:00 PM,J2SE1.5发布,成为Java语言的发展历史的又一个里程碑。要显示版本的重要性,J2SE1.5更名为Java SE 5.0的
2005年JavaOne大会上,Sun公司公开Java SE 6中。在这一点上,各种版本的Java已经被重新命名为取消一个数字“2”:J2EE更名为Java EE,J2SE更名为更名为Java SE,J2ME的Java ME
2006年12月,Sun发布了JRE6目前JDK7.0 0.0
在研究和开发,有测试版的的 。 dev.java.net / 可下载
[编辑本段] Java的互联网
我们知道,以前的WWW不仅可以发送文字和图片,Java的交互式页的的出现是一个伟大的革命。
的Java,设计不是互联网,万维网,它也可以被用来编写独立的应用程序。 Java是一种面向对象的语言,Java语言是C + +语言,所以我们必须掌握C + +编程语言,再学习Java语言是很容易的! Java程序需要编译,它被放置在互联网服务器上,当用户对服务器的访问,Java程序被下载到本地用户的机器,解释的浏览器中运行。实际上有两种Java程序的Java应用程序是一个完整的程序,如Web浏览器。另一个Java应用程序运行在一个Web浏览器程序。
Java程序其浏览器Hotjava中,提供了一种方法,可以让你的浏览器中运行的程序。您可以直接从您的浏览器来播放声音,你可以播放动画,Java的也可以告诉你如何处理与一个新的类型的文件浏览器的页面。当我们能够在2400波特线来传输视频图像,Hotjava中能够显示视频。
[编辑本段] Java和电子商务
,电子商务是当今的一个热门话题,传统的编程语言,但是,不能做电子商务系统,电子商务程序代码的基本要求:安全,可靠,做生意的世界各地,在不同的平台上运行的客户机的要求。 Java的强大的安全性,平台无关的,独立的硬件结构,用简单的语言,面向对象,并在网络编程语言中占据无可比拟的优势,成为电子商务系统的首选语言。
[编辑本段] Java的8个基本数据类型和它们的包装类
int基本数据类型的包装类的原始类型的份额
短短2个字节的整数中的字节数4个字节
长8个字节
浮子的4个字节
双人大床8个字节
字节字节1个字节
CHAR字符2个字节
布尔布尔测试编译环境
[编辑本段]第一个JAVA程序的HelloWorld
/ /文件名的HelloWorld.java
/ /声明公共类一类
的HelloWorld { / /声明一个方法
公共静态无效的主要(字串[] args){/ /程序入口
/ /输出
(“世界你好!); BR /}
}
/ /例子
包的文本;
类测试(
公共静态无效的主要(字串[] args){...... /短D = 12,/ /短整型的
System.out.println(D); / / D
长,C = 144L; / /长整数添加L
系统通过out.println(C)/ /输出
诠释Z = 15; / /整数
System.out.println(Z)/ /输出
字符E ='I “/ /字符”
System.out.println(五);/ /输出è
}
)
[编辑本段] Java新手入门是非常重要的一个一些基本的概念
[1] [2] [3]最后一类:为防止他人从你的类派生出新的类,它是不可扩展的。
动态调用比静态调用花费的时间要长。
抽象类:规定一个或多个抽象方法的类本身必须定义为abstract。
案件:公共抽象的字符串getDescripition
Java的每一个类都是从Object类扩展。和
平等和对象类的toString方法。
等于用于测试一个对象是否与另一个对象是相等的。
的toString返回一个字符串,几乎每一个类的对象将覆盖此方法,以便返回当前状态的正确表示。
(toString方法是一个很重要的方法)
泛型编程:所有的值?任何类型可以是同一对象类的变量,而不是。
数组列表:ArrayList的动态数组列表,是一个类库,定义在java.uitl包可自动调节数组的大小。
类的类对象类的getClass方法返回一个类型的实例的类,它包含的主要方法的类会被加载在程序启动时,虚拟机是所有他需要的类,每一个加载的类加载必须加载它需要的类。
作为一个JAVA程序员, 应该掌握哪些知识, 目前, 比较流行的java开发框架有哪些,
java基础,三大主流数据库mysql,orcale,sql server;然后是j2ee的相关知识,也就是java开发框架。
Spring Framework 【Java 开源JEE框架】
Spring是一个解决了许多在J2EE开发中常见的问题的强大框架。
Spring提供了管理业务对象的一致方法并且鼓励了注入对接口编程而不是对类编程的良好习惯。Spring的架构基础是基于使用JavaBean属性的
Inversion of
Control容器。然而,这仅仅是完整图景中的一部分:Spring在使用IoC容器作为构建完关注所有架构层的完整解决方案方面是独一无二的。
Spring提供了唯一的数据访问抽象,包括简单和有效率的JDBC框架,极大的改进了效率并且减少了可能的错误。Spring的数据访问架构还集成了
Hibernate和其他O/R mapping解决方案。Spring还提供了唯一的事务管理抽象,它能够在各种底层事务管理技术,例如JTA或者
JDBC事务提供一个一致的编程模型。Spring提供了一个用标准Java语言编写的AOP框架,它给POJOs提供了声明式的事务管理和其他企业事务
--如果你需要--还能实现你自己的aspects。这个框架足够强大,使得应用程序能够抛开EJB的复杂性,同时享受着和传统EJB相关的关键服务。
Spring还提供了可以和IoC容器集成的强大而灵活的MVC Web框架。【SpringIDE:Eclipse平台下一个辅助开发插件】.
WebWork 【Java开源Web开发框架】
WebWork是由OpenSymphony组织开发的,致力于组件化和代码重用的拉出式MVC模式J2EE
Web框架。WebWork目前最新版本是2.1,现在的WebWork2.x前身是Rickard
Oberg开发的WebWork,但现在WebWork已经被拆分成了Xwork1和WebWork2两个项目。
Xwork简洁、灵活功能强大,它是一个标准的Command模式实现,并且完全从web层脱离出来。
Xwork提供了很多核心功能:前端拦截机(interceptor),运行时表单属性验证,类型转换,强大的表达式语言(OGNL – the
Object Graph Notation Language),IoC(Inversion of Control倒置控制)容器等。
WebWork2建立在Xwork之上,处理HTTP的响应和请求。WebWork2使用ServletDispatcher将HTTP请求的变成
Action(业务层Action类),
session(会话)application(应用程序)范围的映射,request请求参数映射。WebWork2支持多视图表示,视图部分可以使用
JSP, Velocity, FreeMarker,
JasperReports,XML等。在WebWork2.2中添加了对AJAX的支持,这支持是构建在DWR与Dojo这两个框架的基础之上.
【EclipseWork:用于WebWork辅助开发的一个Eclipse插件】
Struts 【Java开源Web开发框架】
Struts是一个基于Sun
J2EE平台的MVC框架,主要是采用Servlet和JSP技术来实现的。由于Struts能充分满足应用开发的需求,简单易用,敏捷迅速,在过去的一年中颇受关注。Struts把Servlet、JSP、自定义标签和信息资源(message
resources)整合到一个统一的框架中,开发人员利用其进行开发时不用再自己编码实现全套MVC模式,极大的节省了时间,所以说Struts是一个非常不错的应用框架。【StrutsIDE:用于Struts辅助开发的一个Eclipse插件】
Hibernate 【Java开源持久层框架】
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。
Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序实用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。Eclipse平台下的Hibernate辅助开发工具:【Hibernate
Synchronizer】【MiddlegenIDE】
Quartz 【Java开源调度框架】
Quartz是OpenSymphony开源组织在Job
scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的日程序表。Jobs可以做成标准的Java组件或
EJBs。Quartz的最新版本为Quartz 1.5.0。
Velocity 【Java开源模板引擎】
Velocity是一个基于java的模板引擎(template engine)。它允许任何人仅仅简单的使用模板语言(template
language)来引用由java代码定义的对象。当Velocity应用于web开发时,界面设计人员可以和java程序开发人员同步开发一个遵循MVC架构的web站点,也就是说,页面设计人员可以只关注页面的显示效果,而由java程序开发人员关注业务逻辑编码。Velocity将java代码从web页面中分离出来,这样为web站点的长期维护提供了便利,同时也为我们在JSP和PHP之外又提供了一种可选的方案。
Velocity的能力远不止web站点开发这个领域,例如,它可以从模板(template)产生SQL和PostScript、XML,它也可以被当作一个独立工具来产生源代码和报告,或者作为其他系统的集成组件使用。Velocity也可以为Turbine
web开发架构提供模板服务(template
service)。Velocity+Turbine提供一个模板服务的方式允许一个web应用以一个真正的MVC模型进行开发。【VeloEclipse
:Velocity在Eclipse平台下的一个辅助开发插件】
IBATIS 【Java开源持久层框架】
使用ibatis 提供的ORM机制,对业务逻辑实现人员而言,面对的是纯粹的Java对象, 这一层与通过Hibernate 实现ORM
而言基本一致,而对于具体的数据操作,Hibernate 会自动生成SQL 语句,而ibatis 则要求开发者编写具体的SQL
语句。相对Hibernate等 “全自动”ORM机制而言,ibatis
以SQL开发的工作量和数据库移植性上的让步,为系统设计提供了更大的自由空间。作为“全自动”ORM 实现的一种有益补充,ibatis 的出现显
得别具意义。
Compiere ERPCRM 【Java开源ERP与CRM系统】
Compiere
ERPCRM为全球范围内的中小型企业提供综合型解决方案,覆盖从客户管理、供应链到财务管理的全部领域,支持多组织、多币种、多会计模式、多成本计算、多语种、多税制等国际化特性。易于安装、易于实施、易于使用。只需要短短几个小时,您就可以使用申购-采购-发票-付款、报价-订单-发票-收款、产品与定价、资产管理、客户关系、供应商关系、员工关系、经营业绩分析等强大功能了。
Roller Weblogger 【Java开源Blog博客】
这个weblogging
设计得比较精巧,源代码是很好的学习资料。它支持weblogging应有的特性如:评论功能,所见即所得HTML编辑,TrackBack,提供页面模板,RSS
syndication,blogroll管理和提供一个XML-RPC 接口。
Eclipse 【Java开源IDE】
Eclipse平台是IBM向开发源码社区捐赠的开发框架,它之所以出名并不是因为IBM宣称投入开发的资金总数
—4千万美元,而是因为如此巨大的投入所带来的成果:一个成熟的、精心设计的以及可扩展的体系结构。
XPlanner 【Java开源项目管理】
XPlanner 一个基于Web的XP团队计划和跟踪工具。XP独特的开发概念如iteration、user
stories等,XPlanner都提供了相对应的的管理工具,XPlanner支持XP开发流程,并解决利用XP思想来开发项目所碰到的问题。
XPlanner特点包括:简单的模型规划,虚拟笔记卡(Virtual note cards),iterations、user
stories与工作记录的追踪,未完成stories将自动迭代,工作时间追踪,生成团队效率,个人工时报表,SOAP界面支持。
HSQLDB 【Java开源开源数据库】
HSQLDB(Hypersonic SQL)是纯Java开发的关系型数据库,并提供JDBC驱动存取数据。支持ANSI-92 标准
SQL语法。而且他占的空间很小。大约只有160K,拥有快速的数据库引擎。
Liferay 【Java开源门户系统】
代表了完整的J2EE应用,使用了Web、EJB以及JMS等技术,特别是其前台界面部分使用Struts
框架技术,基于XML的portlet配置文件可以自由地动态扩展,使用了Web Services来支持一些远程信息的获取,使用 Apahce
Lucene实现全文检索功能。
主要特点:
提供单一登陆接口,多认证模式(LDAP或 SQL);
管理员能通过用户界面轻松管理用户,组,角色;
用户能可以根据需要定制个性化的portal layout;
能够在主流的J2EE应用服务器上运行,如JBoss+Jetty/Tomcat,JOnAS;
支 持主流的数据库,如PostgreSQL,MySQL;
使用了第三放的开源项目,如Hibernate, Lucene, Struts;
支持包括中文在内的多种语言;
采用最先进的技术 Java, EJB, JMS, SOAP, XML;
JetSpeed 【Java开源门户系统】
Jetspeed是一个开放源代码的企业信息门户(EIP)的实现, 使用的技术是Java和XML. 用户可以使用浏览器,
支持WAP协议的手机或者其它的设备访问Jetspeed架设的信息门户获取信息. Jetspeed扮演着信息集中器的角色,
它能够把信息集中起来并且很容易地提供给用户.
Jetspeed具有如下的特征:
即将成为标准化的Java Portlet API
基于模板的布局, 包括JSP和Velocity
通过开放的内容同步技术支持远程XML 内容交换
定制默认的主页
使用数据库进行用户认证
内存缓存技术, 加快页面的响应
通 过Rich Site Summary技术, 支持同步内容
和Cocoon, WebMacro, Velocity集成.
Wireless Markup Language (WML) 支持
使用XML格式的配置文件注册portlet.
完整的 Web Application Archive (WAR) 支持
Web应用程序开发的基础设施
可以在本地缓 存远程内容
与Avantgo同步
可移植到所有支持JDK1.2和Servlet 2.2的平台
与 Turbine模块和服务集成
可以根据用户, 安装媒体类型和语言的不同设定, 产生不同的个性化服务
持续化服 务使得所由的portlet能够容易的存储每个用户的状态, 页面和portlet
使用皮肤技术使得用户可以选择portlet的颜 色和显示属性
自定义功能是的管理员可以选择portlet以及定义个人页面的布局
在数据库中存储PSML
通 过Jetspeed的安全portlets管理用户, 组,角色和权限
基于角色对访问portlet进行控制
JOnAS 【Java开源应用服务器】
JOnAS是一个开放源代码的J2EE实现,在ObjectWeb协会中开发。整合了Tomcat或Jetty成为它的Web容器,以确保符合Servlet
2.3和JSP 1.2规范。JOnAS服务器依赖或实现以下的Java API:JCA、JDBC、JTA
、JMS、JMX、JNDI、JAAS、JavaMail 。
JFox3.0 【Java开源应用服务器】
JFox 是 Open Source Java EE Application Server,致力于提供轻量级的Java
EE应用服务器,从3.0开始,JFox提供了一个支持模块化的MVC框架,以简化EJB以及Web应用的开发!
如果您正在寻找一个简单、轻量、高效、完善的Java EE开发平台,那么JFox正是您需要的。
JFox 3.0 拥有以下特性:
重 新设计的 IoC 微内核,融入 OSGi 模块化思想
设计成嵌入式架构,能够和任何 Java Web Server集成部署
支 持 EJB3,JPA规范,支持容器内和容器外两种方式运行EJB和JPA组件
支持 EJB 发布成Web Service
采 用 JOTM()提供事务处理,支持两阶段提交 (2PC)
采用 XAPool() 提供 XA
DataSource,支持智能连接池管理
内置 MVC 框架,实现自动Form
Mapping,Validator,Uploading等功能,支持JSP/Velocity/Freemarker页面引擎,并支持直接在
Action中注入EJB
支持多应用模块部署,让中大型应用充分享受模块化开发带来的优势
提供 Manager 管理模块,可以查看和管理各种运行时参数
提供根据 JFox 特色重写的 Petstore 应用模块
EasyJWeb 【Java开源Web开发框架】
EasyJWeb是基于java技术,应用于WEB应用程序快速开发的MVC框架,框架设计构思来源于国内众多项目实践,框架充分借签了当前主要流行的开源Web框架(Struts、JSF、Tapestry
、Webwork),吸取了其优点及精华,利用Velocity作为模板页面引擎,是一个实现了页面及代码完全分离的MVC开发框架。是一个能实现中小型
Web应用系统快速开发的简易Web框架。
通过EasyJWeb
Tools提供的配套开发工具,可以实现基于EasyJWeb框架的Web应用快速开发,包括常用应用软件的代码自生成、数据库添删改查(CRUD)代码生成、自动页面模版生成、配置文件管理等。
框架特点:
零配文件置支持。以前我们每接触一个框架,开始总都要被
他的配置文件折腾一番。EasyJWeb实现零配置支持,可以不写一句配置文件就在框架基础上构建你的运用。(适合小型网站系统)。
简 易的模板页面设计支持:放弃使用jsp,使用简单Velocity脚本语言作为页面模板。
页面程序完全分离:实现显示页面与程序逻辑 的完全分离,克服了传统jsp页面难于维护的问题。
基于页面组件的框架。灵活的页面组件配置,可以直接通过配置文件设置字段级的事件 组件。
快速开发支持:通过EasyJWeb
Tools,可以自动生成应用软件模板代码,定制并管理自己的J2EE代码模板,代码生成模板支持最流行的实用Java开发框架(如hibernate、
Spring等)实现快速开发。
Tapestry 【Java开源Web开发框架】
Tapestry是一个开源的基于servlet的应用程序框架,它使用组件对象模型来创建动态的,交互的web应用。一个组件就是任意一个带有
jwcid属性的html标记。其中jwc的意思是Java Web
Component。Tapestry使得java代码与html完全分离,利用这个框架开发大型应用变得轻而易举。并且开发的应用很容易维护和升级。
Tapestry支持本地化,其错误报告也很详细。Tapestry主要利用javabean和xml技术进行开发。【Spindle:Tapestry
辅助开发Eclipse插件】.
FreeMarker 【Java开源模板引擎】
FreeMarker允许Java
servlet保持图形设计同应用程序逻辑的分离,这是通过在模板中密封HTML完成的。模板用servlet提供的数据动态地生成
HTML。模板语言是强大的直观的,编译器速度快,输出接近静态HTML页面的速度。
【FreeMarker Eclipse Plugin与FreeMarker IDE:Eclipse平台下的辅助开发工具】
Lucene 【Java开源搜索引擎】
Apache
Lucene是一个基于Java全文搜索引擎,利用它可以轻易地为Java软件加入全文搜寻功能。Lucene的最主要工作是替文件的每一个字作索引,索引让搜寻的效率比传统的逐字比较大大提高,Lucen提供一组解读,过滤,分析文件,编排和使用索引的API,它的强大之处除了高效和简单外,是最重要的是使使用者可以随时应自已需要自订其功能。
iText 【Java开源PDF类库】
iText是一个能够快速产生PDF文件的java类库。iText的java类对于那些要产生包含文本,表格,图形的只读文档是很有用的。它的类库尤其与java
Servlet有很好的给合。使用iText与PDF能够使你正确的控制Servlet的输出。
Groovy 【Java开源动态语言】
Groovy是一种基于JVM的敏捷开发语言,它结合了Python、Ruby和 Smalltalk的许多强大的特性。
Groovy已在WebWork2中的应用。它可以被编译为标准的Java Bytecode。
OpenCms 【Java开源CMS系统】
OpenCms是一个J2EE的产品,它是用 Java写成的。它和Tomcat捆绑在一起。但是也能够使用ATG
Dynamo、WebLogic和WebSphere。OpenCms支持多种RDBMS来保存内容,包括Oracle、SQL
Server、Sybase和mySQL。新版本提供了一个新的模板引擎,JSP支持,一种新的连接管理系统,提高了稳定性。
JUnit 【Java开源测试工具】
JUnit是由 Erich Gamma 和 Kent Beck 编写的一个回归测试框架(regression testing
framework)。Junit测试是程序员测试,即所谓白盒测试,因为程序员知道被测试的软件如何(How)完成功能和完成什么样(What)的功能。Junit是一套框架,继承TestCase类,就可以用Junit进行自动测试了。
BlueJ 【Java开源IDE】
BlueJ是一个专门为入门级教学设计的JavaTM 开发环境。它是由澳大利亚墨尔本Monash大学BlueJ小组设计并开发的。
XWiki 【Java开源Wiki系统】
XWiki是一个强大的Java开源的Wiki引擎。它支持一些受欢迎的特性如:
内 容管理(浏览/编辑/预览/保存),
支持附件,
版本控制,
全文本搜索,
权 限管理
使用Hibernate进行数据存储,
RSS输出与显示外部的RSS feeds,
多 语言支持,
提供XML/RPC的API,
WYSIWYG HTML编辑器,
导出为PDF
Groovy 脚本支持等等....。
EJBCA 【Java开源网络服务器端组件】
EJBCA是一个全功能的CA系统软件,它基于J2EE技术,并提供了一个强大的、高性能并基于组件的CA。EJBCA兼具灵活性和平台独立性,能够独立使用,也能和任何J2EE应用程序集成。
JXTA 【Java开源其它项目】
Sun微系统公司公开了旨在建立P2P(Peer to
Peer)通用技术基础的JXTA计划。JXTA技术是网络编程和计算的平台,用以解决现代分布计算尤其是点对点(P2P)计算中出现的问题。
JXTA将建立核心的网络计算技术,提供支持在任何平台、任何地方以及任何时间实现P2P计算的一整套简单、小巧和灵活的机制。JXTA首先将归纳目前
P2P的功能特别,而后建立核心的技术来表达目前的P2P计算的局限性。其重点是创建基本的机制,而具体的策略选择权则交给应用的开发者。JXTA将充分利用XML、Java等开放技术,使得UNIX操作系统更强大和灵活,比如利用管道(Pipes)传输Shell命令实现复杂的计算任务。JXTA支持
P2P应用的基本功能来建立一个P2P系统,还将努力证实这些可以成为建立更高层功能的基础构造模块。JXTA架构可以分为三个层面:JXTA核心层、
JXTA业务层和JXTA应用层。
DWR 【Java开源AJAX框架】
DWR(Direct Web
Remoting)是一个WEB远程调用框架.利用这个框架可以让AJAX开发变得很简单.利用DWR可以在客户端利用JavaScript直接调用服务端的Java方法并返回值给JavaScript就好像直接本地客户端调用一样(DWR根据Java类来动态生成JavaScrip代码).它的最新版本
DWR0.6添加许多特性如:支持Dom Trees的自动配置,支持Spring(JavaScript远程调用spring
bean),更好浏览器支持,还支持一个可选的commons-logging日记操作.
ZK 【Java开源AJAX框架】
ZK是一个Ajax Java Web框架,利用少量代码就能够开发出拥有Rich
UI的Web应用。ZK提供基于XUL的标记语言和事件驱动的组件,可以让你像开发桌面应用程序一样简单。支持EL表达式和脚本语言包括:JavaScript、Ruby和Groovy等。支持Annotation及数据绑定。集成Google
Maps、FCKeditor、DOJO以及Timeline。
java protobuf 定义rpc服务怎么调用
1.,选择其中的win版本下载,我选择的是protoc-2.4.1-win32.zip
2.下载一个protobuf-java-2.4.1.jar文件(注意,要与你刚才下的proto.exe版本相同)
然后就开始开发了。
步骤:
1.用记事本编写一个.proto文件:
}如:编写的是test.proto
package protobuf;
option java_package = "com.sq.protobuf";
option java_outer_classname = "FirstProtobuf";
message testBuf {
required int32 ID = 1;
required string Url = 2;
}
将其放在与刚解压的protoc.exe同级目录中。
2.在cmd中,到protoc-2.4.1-win32文件夹下,
执行
E:\protoc-2.4.1-win32 protoc.exe --java_out=./ test.proto
则可以找到的一个生成的FirstProtobuf.java文件。
3.在MyEclipse中新建一个java project,建立包com.sq.protobuf,然后将刚才生成的FirstProtobuf.java文件放在其下面。
此时会报错,因为没有引入jar包,在package视图下,将protobuf-java-2.4.1.jar引入,即可解决问题。
关于javarpc接口开发和grpc Java的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
发布于:2022-11-28,除非注明,否则均为
原创文章,转载请注明出处。