Maison > Java > javaDidacticiel > Cas dans lequel Java est appelé par Node

Cas dans lequel Java est appelé par Node

黄舟
Libérer: 2017-09-21 09:36:28
original
1968 Les gens l'ont consulté

Cet article présente principalement l'exemple de code permettant à Node d'appeler Java. L'éditeur pense que c'est plutôt bon, je vais donc le partager avec vous maintenant et le donner comme référence. Suivons l'éditeur pour y jeter un œil

Le côté Java sert de fournisseur de services, implémente des services basés sur Dubbo et expose les services via l'extension Dubbo Hessian, le côté Node agit en tant que consommateur de services, appelant les services côté Java via l'extension Dubbo Hessian. nœud-hessien.

Côté Java

Interface de service


package com.yuanxin.paas.ssb;
 
public interface TestService {
 
  /**
   * 测试:无参,无返回值。
   */
  void test();
   
  /**
   * 测试:原生类型参数与返回值。
   * 
   * @param i
   * @return 
   */
  String test0(int i);
   
  /**
   * 测试:无参,自定义类型返回值。
   * 
   * @return 
   */
  Result test1();
   
  /**
   * 测试:自定义类型参数,无返回值。
   * 
   * @param arg 
   */
  void test2(Arg arg);
   
  /**
   * 测试:自定义参数,自定义返回值。
   * 
   * @param arg
   * @return 
   */
  Result test3(final Arg arg);
}
Copier après la connexion

Classe de paramètres personnalisés


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;
  }
 
}
Copier après la connexion

Classe de valeur de retour personnalisée


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;
  }
 
}
Copier après la connexion

La configuration Dubbo est omise.

Côté nœud

node-hessian

Installer node-hessian :


npm install hessian-proxy
Copier après la connexion

Interface de service d'appel


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));
})
Copier après la connexion

Résultat d'exécution

Côté Java

Côté nœud

Résumé

Dubbo est très bon et prend en charge le protocole natif Hessian et est également très simple à appeler, mais il reste encore quelques points ; à surveiller Regardons :

  • Les méthodes d'interface ne peuvent pas être surchargées (les méthodes de l'interface doivent utiliser des noms de méthodes différents)

  • Type personnalisé service d'espace de noms Le client et le consommateur doivent être cohérents (com.yuanxin.paas.ssb.Arg)

  • Le type personnalisé côté serveur doit implémenter l'interface de sérialisation (java.io.Seriallessly )

  • Essayez d'utiliser des structures de type personnalisées simples (évitez l'imbrication)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal