【发布时间】:2012-02-29 13:30:34
【问题描述】:
我创建了一个简单的appmod,它会在收到的消息时发回相同的消息。但是我在命令提示符下收到一条错误消息,并且 WebSocket 连接已关闭。
如果我发送带有 3 个字符的消息,我会收到以下错误消息:
=ERROR REPORT==== 8-Feb-2012::05:09:14 ===
Error in process <0.59.0> with exit value: {undef,[{mywebsocket,handle_message,[
{text,<<3 bytes>>}],[]},{lists,map,2,[{file,"lists.erl"},{line,1173}]},{yaws_web
sockets,loop,4,[{file,"yaws_websockets.erl"},{line,151}]}]}
我做错了什么?句柄使用text,如果我使用binary也不起作用。
这是我的 HTML+JavaScript 客户端:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<script>
window.onload = function() {
document.getElementById('sendbutton').addEventListener('click', sendMessage, false);
document.getElementById('connectbutton').addEventListener('click', connect, false);
document.getElementById('disconnectbutton').addEventListener('click', disconnect, false);
}
function writeStatus(message) {
var html = document.createElement("div");
html.setAttribute("class", "message");
html.innerHTML = message;
document.getElementById("status").appendChild(html);
}
function connect() {
ws = new WebSocket("ws://localhost:8090/ws.yaws");
ws.onopen = function(evt) {
writeStatus("connected");
}
ws.onclose = function(evt) {
writeStatus("disconnected");
}
ws.onmessage = function(evt) {
writeStatus("response: " + evt.data);
}
ws.onerror = function(evt) {
writeStatus("error: " + evt.data);
}
}
function disconnect() {
ws.close();
}
function sendMessage() {
var msg = document.getElementById('messagefield').value
ws.send(msg);
}
</script>
</head>
<body>
<h1>Chat</h1>
<button id="connectbutton">Connect</button>
<button id="disconnectbutton">Disconnect</button><br/>
<input type="text" id="messagefield"/><button id="sendbutton">Send</button>
<div id="status"></div>
</body>
</html>
我的ws.yaws 从客户端调用连接 看起来像这样:
<erl>
out(A) -> {websocket, mywebsocket, []}.
</erl>
我的回调 appmod mywebsocket.erl 看起来像这样:
-module(mywebsocket).
-export([handle_message/1]).
handle_message({text, Message}) ->
{reply, {text, Message}}.
在yaws.conf我已经这样配置了服务器:
<server localhost>
port = 8090
listen = 0.0.0.0
docroot = "C:\Users\Jonas/yawswww"
appmods = <ws, mywebsocket>
</server>
我使用 Yaws 1.92 和 Chrome 16。
【问题讨论】: