轻量级 js2java rpc 框架发布 -买球官网平台

5顶
0踩

轻量级 js2java rpc 框架发布

2011-08-19 10:04 by 见习记者 jxpath 评论(8) 有12957人浏览
1. 相关介绍:

1.1 是什么

是一个基于flash、java、js架构设计的超轻量级rpc框架。

1.2 特点是什么

1、js2java rpc:能够在javascript的web浏览器环境中指定java类,获取该类实例的属性,调用该实例的方法

2、支持复杂js对象作为入参:能够传递复杂的javascript object对象作为调用参数,在java中得到对应的map对象

3、自动压缩、解压传递的数据:调用过程中传递的数据自动进行压缩传输,后台自动解压,然后转换为map给开发人员;因此从一定层面上保护、加密了传输的数据

4、js回调函数中能够接收java返回的复杂对象:java中可以返回复杂的对象,比如map、list,在javascript中对应为object和array

5、友好逐行数据输出并回调:java中可以将list逐行输出到浏览器中,框架每接收到一条数据,能够自动回调给定的javascript方法,从而实现数据流的逐行输出;该接口继承与“com.ibatis.sqlmap.client.event.rowhandler”因此很容易将ibatis的数据流逐行输出给浏览器,从而实现非常友好的数据加载方式

6、支持回调全异步(观察者模式):所有的过程调用都采用异步方式,可以指定回调函数,用来接收返回的对象,并进行其他处理

7、日志回调:l异步过程可以设置日志回调函数,让你掌控全过程

1.3 包含什么

包含:
xtzpstream.swf:v1.0:25kb,flash文件
xtzpstream_1.0.jar:655 kb,java服务端jar
xtzpstream.js:3.69 kb,
jsp中使用的代码片段:未压缩,大约2.61 kb

1.4 应该注意什么

xtzpstream和json-rpc-for-java都要求utf-8字符集---js代码

1.5 下载地址是什么



1.6 依赖什么

依赖的jar【2.36 mb】:
backport-util-concurrent.jar
commons-httpclient-3.0.1.jar
jgroups.jar

2 web.xml配置

仅仅需要在web.xml中配置,http://code.google.com/p/json-rpc-for-java/上的两个rpc框架都是,只需要简单的配置.
xtzpstream 在web.xml中的配置:

    
        commonhttpservlet
        
    com.rmuzwqqryqmyyvft1de0fat7jwvjj3ja.commonhttpservlet
        
        3
    
    
        commonhttpservlet
        /cmhs
    


3 如何使用

3.1 java

package com.rmuzwqqryqmyyvft1de0fat7jwvjj3ja;
import java.util.arraylist;
import java.util.list;
import java.util.map;
public class test {
   /**
    * 一般对象
    * @param m
    * @return
    */
   public object mycbktest(map m)
   {
     list lst = new arraylist();
     lst.add(new string[]{"牧仁", "之", "数据压缩传输", "创新"});
     lst.add(new int[]{1,1,6,0,2,0,1,1});
     return lst;
   }
   
   /**
    * 行流方式
    * @param m
    * @param cbk
    * @throws exception
    */
   public void mycbktestrow(map m, irowhandler cbk) throws exception
   {
     list lst = new arraylist();
     lst.add(new string[]{"牧仁2", "之", "数据压缩传输", "创新"});
     lst.add(new int[]{1,1,6,0,2,0,1,1});
     if(null != cbk)
     for(int i = 0; i < lst.size(); i  )
        cbk.handlerow(lst.get(i));
   }
   /**
    * @param args
    */
   public static void main(string[] args) {
     system.out.println(new objecttojson(new test()).tojson());
   }
}


3.2 jsp

<%@ page  pageencoding="utf-8"%>
<%
    string path = request.getcontextpath();
    string basepath = request.getscheme()   "://"
              request.getservername()   ":"   request.getserverport()
              path   "/";
%>
xtzpstream框架使用演示(demo)

       




3.3 js api

// 指定上下文路径,必须的,没有的上下文的时候就是空串""
var contextpath = "<%=path%>";
var xtzps = xtzpstream(contextpath);


1、xtzps.nextid(); // 生成一个唯一的字符串id

