使用服务器Java&Javascript客户端与Apache Thrift的数组

问题描述:

即时通讯使用Javascript来显示用Java生成的信息。 我谈了10,000个数据,所有这些数据都是用Java生成的,并且使用随机值生成了测试内容。那么我想在我的JavaScript页面中看到这10,000个值。使用服务器Java&Javascript客户端与Apache Thrift的数组

我已经有一个简单的服务器Java和客户端Javascript共享2双打。

这是2个双打的节俭文件:

namespace java test_thrift 
service test{ 
    double number(1:double n1, 2:double n2) 
} 

这是我的JavaScript客户端

function calc() { 
var transport = new Thrift.Transport("/service"); 
var protocol = new Thrift.Protocol(transport); 
var client = new testClient(protocol); 

var workbench = Math.random()*1000; 
    try { 
     result = client.number(workbench); 
     $('#result').val(result); 
     $('#result').css('color', 'black'); 
     document.getElementById("demo").innerHTML = result; 
    } catch(ouch){ 
     $('#result').val(ouch.why); 
     $('#result').css('color', 'red'); 
    } 
} 

Im的发送随机只拿到的范围内码返回。实施例:1,从3的值返回到图9中,2返回一个9至15个值等

而在Java我有一个testHandler类:

public double number(double n1, double n2) throws TException { 
    //System.out.println(n1 + " - " + n2); 
    Random rnd = new Random(); 
    n1 = rnd.nextDouble() * 10 + 1; 
    n2 = rnd.nextDouble() * 15 + 10; 
    return n2; 
} 

那么这将返回值1。我想在我的Javascript页面中看到所有内容。但有10,000个元素。我怎样才能做到这一点?

此外,我想补充的是,最终的结构来分享的是这样的:

dis[10000][3]={ 
    ABC,12.5,13.5, 
    ACD,14.4,11.5, 
    .....ETC......} 

林卡住

发现这一点,但我不知道如何得到它的工作:/

namespace java test_thrift 

typedef list<double> Vector 

struct test 
{ 
    1:i32 rows, 
    2:i32 cols, 
    3:list<Vector> data, 
} 
+0

鉴于我理解这个问题的权利:怎么样使用'名单'和'pair'是一个'struct pair {1:double one,2:double two}'?通过这种方式,您可以通过一次呼叫传递尽可能多的数据。如果chaning服务器的IDL不是一个有效的选择,那么你必须执行10000次调用(这将是更低的性能) – JensG

+0

准确地说,我只想进行1次调用并传递所有信息。但我不知道如何“名单”的作品。我从来没有用过它。你知道一些例子吗? –

所以,我设法解决它。这里是一个客户JavasCript,它使reequest和Java服务器回馈一个10000 x 18矩阵。

节俭文件:

命名空间中的Java test_thrift

struct Cell { 
    1: string did 
    2: double l_x 
    3: double l_y 
    4: double l_z 
    5: double m_x 
    6: double m_y 
    7: double m_z 
    8: double a_x 
    9: double a_y 
    10: double a_z 
    11: double g_x 
    12: double g_y 
    13: double g_z 
    14: string d_t 
    15: double tp 
    16: double r_q 
    17: string o_m 
    18: double b_v 
} 

service test{ 
    list<Cell> number(1 : i16 req) 
} 

然后在Javascript中我只发送请求:

function calc() { 
var transport = new Thrift.Transport("/service"); 
var protocol = new Thrift.Protocol(transport); 
var client = new pruebaClient(protocol); 


var workbench = Math.random()*1000; 
var div = document.getElementById('deltat'); 


    try { 

     result = client.number(1); 
     div.innerHTML = div.innerHTML + '\nReady'; 

    } catch(ouch){ 

     $('#result').val("ERROR"); 
     $('#result').css('color', 'red'); 
    } 
} 

而且在结果y的[10000] [18]答案并像这样打印:

for (var i = result.length - 1; i >= 0; i--) { 
     //div.innerHTML = div.innerHTML + '\n' + result[i]; 
     div.insertAdjacentHTML('beforeend', '\n'+result[i].did+' '+result[i].l_x+' '+result[i].l_y+' '+result[i].l_z+' '+result[i].m_x+' '+result[i].m_y+' '+result[i].m_z+' '+result[i].a_x+' '+result[i].a_y+' '+result[i].a_z+' '+result[i].g_x+' '+result[i].g_y+' '+result[i].g_z+' '+result[i].d_t+' '+result[i].tp+' '+result[i].r_q+' '+result[i].o_m+' '+result[i].b_v); 
    }; 
    } 

最后,在我的Java服务器的处理程序是这样的:

public class TestHandler implements test.Iface { 
    public Random rnd = new Random(); 
    public static List<Cell> p = new ArrayList<Cell>(); 

    public void test() { 
    for (int i = 0; i < 10000; i++) { 
     Cell a = new Cell(); 
     a.did = "SomeString"; 
     a.l_x = rnd.nextDouble()*10+1; 
     a.l_y = rnd.nextDouble()*10+1; 
     a.l_z = 0.0; 
     a.m_x = 0.0; 
     a.m_y = 0.0; 
     a.m_z = 0.0; 
     a.a_x = 0.0; 
     a.a_y = 0.0; 
     a.a_z = 0.0; 
     a.g_x = 0.0; 
     a.g_y = 0.0; 
     a.g_z = 0.0; 
     a.d_t = "String here"; 
     a.tp = 0.0; 
     a.r_q = 0.0; 
     a.o_m = "A"; 
     a.b_v = 0.0; 
     p.add(a); 
    } 
} 
@Override 
public List<Cell> number(short req) throws TException { 
    test(); 
    return ips.ReminderBeep.list_d; 
} 

我希望这将是有用的人

+0

您是否意识到您的答案与您自己的问题甚至不相符? – JensG

+0

为什么不呢?我在开始时说过,我会像这样的形式发送一个矩阵: 'dis [10000] [3]'。你不读那个吗?我只是改变“3”为“18”。怎么了?。你回答从Javascript发送数据到Java,我提到我想要的是相反的。 –

使用此IDL文件

namespace java test_thrift 

struct MyPair { 
    1: double one 
    2: double two 
} 

service test{ 
    list<double> number(1 : list<MyPair> data) 
} 

的功能,然后调用,像这样:然后

var list = []; 
for(var i = 0; i < 10000; ++i) { 
    list.push({ 
     one : Math.random()*1000, 
     two : Math.random()*1000 
    }); 
} 
result = client.number(list); 

结果应该是当然的给定,返回的值列表中的服务器端相应的执行。

+0

没关系,如果我重新使用服务器,只需更改处理程序?我试图打印列表的大小,但我不能。 JavaScript的文件总是去捕捉。对不起,这是烦人的,我是新的节俭,但真的很感谢你的帮助。 –