Apache Thrift使用服务器Java& Javascript客户端

时间:2016-07-25 20:49:53

标签: javascript java apache thrift

我使用Javascript来显示用Java生成的信息。 我在谈论10,000个数据,所有数据都是用Java生成的,并且是使用随机值测试im的porpouse。好吧,我想在我的javascript页面中看到这10,000个值。

我已经有一个简单的Server Java和一个Client Javascript来共享2个双打。

这是2个双打的Thrift文件:

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');
    }
}

我只发送一个随机来获得回报的范围。示例: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,
}

2 个答案:

答案 0 :(得分:1)

使用此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);

结果应该是您返回值的列表,当然服务器端也会相应地实现。

答案 1 :(得分:1)

所以,我设法修复它。这是一个客户端JavasCript进行reequest和Java服务器回赠10000 x 18矩阵。

节俭文件:

namespace 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 Server中的处理程序是这样的:

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;
}

我希望这对某人有用