场景:创建一个节点API(GET),在socket.io节点服务器中调用该API,并在angular客户机中调用该套接字服务器。
我所做的:为get,request和post创建了一个节点API,并创建了一个套接字服务器,我试图使用这个应用程序。
问题:1。我尝试使用API,但无法获取套接字服务器和2中的数据。如果它的工作,也如何我可以得到插座的数据按钮点击角应用?
注意:我在3000服务器上运行节点API,在3001上运行套接字服务器。
下面是我的代码
3000端口上运行的节点api代码:
const express = require('express')
const bodyParser = require('body-parser');
const cors = require('cors');
const app = express()
const port = 3000
let books = [{
"isbn": "9781593275846",
"title": "Eloquent JavaScript, Second Edition",
"author": "Marijn Haverbeke",
"publish_date": "2014-12-14",
"publisher": "No Starch Press",
"numOfPages": 472,
}];
app.use(cors());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
app.post('/book', (req, res) => {
const book = req.body;
// output the book to the console for debugging
console.log(book);
books.push(book);
res.send('Book is added to the database');
});
app.get('/book', (req, res) => {
res.json(books);
});
app.listen(port, () => console.log(`Hello world app listening on port ${port}!`));
在3001上运行的Socket.IO服务器
var app = require('express')();
var http = require('http').createServer(app);
var io = require('socket.io')(http);
const apiUrl="http://localhost:3000/book"
io.on('connection', function (socket) {
socket.on('getBanners', function(data){
request.get(apiUrl,function (error, response, body){
console.log(body)
socket.emit('result', {res:JSON.parse(body)})
})
});
});
http.listen(3001, function(){
console.log('listening on *:3001');
});
注意:节点API服务器-->;socketio服务器(不是客户端)
我不建议按照你的设计。
除非有非常具体/重要的原因使socket.io服务器位于HTTP服务器之外的其他端口,否则我建议您从HTTP服务器本身升级socket.io服务器。
例如。
在bin/www
中:
const { initSocketIOServer } = require('../socket-server');
const port = normalizePort(process.env.PORT || '3001');
app.set('port', port);
/**
* Create HTTP server.
*/
const server = http.createServer(app);
initSocketIOServer(server);
在socket.server.js
中
module.exports.initSocketServer = (server) => {
io = require('socket.io')(server);
io.on('connection', (socket) => {
console.log('client connected');
socket.on('getBanners', (event) => {
// handle getBanners event here
});
});
};
但是,根据您的示例,如果确实需要向HTTP服务器发出请求以获取数据,则可能需要使用HTTP库:
socket.on('getBanners', (event) => {
http.get({
hostname: 'localhost',
port: 3000,
path: '/book',
agent: false // Create a new agent just for this one request
}, (res) => {
// Do stuff with response, eg.
const socketResponse = processBooks(book);
socket.emit('result', socketResponse);
});
});
您可以将任何节点包用于请求,如requesthttps://github.com/request/request here