2、xtzps.getrpcobj(s,mycbk);
-------------------------------------------------------------
s        类名,例如:"com.rmuzwqqryqmyyvft1de0fat7jwvjj3ja.test"
-------------------------------------------------------------
mycbk  回调函数,有一个入参,是指定类转换为js的对象,例如:
    
 function(o)
            {
                /*//////和下面的方法效果一样/////////
                o.mycbktest({data:"表单数据"}, function(p)
                {
                    for(var k in p)alert(k   " = "   p[k]);
                });
                /////////////////////////*/
                test.mycbktest({data:"表单数据"}, function(p)
                {
                    for(var k in p)alert(k   " = "   p[k]);
                });
            }


3、xtzps.readstm(o, fncbk, ctx);
-------------------------------------------------------------
o    传递到后台的复杂js对象,例如:
{ name:"牧仁", 
                    qq:11602011, 
                    age:"9zb",
                    a: {b:[1234,34,33,34]},  /* 复杂对象传递测试*/
                    /* 回调java方法,并返回结果,入口参数为: public object mycbktest(map m) */
                    xtstreamcbk: "com.rmuzwqqryqmyyvft1de0fat7jwvjj3ja.test.mycbktest" 
                   }


xtstreamcbk用于指定要回调的java类名:(com.rmuzwqqryqmyyvft1de0fat7jwvjj3ja.test)和方法(mycbktest)
其中方法定义、入参要求是:

// 入参要去是map
public object mycbktest(map m)
{
     list lst = new arraylist();
     lst.add(new string[]{"牧仁", "之", "数据压缩传输", "创新"});
     lst.add(new int[]{1,1,6,0,2,0,1,1});
     return lst;
}


另外:

/* 回调java方法,并返回结果,入口参数为: public void mycbktestrow(map m, irowhandler cbk) throws exception */
xtstreamcbkrow: "com.rmuzwqqryqmyyvft1de0fat7jwvjj3ja.test.mycbktestrow"
用来指定基于流的方式输出行流对象,并逐行回调js方法,方法的定义要求:

   public void mycbktestrow(map m, com.rmuzwqqryqmyyvft1de0fat7jwvjj3ja.irowhandler cbk) throws exception
   {
     list lst = new arraylist();
     lst.add(new string[]{"牧仁2", "之", "数据压缩传输", "创新"});
     lst.add(new int[]{1,1,6,0,2,0,1,1});
     if(null != cbk)
     for(int i = 0; i < lst.size(); i  )
        cbk.handlerow(lst.get(i));// 这里逐行输出数据
   }

-------------------------------------------------------------
fncbk  回调函数,具有一个入口参数,是异步返回的对象,例如:
var k, cbk = function(o)
        {
            o || (o = {});
            var k;
            for(k in o)
               alert(k   " = "   o[k]);
        };

-------------------------------------------------------------
ctx 当前应用上下文路径,没有时为"",例如:var ctx = "<%=request.getcontextpath()%>";

项目网站

下载地址
  • (2.9 mb)
  • 下载次数: 73
5
0
评论 共 8 条 请登录后发表评论
8 楼 jxpath 2012-05-09 16:00
kingsfighter 写道
不错,不过和dwr比起来,有什么优势?应该把亮点都列出来。

优势:数据压缩传输,尤其是后台返回list数据,是经过压缩后,下载效率就非常高了,例如应用开发中1000~n条数据的加载

j5321594 写道
能不能 不要每次把页面的输入 标签的值提交到后台? 项目是个单页的大量的输入标签都被隐藏着,每次都会提交大量无用数据给后台。

肯定可以指定定特定的参数传递了
7 楼 2012-02-17 08:46
跟dwr有什么区别呢?即使有区别,那点区别意义在哪呢?
6 楼 2011-12-14 18:19
能不能 不要每次把页面的输入 标签的值提交到后台? 项目是个单页的大量的输入标签都被隐藏着,每次都会提交大量无用数据给后台。
5 楼 2011-08-21 15:10
搞不懂什么趋势啊这是。。。。
4 楼 2011-08-19 17:10
比dwr的优势在哪 没有说明
3 楼 jxpath 2011-08-19 12:33
据传:
引用
1、数据传输压缩、自动解压

