- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在 js 和 java 之间建立网络套接字连接,但我得到了这个答案:
未捕获的 DOMException:尝试使用一个不可用或不再可用的对象
我是根据互联网上的一些样本做的。有人知道它会是什么吗?
项目名称为Teste-1
JS代码
var socket = null;
function init(){
socket = new WebSocket("wss://localhost:8080/Teste-1/task");
socket.onmessage = onMessage;
}
function onMessage(event){
var task = JSON.parse(event.data);
if(task.action === "add"){
document.getElementById("point").innerHTML += event.data;
}
}
function teste() {
var action = {
action: "add",
name: "Test",
description: "This is just a test"
};
socket.send(JSON.stringify(action));
}
window.onload = init;
HTML代码
<html>
<head>
<title>Test</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0"/>
</head>
<body>
<button onclick="teste()">Teste</button>
<div id="point"></div>
<script src="websocket.js"></script>
</body>
</html>
Java 代码
public class Task implements Serializable{
private static final long serialVersionUID = 1L;
private String name;
private String description;
public Task(){}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
}
@ServerEndpoint(value="/task")
public class TaskSocket {
@Inject
private TaskSessionHandler handler;
@OnOpen
public void open(Session session){
handler.addSession(session);
}
@OnClose
public void close(Session session){
handler.removeSession(session);
}
@OnError
public void onError(Throwable error){
Logger.getLogger(TaskSocket.class.getName()).log(Level.SEVERE, null, error);
}
@OnMessage
public void handleMessage(String message, Session session) {
try (JsonReader reader = Json.createReader(new StringReader(message))) {
JsonObject jsonMessage = reader.readObject();
if ("add".equals(jsonMessage.getString("action"))) {
Task task = new Task();
task.setName(jsonMessage.getString("name"));
task.setDescription(jsonMessage.getString("description"));
handler.addTask(task);
}
}
}
}
@ApplicationScoped
public class TaskSessionHandler {
//Each client connected to the application has its own session.
private final Set<Session> sessions = new HashSet<>();
private final Set<Task> tasks = new HashSet<>();
public void addSession(Session session) {
sessions.add(session);
for(Task task : tasks){
JsonObject addMessage = createJSON(task);
sendToSession(session, addMessage);
}
}
public void removeSession(Session session) {
sessions.remove(session);
}
public List<Task> getTasks(){
List<Task> list = new ArrayList<Task>(tasks);
return list;
}
public void addTask(Task e){
tasks.add(e);
JsonObject message = this.createJSON(e);
sendToAllConnectedSessions(message);
}
private JsonObject createJSON(Task task){
JsonProvider provider = JsonProvider.provider();
JsonObject message = provider.createObjectBuilder()
.add("action", "add")
.add("name",task.getName())
.add("description",task.getDescription()).build();
return message;
}
private void sendToAllConnectedSessions(JsonObject message) {
for (Session session : sessions) {
sendToSession(session, message);
}
}
private void sendToSession(Session session, JsonObject message) {
try {
session.getBasicRemote().sendText(message.toString());
} catch (IOException ex) {
sessions.remove(session);
Logger.getLogger(TaskSessionHandler.class.getName()).log(Level.SEVERE, null, ex);
}
}
}
最佳答案
由于在与 webSocket 服务器的连接建立和打开之前执行了 websocket.send(),我收到了相同的错误消息。
我的贡献是建议确保在连接打开之前不发送消息,以便服务器实际上可以接收它们。
不过,我无法判断这是否是所提问题中的问题。然而,我遇到了一个非常相似的问题并最终来到这里,并想分享对我有用的东西。
在我的例子中,不起作用的代码如下所示:
const exampleSocket = new WebSocket('wws://example')
exampleSocket.onopen = function (event) {
console.log('connection is open!')
}
exampleSocket.send(JSON.stringify(msg))
exampleSocket.onmessage = function (event) {
console.log('message event data looks like this: ', event.data)
}
起作用的是将发送消息的代码移到 onopen 回调函数中。
const exampleSocket = new WebSocket('wws://example')
exampleSocket.onopen = function (event) {
console.log('connection is open!')
exampleSocket.send(JSON.stringify(msg)) // <- this is the change
}
exampleSocket.onmessage = function (event) {
console.log('message event data looks like this: ', event.data)
}
旁注:websocket 的 readyState 属性在处理确保服务器准备好接收消息时可能很有用。
如果为1,表示连接打开,可以这样使用:
if (exampleSocket.readyState === 1) {
console.log("It is safe to send messages now")
}
关于javascript - Javascript 和 Java 的 Web 套接字问题 - 未捕获的 DOMException : An attempt was made to use an object that is not, 或不再可用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64488266/
我正在尝试使用 Google 的 Material 设计。 我在下面有一个组件,其路径是 epimss_design/lib/component/menu/main-menu-form.html; e
我在导航文档对象以删除特定节点时遇到 DOMException.HIERARCHY_REQUEST_ERR,在谷歌搜索此错误代码后,它说: “HIERARCHY_REQUEST_ERR:如果此节点的类
我已经使用 React JS 为 service worker 注册了 JS 文件。但是,当我尝试注册 periodic-background-sync 时出现错误。我需要在谷歌浏览器中进行任何设置吗
我在 Polymer 2 中有一个简单的 todo aap。它工作得很好,但是当我从 Polymer 目录添加元素时,我收到以下错误?还有纸张输入不能正常显示?检查屏幕截图。一切都很好我不知道为什么这
我一直在查询 websql 数据库表。在这里,插入和删除语句工作正常。 但是当我尝试执行 findAll 查询时,本质上是'select * from myTable',它返回一个带有 DOMExce
我刚刚动态创建了视频对象,然后在将视频对象附加到文档中之前添加了 2 个属性,例如 source 和 muted,最后使用方法 play() 播放添加的视频,如下所示。 let v = documen
在“我的应用程序”中,我想将节点从一个文档复制到另一个文档。 这是代码。 Element entryElement, operationElement; for (int i = 0; i < eve
我正在尝试通过替换其中的某些元素来使用 DOM 修改 XML 文档,但出现以下异常: 03-10 10:49:20.943: W/System.err(22584): org.w3c.dom.D
我正在使用 native-crypto 包,它是一个用于跨平台加密的 API(例如 web 和 node.js)。 let crypto = require("native-crypto"); 我已经
Chrome 会阻止自动播放音频/视频。我找到了自动播放视频的解决方案,但我的用例需要自动播放音频。这是我的代码: let audio = new Audio('music/test.mp3'); a
我正在尝试加载音频,但遇到了两个错误,但是一切都很好,并且来源是正确的。 错误: GET http:// localhost:4200 / src / assets / sound / welcome
每当我运行此代码时 var blob = new Blob(["ninja.mp3"], {type:"audio/mp3"}); var audio = new Audio(URL.createOb
我正在尝试使用 C3 在我的 React 项目中呈现图表。 问题 我所做的是动态生成一个 id (UUID) 并将其附加到我的图表组件中的 div。然后,在组件在 componentDidMount
您好,我在 Chrome 中播放音频时遇到异常。 这是我播放音频的功能 $(document).ready(function () { generateAlarm(); }); functio
我正在开发一个 WebAudio 应用程序,它需要 AudioWorklets 并且需要来自许多不同脚本的函数以用于 process() 函数。因此,我尝试使用 import 命令在 processo
我正在学习本教程,该教程教授 polymer 元件的安装: https://www.polymer-project.org/3.0/start/toolbox/add-elements 运行 npm
我有Video Player 。但是当我改变质量时它给出了这个错误 Uncaught (in promise) DOMException: The play() request was interru
我正在尝试将加密数据从服务器发送到客户端,并使用window.crypto.subtle.decrypt()对其进行解密。但我有一个没有描述的错误。我该如何修复它? node.js 服务器代码: co
我收到这个错误: Uncaught (in promise) DOMException: lockOrientation() is not available on this device. co
我正在使用 indexedDB(通过 npm 的 idb 包装器)来存储表示音频 channel 数据的 2D Float32 数组。它在一段时间内工作正常,但是,当其中一个数组的长度达到大约 166
我是一名优秀的程序员,十分优秀!