tutoriel - xampp phpmyadmin




noeud Socket.io liens comment donnera dans le serveur pas localhost(wamp/xampp) (2)

Je suis nouveau à la session socket, mais j'ai appris comment cela fonctionnera dans wamp / xampp localhost. Mais quand je passe au serveur qui héberge. ça ne marchera pas.

<script src="http://localhost:3000/socket.io/socket.io.js"></script>

Au dessus de ce travail dans wamp / xampp. mais pas trouvé dans le serveur d'hébergement. Que dois-je donner sur src. Mon hébergement est comme: aaa.bbb.com et son port est 8803 ou bbb.com et son port est 8803.

J'ai essayé les moyens d'être inclus comme

<script src="/socket.io/socket.io.js"></script>
<script src="http://aaa.bbb.com:3000/socket.io/socket.io.js"></script>
<script src="http://bbb.com:3000/socket.io/socket.io.js"></script>

Mon code côté serveur est

var express = require('express');
var app = express();
var socket = require('socket.io');
var server = require('http').createServer(app);
server.listen(3000);
var io = socket.listen(server);
var async = require('async');
var mysql= require('mysql');
var pool  = mysql.createPool({
   host     : 'XXXXX',
   user     : 'XXXXX',
   password : 'XXXX',
   database:'XXXXX',
 });

 var chatserver=require('./chatserver.js');
 var chatpage=io.of('/as/chatRoom').authorization(function (handshakeData, callback) {
 console.dir(handshakeData);
 handshakeData.page = '/welcome/chatRoom';
 callback(null, true);
 }).on('connection', function (socket) {
   console.dir(socket.handshake.page);
   chatserver.getUserFeeds(chatpage,socket,io,pool,async);
});

Du côté serveur de l'index.js du noeud, vous aurez besoin de io, sur le serveur http

var 
app = require('express')(),
http = require('http').Server(app),
io = require('socket.io')(http);`

Je suis un guidon comme mon système de modèle, donc allez-y. Sur votre fichier de modèle de maison, vous allez ajouter

<script>
var socket = io.connect('http://bbb.com:3000');
   socket.on('connect', function(){
       socket.emit('authenticate', {data: "token"});
       socket.on('error', function(err){ alert(err); 
   });
   socket.on('unauthorized', function(err){
       alert("Disconnected");
       console.log("There was an error with the authentication:", err.message);
    });
    socket.on('disconnected', function() { alert('Disconnected') });
 });
 </script>

Cela fonctionne pour moi sur le serveur en direct.


Avec votre code:

var express = require('express');
var app = express();
var socket = require('socket.io');
var server = require('http').createServer(app);
server.listen(3000);
var io = socket.listen(server);

Le chemin de socket.io.js est:

http://127.0.0.1:3000/socket.io/socket.io.js

Vous devez utiliser javascript ou php.

Javascript:

(Dynamique js inclure)

var PORT = 3000;
var script = document.createElement("script");
script.type = "text/javascript";
script.src = "http://" + document.location.hostname + ":" + PORT + "/socket.io/socket.io.js";
script.onerror = function () {
    console.log("Socket.io: unfound.");
};
script.onload = function () {
    console.log("Socket.io: loaded.");
    // Your code here.
    // startSocketIO();
};

document.getElementsByTagName("head")[0].appendChild(script);
// <script type="text/javascript" src="http://127.0.0.1:3000/socket.io/socket.io.js"></script>

PHP:

<script src="http://<?=$_SERVER["SERVER_NAME"]?>:3000/socket.io/socket.io.js"></script>