Node調(diào)用Java的示例代碼
Java 端作為服務(wù)提供者,基于Dubbo 實(shí)現(xiàn)服務(wù)并通過 Dubbo Hessian 擴(kuò)展暴露服務(wù);Node 端作為服務(wù)消費(fèi)者,通過node-hessian 調(diào)用 Java 端的服務(wù)。
Java 端
服務(wù)接口
package com.yuanxin.paas.ssb;
public interface TestService {
/**
* 測(cè)試:無參,無返回值。
*/
void test();
/**
* 測(cè)試:原生類型參數(shù)與返回值。
*
* @param i
* @return
*/
String test0(int i);
/**
* 測(cè)試:無參,自定義類型返回值。
*
* @return
*/
Result test1();
/**
* 測(cè)試:自定義類型參數(shù),無返回值。
*
* @param arg
*/
void test2(Arg arg);
/**
* 測(cè)試:自定義參數(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
調(diào)用服務(wù)接口
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));
})
運(yùn)行結(jié)果
Java 端

Node 端

總結(jié)
Dubbo 非常贊,提供了對(duì) Hessian 原生協(xié)議的支持;Node 調(diào)用起來也非常簡(jiǎn)單,不過還是有幾個(gè)點(diǎn)需要注意一下:
- 接口方法不能重載(接口里的方法必須使用不同的方法名)
- 自定義類型的命名空間服務(wù)端與消費(fèi)端要一致(com.yuanxin.paas.ssb.Arg)
- 服務(wù)端自定義類型需要實(shí)現(xiàn)序列化接口(java.io.Serializable)
- 盡量使用簡(jiǎn)單的自定義類型結(jié)構(gòu)(避免嵌套)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
NodeJS感知和控制自身進(jìn)程的運(yùn)行環(huán)境和狀態(tài)
NodeJS可以感知和控制自身進(jìn)程的運(yùn)行環(huán)境和狀態(tài),也可以創(chuàng)建子進(jìn)程并與其協(xié)同工作,這使得NodeJS可以把多個(gè)程序組合在一起共同完成某項(xiàng)工作,并在其中充當(dāng)膠水和調(diào)度器的作用,和進(jìn)程管理相關(guān)的API單獨(dú)介紹起來比較枯燥,這里從一些典型的應(yīng)用場(chǎng)景出發(fā)2024-01-01
Node.js查找當(dāng)前目錄下文件夾實(shí)例代碼
本篇文章主要介紹了Node.js查找當(dāng)前目錄下文件夾實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-03-03
利用Node.js了解與測(cè)量HTTP所花費(fèi)的時(shí)間詳解
這篇文章主要給大家介紹了關(guān)于利用Node.js了解與測(cè)量HTTP所花費(fèi)的時(shí)間的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09
Restify中接入Socket.io報(bào)Error:Can’t set headers的錯(cuò)誤解決
這篇文章主要給大家介紹了在Restify中接入Socket.io報(bào)Error:Can’t set headers的錯(cuò)誤解決方法,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。2017-03-03
使用 Node.js 模擬滑動(dòng)拼圖驗(yàn)證碼操作的示例代碼
本篇文章主要介紹了使用 Node.js 模擬滑動(dòng)驗(yàn)證碼操作的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11

