JavaScriptを有効にしてください

無料で使える WebSocket サーバー「Achex」

 ·  ☕ 3 分で読めます

無料で使える WebSocket サーバー「Achex」

無料で使える WebSocket サーバー「Achex」を使用してみました。
Achex

こちらは簡単に使用することが可能なのでチャットシステムなど簡単に作れそうです。
ただし、使用する際はフリーのサーバーなのでセキュリティが必要なものにはおすすめしません。

サンプル

簡単なチャットシステムです。
複数のブラウザで開けばチャットが出来ます。
また他に開いている人が居ればやり取りが出来ます。
古いログは表示されません。

サンプルソース

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<div id="id" style="width:100%;border:solid 1px #FFFFFF;"></div>
<input id="msg" type="text" style="width:80%;" value=""/> <button id="send" type="button" onclick="sendChat()">送信</button>
<div id="chat" style="width:100%;height:300px;border:solid 1px #FFFFFF;overflow:auto;"></div>
<script>
var chat = document.getElementById("chat");
// ID生成
var id = Math.random().toString(32).substring(2);
document.getElementById("id").innerHTML = 'ID : ' + id;
// WS接続(Achexへ接続)
ws = new WebSocket("wss://cloud.achex.ca/chat");
// WS接続
ws.onopen = e => {
  console.log('open');
  chat.innerHTML = 'You ID : ' + id + '(' + getDateTime() + ')';
  // 認証(auth, passwordは何でもOK)
	ws.send(JSON.stringify({"auth": "hoge", "password": "1234"}));
  // 
  ws.send(JSON.stringify({"to": "hoge", "id": id, "message": 'Login'}));
}
// メッセージ受信
ws.onmessage = e => {
  console.log('message');
  console.log(e);
  var obj = JSON.parse(e.data);
  if(obj.auth == 'OK'){
    // 認証OK
    return;
  }
  addChat(obj.id, obj.message);
}
// WS切断
ws.onclosed = e => {
  console.log('closed');
  ws.send(JSON.stringify({"to": "hoge", "id": id, "message": 'Logout'}));
}
// メッセージ送信
function sendChat(){
  let msgElem = document.getElementById("msg");
  let msg = msgElem.value;
  msgElem.value = "";
  ws.send(JSON.stringify({"to": "hoge", "id": id, "message": msg}));
}
// チャット
function addChat(id, msg){
  chat.innerHTML = id + ' : ' + msg + '(' + getDateTime() + ')' + '<br>' + chat.innerHTML;
}
// 1桁の数字を0埋めで2桁にする
var toDoubleDigits = function(num) {
  num += "";
  if (num.length === 1) {
    num = "0" + num;
  }
 return num;     
};
// 日時取得 YYYY/MM/DD HH:DD:MI:SS形式で取得
var getDateTime = function() {
  var date = new Date();
  var year = date.getFullYear();
  var month = toDoubleDigits(date.getMonth() + 1);
  var day = toDoubleDigits(date.getDate());
  var hour = toDoubleDigits(date.getHours());
  var min = toDoubleDigits(date.getMinutes());
  var sec = toDoubleDigits(date.getSeconds());
  return year + '/' + month + '/' + day + ' ' + hour + ':' + min + ':' + sec;
};
</script>

参考

共有

こぴぺたん
著者
こぴぺたん
Copy & Paste Engineer