2、不要注册使用的java类

3、支持数据流传输

2 楼 2011-08-19 10:44
flash js jsp java ?很好奇,研究下
1 楼 2011-08-19 10:43
不错,不过和dwr比起来,有什么优势?应该把亮点都列出来。

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 去中心化自动组网,充分利用内结点互相发现相互通信开发中js脚本开发支持因素dfactor是一个基于actor模型的消息处理框架,充分利用多核处理器,平衡业务负载,可参考erlang dfactor使用java编写,天生多平台支持,...

  • 1. 相关介绍: ...是一个基于flash、java、js架构设计的超轻量级rpc框架。 1.2 特点是什么 1、js2java rpc:能够在javascript的web浏览器环境中指定java类,获取该类实例的属性,调用该实例的方法

  • 1.hessian简介hessian是一个轻量级的远程http工具,采用binaray rpc协议,适合发送二进制数据,同时具有防火墙穿透能力,hessian一般通过web应用来提供服务。...

  • java 轻量rpc框架 重要要点 http-rpc是一个轻量级的开源框架,用于使用rpc隐喻开发restful应用程序 提供服务器和客户端api 支持多种操作系统和设备 支持多种语言,包括java,objective-c / swift和...

  • 文件夹技术简单介绍json-rpc是基于json的跨语言远程调用协议。比xml-rpc、webservice等...眼下主流语言都已有json-rpc的实现框架,java语言中较好的json-rpc实现框架有jsonrpc4j、jpoxy、json-rpc。三者之中jsonrpc...

  • solon 是一个轻量级应用开发框架。支持 web、data、job、remoting、cloud 等任何开发场景。短小而精悍! 强调,克制 简洁 开放的原则 力求,更小、更快、更自由的体验 关于 solon cloud solon cloud 定义了一...

  • 相信大家和我一样,都有一个大厂梦,作为一名资深java选手,深知面试重要性,接下来我准备用100天时间,基于java岗面试中的高频面试题,以每日3题的形式,带你过一遍热门面试题及恰如其分的解答。   一路走来,...

  • 仅不到100行的javascript代码和不到10个java文件实现的超轻量级的通过javascript快速调用java对象并返回任意对象的轻量级框架,和支持级联调用,而无需额外javascript编程,就可以通过javascript调用被注册的java...

  • 笔者工作也有些时间了,在某互联网一二线场都工作过,当时在某二线厂工作时,部门自研了rpc框架,用来支撑部门c端产品业务开发,当时一直想自己也要写一个rpc框架,但由于一直没有时间,这个想法隔着了很久。...

  • 核心要点\http-rpc是一个开发restful应用的轻量级开源框架,同时符合rpc隐喻的做法; \提供了服务端和客户端的api; \支持各种操作系统和设备; \支持多种语言,包括java、objective-c/swift和javascript。http-rpc...

  • rpc技术简单说就是为了解决远程调用服务 的一种技术,使得调用者像调用本地服务一样方便透明 thrift的定义   thrift是一个轻量级、跨语言的rpc框架,主要用于各个服务之间的rpc通信,最初由facebook于2007 年开发...

  • smart framework:轻量级 java web 框架 收藏 黄勇 工作闲暇之余,我开发了一款轻量级 java web 框架 ——smartframework。 开发该框架是为了: 加速基于 java 的中小型...

  • soap是一种数据交换协议规范,是一种轻量的、简单的、基于xml的协议的规范。而soap可以看着是一个重量级的协议,基于xml、soap在安全方面是通过使用xml-security和xml-signature两个规范组成了ws-security来实现安全...

  • 但并不是每一项技术都是一样的java是二十多年来在科技界享有强大地位的少数技术之一! 根据各种标准报告,java仍然是最流行和最需要的编程语言之一。java如此受欢迎的主要原因之一是它有广泛的应用程序,如android...

  • rpc 2.0 specification》的 .net 实现, 它是基于 http (也能支持本地调用和tcp)方式实现的轻量级松耦合的远程调用服务框架,提供了高效可用、无侵入式的方式搭建自己的服务平台,可以快速开发、调试、发布、调用...

global site tag (gtag.js) - google analytics