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>