使用 AngularJS 向 KDB+ 进程发送 HTTP GET 请求

use*_*583 2 javascript web-applications kdb angularjs

我正在使用 AngularJS 开发一个网络应用程序,但我对此非常缺乏经验。

我的目标是让用户在文本字段中键入一些参数,然后使用该参数作为 GET 请求中的参数之一发送 GET 请求(使用 Angular 中的 $http 服务)。

请求的目标是 KDB+ 进程(来自 KX Systems 的专有列导向数据库/语言)。此过程可以采用以下形式的请求:

http://servername:1234/?queryToRunHere[paramFromApp]
Run Code Online (Sandbox Code Playgroud)

此调用应返回一个 JSON 字符串。由于网络服务器和此进程在不同端口上运行,我收到“Access-Control-Allow-Origin”错误,该错误阻止我将此查询运行到其他端口。我试图使用 $http.jsonp 命令(因为我读到它允许远程获取)但是这要求我提供一个“&callback”参数。这是不可能的,因为 KDB+ 将解释“?”右侧的所有内容。作为内部查询。

我不确定如何继续,但到目前为止,这些是我的想法:

  1. KDB+ 为 Java 提供了一个 API(但就我所知的 JavaScript 而言不是这样)。也许我可以用 Java 编写某种 Web 服务,然后可以通过 angular 调用它,然后使用其原生 API 调用 KDB+。问题在于它创建了另一个要维护的程序,而且我不确定如何编写这样的服务(什么技术、框架等)。

  2. 在 Angular 中有另一种我不知道的方法,或者有一种方法不必在 $http.jsonp 中指定回调参数。

我将不胜感激任何帮助。

J.P*_*ong 5

Access-Control-Allow-Origin由于浏览器内置的同源策略,您会收到错误消息。默认情况下,当您的 JavaScript 和服务器 API 并非源自相同的server:port. 要解决此问题,您需要Access-Control-Allow-Origin在来自服务器的 HTTP 响应的标头中指定。

要在 KDB/Q 中完成此操作,请执行以下操作:

.z.ph:{ "\r\n" sv ("HTTP/1.1 200 OK"; "Access-Control-Allow-Origin: *"; 
"Content-Type: application/json"; ""; (.j.j select from aTable)) }
Run Code Online (Sandbox Code Playgroud)