Node調用Java的示例代碼
Java 端作為服務提供者,基于Dubbo 實現(xiàn)服務并通過 Dubbo Hessian 擴展暴露服務;Node 端作為服務消費者,通過node-hessian 調用 Java 端的服務。
Java 端
服務接口
package com.yuanxin.paas.ssb;
public interface TestService {
/**
* 測試:無參,無返回值。
*/
void test();
/**
* 測試:原生類型參數(shù)與返回值。
*
* @param i
* @return
*/
String test0(int i);
/**
* 測試:無參,自定義類型返回值。
*
* @return
*/
Result test1();
/**
* 測試:自定義類型參數(shù),無返回值。
*
* @param arg
*/
void test2(Arg arg);
/**
* 測試:自定義參數(shù),自定義返回值。
*
* @param arg
* @return
*/
Result test3(final Arg arg);
}
自定義參數(shù)類
package com.yuanxin.paas.ssb;
import java.io.Serializable;
public class Arg implements Serializable {
private int i;
public int getI() {
return i;
}
public void setI(int i) {
this.i = i;
}
}
自定義返回值類
package com.yuanxin.paas.ssb;
import java.io.Serializable;
public class Result implements Serializable {
private int i;
private String string;
public int getI() {
return i;
}
public void setI(int i) {
this.i = i;
}
public String getString() {
return string;
}
public void setString(String string) {
this.string = string;
}
}
Dubbo 配置略。
Node 端
node-hessian
npm install hessian-proxy
調用服務接口
var Proxy = require('hessian-proxy').Proxy;
var proxy = new Proxy('http://127.0.0.1:9098/test-provider/provider/com.yuanxin.paas.ssb.TestService', '', '', proxy);
proxy.invoke('test', null, function (err, reply) {
console.log('test: ' + reply);
});
proxy.invoke('test0', [25], function (err, reply) {
console.log('test0: ' + JSON.stringify(reply));
})
proxy.invoke('test1', null, function (err, reply) {
if (err) {
console.log('test1: ' + err);
}
console.log('test1: ' + JSON.stringify(reply));
})
var argForTest2 = {
i: 2
};
argForTest2.__type__ = 'com.yuanxin.paas.ssb.Arg';
proxy.invoke('test2', [argForTest2], function (err, reply) {
if (err) {
console.log('test2: ' + err);
}
console.log('test2: ' + JSON.stringify(reply));
})
var argForTest3 = {
i: 3
};
argForTest3.__type__ = 'com.yuanxin.paas.ssb.Arg';
proxy.invoke('test3', [argForTest3], function (err, reply) {
if (err) {
console.log('test3: ' + err);
}
console.log('test3: ' + JSON.stringify(reply));
})
運行結果
Java 端

Node 端

總結
Dubbo 非常贊,提供了對 Hessian 原生協(xié)議的支持;Node 調用起來也非常簡單,不過還是有幾個點需要注意一下:
- 接口方法不能重載(接口里的方法必須使用不同的方法名)
- 自定義類型的命名空間服務端與消費端要一致(com.yuanxin.paas.ssb.Arg)
- 服務端自定義類型需要實現(xiàn)序列化接口(java.io.Serializable)
- 盡量使用簡單的自定義類型結構(避免嵌套)
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Vue+Node服務器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞操作實例分析
這篇文章主要介紹了Vue+Node服務器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞操作,結合實例形式分析了node.js查詢MongoDB數(shù)據(jù)庫及vue前臺頁面渲染等相關操作技巧,需要的朋友可以參考下2019-12-12
利用Node.js和MySQL實現(xiàn)創(chuàng)建API服務器
這篇文章主要為大家詳細介紹了如何使用Node.js和MySQL創(chuàng)建API服務器的步驟,這也是從前端邁向全棧的一個開始,文中的示例代碼講解詳細,感興趣的小伙伴可以了解下2024-01-01
Node 搭建一個靜態(tài)資源服務器的實現(xiàn)
這篇文章主要介紹了Node 搭建一個靜態(tài)資源服務器的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-05-05

