既然这篇文章用的是nodejs和Java访问远程服务器的服务,那么咱们先用另一门编程语言,SAP的ABAP(我日常工作使用得最多的编程语言)来开发一个服务吧。
这是我用ABAP编程语言实现服务的类:ZCL_DIS_HTTP_HANDLER
这个类实现了一个接口IF_HTTP_EXTENSION里定义的一个方法HANDLE_REQUEST.
大家可以不用被ABAP陌生的语法所迷惑,其实和Java的Servlet是相通的。
我画了张图:
我的这个远程服务很简单,就是无论调用者发送什么,都简单地返回一个文本:HELLO WORLD。
现在我们就分别用nodejs和Java去消费。
nodejs
看下nodejs代码。
下面的代码传入Buffer的WANGJER为我的用户名,123456为密码。使用的登录方式是Basic Authentication。
var request = require('request');
var getTokenOptions = {
url: "https://<此处填入您的远程服务器上的服务地址url",
method: "GET",
headers: {
'Authorization': 'Basic ' + new Buffer("WANGJER:123456").toString('base64')
}
};
function getToken() {
return new Promise(function(resolve,reject){
var requestC = request.defaults({jar: true});
console.time("Remote");
requestC(getTokenOptions,function(error,response,body){
console.log("response body: " + body);
console.timeEnd("Remote");
resolve(response);
});
});
}
getToken().then(function(response) {
});
执行结果:算上网络开销总共花了1.4秒。
java
下面代码的WANGJER为我的用户名,123456为密码。使用的登录方式是Basic Authentication。
package connectivity;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import org.apache.commons.codec.binary.Base64;
import java.util.stream.Collectors;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.HttpClientBuilder;
public class OPSystemConnectivity
{
static public void main(String[] arg){
final HttpGet get = new HttpGet("https://<您远程服务器的url");
HttpClient httpClient = HttpClientBuilder.create().build();
String raw = "WANGJER:123456";
String encoded = Base64.encodeBase64String(raw.getBytes());
get.setHeader("Authorization", "Basic " + encoded);
HttpResponse response;
try {
long start = System.currentTimeMillis();
response = httpClient.execute(get);
InputStream stream = response.getEntity().getContent();
String result = new BufferedReader(new InputStreamReader(stream)).lines()
.parallel().collect(Collectors.joining(" "));
System.out.println("response: " + result);
stream.close();
long end = System.currentTimeMillis() - start;
System.out.println("time consumed: " + end );
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException | UnsupportedOperationException e) {
e.printStackTrace();
}
}
}
执行结果,耗时和nodejs差不多。
注意,用本文介绍的方法不仅能访问远程服务器的服务,也能达到资源下载的目标:比如下载某服务器上的图片,mp3等。只需要把对应资源的url传入系统即可。
要获取更多Jerry的原创技术文章,请关注公众号"汪子熙"或者扫描下面二维码:
相关推荐
标题中的“nodejs使用原生的dubbo协议打通了dubbo的rpc方法调用”意味着在Node.js环境中,开发者成功地实现了对Dubbo服务的RPC(远程过程调用)访问,利用了Dubbo协议的特性。Dubbo是阿里巴巴开源的一个高性能、轻量...
它以其酷炫的界面和高逼格的设计,为DevOps、运维和网络管理员提供了一种现代化的监控解决方案,特别适用于需要对多服务器进行远程监控的场景。 1. **Node.js技术基础**: ServerMmon利用Node.js的非阻塞I/O和事件...
4. **日志管理**:如何配置log4js,设置不同级别的日志输出,以及如何将日志写入文件或发送到远程服务器。 5. **错误处理**:在服务端遇到错误时的捕获和处理机制,以确保程序的稳定运行。 6. **安全性**:可能涉及...
2. **API 使用**:在Android应用中,WebRTC API 提供了关键功能,如获取本地媒体流(getUserMedia),创建RTCPeerConnection对象以处理信令和媒体流,以及添加本地和远程轨道(addStream和addTrack)。 3. **信令...
- **WebSocket**:为了实现双向实时通信,Node.js可能使用WebSocket协议,它提供了一种在客户端和服务器之间持续开放的连接,使数据能够即时双向传输。 3. 实现流程 - 用户A和B打开网页,通过浏览器访问Node.js...
在Ktrader中,Java可能用于构建高性能的服务器端,处理大量并发请求,确保交易系统的稳定性和安全性。 3. **PHP**:PHP通常用于Web开发,其与MySQL数据库的良好集成使其在构建后端服务时具有优势。在Ktrader系统中...
这样,整个被染色的服务访问路径会被单独记录日志,方便后续的日志分析和问题定位。 总的来说,TAF作为腾讯内部的微服务框架,不仅在技术上具有先进性和高性能的特点,而且在实际的生产环境中提供了完善的服务治理...
Jaguar数据库使用手册介绍了如何使用和管理分布式数据库系统Jaguar。Jaguar数据库采用的是分布式架构设计,支持多种编程语言和操作系统的运行环境。以下是手册中提及的知识点汇总: 1. 安装环境:Jaguar数据库安装...
Node.js是一个JavaScript运行环境,基于Chrome V8引擎,用于构建服务器端和网络应用。安装这个版本的Node.js,可以执行msi文件,按照向导步骤操作。Node.js是运行elasticsearch-head的必要条件,因为elasticsearch-...
此系统基于JSP(Java Server Pages)技术开发,结合SQL 2000数据库,采用B/S(Browser/Server,浏览器/服务器)架构,实现了宿舍管理的网络化。 在系统需求阶段,首要任务是对学生公寓管理的需求进行深入理解,包括...
7. **Go**:Go(又称Golang)是Google推出的一种静态类型的编程语言,设计目标是简化开发过程,提高效率,尤其适用于并发编程和网络服务。 8. **Linux**:Linux是一种自由和开放源码的操作系统内核,是许多服务器和...