【发布时间】:2019-12-15 20:45:13
【问题描述】:
我想用 Angular 和 Socket.io 写一个聊天。一切都在本地机器上运行。但是在远程 Node.js 上,它不处理请求并且不连接到 Socket,尽管我通过 SSH 运行它。也许我做错了什么?我是新手。请帮忙。我已经为此坐了 10 个小时。我会说更多,也许这很重要。当我从 localhost:3000 上的远程站点打开 Socket 时,一切都在本地计算机上运行(尽管这很合乎逻辑)。
服务器部分
const cors = require('cors');
const express = require('express');
const app = express();
const server = require('http').createServer(app);
server.listen(3000);
const io = require('socket.io')(server);
app.use(cors());
let connections = [];
io.on('connection', (socket) => {
connections.push(socket);
console.log('Connect');
console.log(connections.length);
socket.on('disconnect', (data) => {
connections.splice(connections.indexOf(socket), 1);
console.log('Disconnect');
console.log(connections.length);
})
socket.on('send mess', (obj) => {
console.log(obj);
io.sockets.emit('add mess', obj);
})
});
角度服务
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable, Subscriber } from 'rxjs';
import * as io from 'socket.io-client';
import * as $ from 'jquery';
@Injectable({
providedIn: 'root'
})
export class WhiteServiceService {
socket: any;
readonly url: string = 'ws://whitefox.website:3000/';
constructor(private http: HttpClient) {
this.socket = io(this.url);
}
postMessage(message: {}) {
this.socket.emit('send mess', message);
}
white() {
this.socket.on('add mess', (data) => {
$('ul').append('<li>'+data.name +': ' + data.message + '</li><br>');
})
}
}```
Angular 客户端
import { Component, OnInit } from '@angular/core';
import { FormBuilder, Validators } from '@angular/forms';
import { WhiteServiceService } from '../white-service.service';
import * as $ from 'jquery';
@Component({
selector: 'app-chat',
templateUrl: './chat.component.html',
styleUrls: ['./chat.component.css']
})
export class ChatComponent implements OnInit {
messageValue: string = "Hi";
number: number;
constructor(private fb: FormBuilder, private sendMessageServise: WhiteServiceService) { }
messageForm = this.fb.group({
name: ['name', Validators.required],
message: ['message', Validators.required]
})
sendMessage() {
this.messageValue = null;
this.sendMessageServise.postMessage(this.messageForm.value);
}
ngOnInit() {
this.sendMessageServise.white();
}
}
【问题讨论】:
-
您确定端口 3000 为您的服务器打开了吗?
-
原来没有,也不知道怎么打开。灶神星CP。一旦我没有尝试过
标签: javascript