如何解决使用 Ionic App 中的 STOMP 连接到 ActiveMQ 代理
我得到了一个 Ionic + Capacitor 应用程序,它将主要编译为在 Android 平台上运行。我的任务是将与远程 ActiveMQ 代理的通信集成到应用程序中。我使用 STOMP JS 库来实现这一点,当我在浏览器上测试它时,效果非常好。现在,当我在模拟器上测试时,应用程序无法连接到 ActiveMQ 代理。我相信这是因为浏览器支持开箱即用的 WebSockets,而模拟器无法理解 WS URL。我在网上读到我可以使用 SockJS 作为一个简单的解决方案,并且可以很容易地集成到我当前的代码中。我指的是以下教程:
https://stomp-js.github.io/guide/stompjs/rx-stomp/ng2-stompjs/using-stomp-with-sockjs.html
但是,当我按照说明添加教程中提供的回退代码时,我收到了 Typescript 编译器抛出的一个奇怪的错误。我的代码如下:
import {Client,Message,ActivationState,messageCallbackType} from '@stomp/stompjs'
//import StompJs,{ Message } from '@stomp/stompjs';
import { Queue } from 'queue-typescript';
import SockJS from 'sockjs-client';
const brokerEndpoint = "ws://localhost:61614";
//const brokerEndpoint = "ws://10.0.2.2:61614";
const items: string[] = [];
const queue = new Queue<string>(...items);
const createClient = () => {
const client: Client = new Client({
brokerURL: brokerEndpoint,connectHeaders: {
login: 'admin',passcode: 'admin',},debug: function (str) {
console.log(str);
},reconnectDelay: 1000,heartbeatIncoming: 0,heartbeatOutgoing: 0
});
client.webSocketFactory = new SockJS('http://localhost:61613/stomp');
/*
if (typeof WebSocket !== 'function') {
console.log("Not WebScoket");
// For SockJS you need to set a factory that creates a new SockJS instance
// to be used for each (re)connect
client.webSocketFactory = function () {
// Note that the URL is different from the WebSocket URL
return new SockJS('http://10.0.2.2:15674/stomp');
};
} else {
console.log("Still using websockets");
}
*/
return client;
}
const client: Client = createClient()
下面这行是抛出错误的地方:
client.webSocketFactory = new SockJS('http://localhost:61613/stomp');
编译器说“类型 'WebSocket' 不能分配给类型 '() => IStompSocket'。 类型 'WebSocket' 不匹配签名 '(): IStompSocket'。"
根据教程,看来我做对了。但是,Typescript 似乎认为存在一些不兼容。有没有人使用过 SockJS + STOMP 或我导入的任何库,并使其成功运行?任何线索将不胜感激!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。