Node.js + Socket IO + Apache + PHP удалить порт из url?

У меня есть несколько вопросов относительно использования ввода-вывода сокета с 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>
5
задан Dylan Cross 20 December 2011 в 18:10
поделиться