簡體   English   中英

從 React 頁面遠程訪問 Node 服務器

[英]Accessing Node server remotely from React page

我在前端使用 Create React App 創建了一個站點,在后端使用 Node express 創建了一個站點。 然后,我在 IIS 上托管了 React,並在后端將 Node 作為 windows 服務運行。

運行應用程序時,我將 React (REACT_APP_HOST) 中的回調路徑設置為“localhost”,在節點中我的路由是“/routeName”。 這就是說,第一個調用的路徑是${REACT_APP_HOST}/sitemap並且服務器上的接收路徑是router.use('/siteMap', (req, res, next) => siteMapController(req, res, next)); .

在本地服務器上,將其用作客戶端,效果很好。 在遠程客戶端(同一域)上,我收到 404 錯誤。

我嘗試的下一步是將 REACT_APP_HOST 更改為“”,從而調用“/sitemap”。 這甚至在本地主機上也停止了運行。

這是我的代碼(app.js、站點地圖獲取和 server.js)。 希望有人能給我一個線索,告訴我哪里出錯了。

//app.js

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser')
var logger = require('morgan');
var cors = require('cors');
var nodeSSPI = require('express-node-sspi');
let routeList = require('./routes/routeList');
let FileLoader = require('./Controllers/FileLoader');

var app = express();

app.use(bodyParser.json({ limit: '400000' }));
app.use(cors({
  origin:['http://localhost', 'http://intranet-test', 'http://intranet'],
  credentials: true
}));
app.use(express.static(path.join(__dirname,'../public')));
app.options('*', cors()); // include before other routes
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');

//https://www.npmjs.com/package/yarn 
app.use(nodeSSPI({
  retrieveGroups: false,
  offerBasic: false,
  authoritative: true,

}));

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

routeList(app);

// catch 404 and forward to error handler
app.use(function (req, res, next) {
  console.log(req.originalUrl);
  console.log(req.method)
  next(createError(404));
});

// error handler
app.use(function (err, req, res, next) {
  console.log(err);
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;
//sitemap fetch
export const fetchInit = () => {
    return ({
        method: 'GET'
        , headers: {
            'Content-Type': 'application/json'
        }
        , credentials: 'include'
    })
};

export const Sitemap_Fetch = () => (dispatch) => {
    dispatch({
        type: ActionTypes.SITEMAP_LOADING
    });
    var myReq = new Request(`${process.env.REACT_APP_HOST}/siteMap`, fetchInit());//?' + params

    return fetch(myReq)
        .then((response) => {
            // if (response.ok) {
            return response;
            // }
            // else {
            //     var error = new Error("Error " + response.statusText);
            //     error.response = response;
            //     throw error;
            // }
        },
            (error) => {
                var err = new Error(error.message);
                throw err;
            }
        )
        .then(response => response.json())
        .then((data) => {
            try {
                dispatch({
                    type: ActionTypes.SITEMAP_LOADED,
                    payload: data
                })
                return data;
            }
            catch (ex) { throw ex }
        })
        .catch((err) => {
            return dispatch({
                type: ActionTypes.SITEMAP_FAILED,
                payload: err.message
            })
        });
}
//server.js
#!/usr/bin/env node

/**
 * Module dependencies.
 */

var app = require('./app');
var debug = require('debug')('node-backend:server');
var http = require('http');


/**
 * Get port from environment and store in Express.
 */

var port = normalizePort('3000');
app.set('port', port);

/**
 * Create HTTP server.
 */

var server = http.createServer(app);

/**
 * Listen on provided port, on all network interfaces.
 */

server.listen(port, '0.0.0.0');
server.on('error', onError);
server.on('listening', onListening);
server.on('request',test=>{console.log(test)})
/**
 * Normalize a port into a number, string, or false.
 */

function normalizePort(val) {
  var port = parseInt(val, 10);

  if (isNaN(port)) {
    // named pipe
    return val;
  }

  if (port >= 0) {
    // port number
    return port;
  }

  return false;
}

/**
 * Event listener for HTTP server "error" event.
 */

function onError(error) {
  if (error.syscall !== 'listen') {
    throw error;
  }

  var bind = typeof port === 'string'
    ? 'Pipe ' + port
    : 'Port ' + port;

  // handle specific listen errors with friendly messages
  switch (error.code) {
    case 'EACCES':
      console.error(bind + ' requires elevated privileges');
      process.exit(1);
      break;
    case 'EADDRINUSE':
      console.error(bind + ' is already in use');
      process.exit(1);
      break;
    default:
      throw error;
  }
}

/**
 * Event listener for HTTP server "listening" event.
 */

function onListening() {
  var addr = server.address();
  console.log(addr)
  var bind = typeof addr === 'string'
    ? 'pipe ' + addr
    : 'port ' + addr.port;
  debug('Listening on ' + bind);
  console.log('Listening on ' + bind);
}

最后,我從我的 React 站點添加了 .env 文件

BROWSER=none
SKIP_PREFLIGHT_CHECK=true
REACT_APP_HOST=http://localhost
PORT=80

這按原樣工作。 當我將 REACT_APP_HOST 更改為 nothing 時,它停止運行。

謝謝。

我為解決此問題所做的工作是使用簡單批處理文件中的 serve ( https://stackoverflow.com/a/49209041/2242131 ) 命令並從另一批處理運行我的節點后端。 然后在 React 中我創建了一個名為“主機名”的常量,我將其設置為${window.location.hostname}:3000 現在,這一直在為我的頁面提供必要的數據。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM