У меня есть несколько вопросов относительно использования ввода-вывода сокета с PHP и тому подобного. Я новичок в nodejs / socket io, поэтому знаю очень мало, я только начал использовать его в последние несколько дней, и я перехожу к сути где я буду реализовывать это на своем веб-сайте (на данный момент я просто создаю небольшие тестовые примеры).
Вопрос: В настоящее время мне нужно добавить порт на свой локальный хост, чтобы просмотреть его и заставить его работать, очевидно, у меня не может этого быть, когда это действующий веб-сайт, и я также не могу этого сделать, когда использую php страницы (только что делал примеры с html). Если я использую порт 4000 для своего сервера socket io, мне нужно перейти на: localhost: 4000, однако мне нужно иметь возможность перейти на: localhost: 8888 / mysitefolder (8888 - это порт для моего MAMP, для php и всего остального) Я видел в вопросах, где люди решили эту проблему, но мне не удалось заставить его работать на себя.
Вот мой код:
chat.js
var app = require('express').createServer(),
io = require('socket.io').listen(app);
app.listen(4000);
var users = [];
app.get('/', function (req, res) {
res.sendfile(__dirname + '/index.html');
});
io.sockets.on('connection', function (socket) {
socket.emit('connected');
socket.on('userID', function (userID) {
users.push(userID);
});
socket.on('message', function (message) {
socket.broadcast.emit('message-response', { data: message});
});
});
index.html
<title>Testing</title>
<script src="/socket.io/socket.io.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script>
function mktime(){
var newDate = new Date;
return newDate.getTime();
}
function appendMessage(data)
{
$("body").append(data+"<br />");
}
var socket = io.connect('http://localhost:4000');
socket.on('connected', function () {
//select id from database in real environment
socket.emit("userID", mktime());
});
socket.on('message-response', function (message) {
appendMessage(message.data);
});
$(document).ready(function(){
$('#input').keypress(function(event) {
if (event.keyCode != 13) return;
var msg = $("#input").val();
if (msg) {
socket.emit('message', msg );
appendMessage(msg);
$("#input").val('').focus();
}
});
});
</script>
<body>
<input type="text" id="input"><br>
</body>