2016-12-14 1 views
0

익스프레스로 실행되는 앵귤러 2 애플리케이션이 있으며 모든 요청 http를 https로 리디렉션하고 싶습니다. 웹에서 일부 자습서를 따르지만 아무도 작동하지 않았습니다.모든 요청을 HTTP로 리디렉션

내 응용 프로그램은 Heroku에서 호스팅됩니다.

내가 표현을위한 두 개의 구성 파일이 있습니다

서버/

import * as express from 'express'; 
import { json, urlencoded } from 'body-parser'; 
import * as path from 'path'; 
import * as cors from 'cors'; 
import * as compression from 'compression'; 

const app: express.Application = express(); 

app.disable('x-powered-by'); 

app.use(json()); 
app.use(compression()); 
app.use(urlencoded({ extended: true })); 

if (app.get('env') === 'production') { 

// in production mode run application from dist folder 
app.use(express.static(path.join(__dirname, '/../client'))); 
} 

// catch 404 and forward to error handler 
app.use(function(req: express.Request, res: express.Response, next) { 
let err = new Error('Not Found'); 
next(err); 
}); 

// production error handler 
// no stacktrace leaked to user 
app.use(function(err: any, req: express.Request, res: express.Response, next: express.NextFunction) { 

    res.status(err.status || 500); 
    res.json({ 
    error: {}, 
    message: err.message 
    }); 
}); 

export { app } 

서버/빈은/여기

#!/usr/bin/env node 

/** 
* Module dependencies. 
*/ 

import { app } from '../app'; 
import { serverPort } from '../config'; 
import * as http from 'http'; 

/** 
* Get port from environment and store in Express. 
*/ 
const port = normalizePort(process.env.PORT || serverPort); 
app.set('port', port); 


/** 
* Create HTTP server. 
*/ 
const server = http.createServer(app); 

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

server.listen(port); 
server.on('error', onError); 
server.on('listening', onListening); 

/** 
* Normalize a port into a number, string, or false. 
*/ 

function normalizePort(val): boolean | number { 

    const normalizedPort = parseInt(val, 10); 

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

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

    return false; 
} 

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

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

    const 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() { 
    const addr = server.address(); 
    const bind = typeof addr === 'string' 
    ? 'pipe ' + addr 
    : 'port ' + addr.port; 
    console.log('Listening on ' + bind); 
} 

답변

0

을 www.ts 내가 nodeJS를 사용하여 한 방법이다 app.ts :

var app = express(); 
var httpapp = express(); 
options = { 
     key: fs.readFileSync('.key'), 
     cert: fs.readFileSync('.crt'), 
     requestCert: true 
} 

var http = require('http').createServer(httpapp); 
var server = require('https').createServer(options, app); 
var port = process.env.PORT || 3000; 

//Redirect http to https 

httpapp.get('*', function(req, res) { 
     res.redirect('https://127.0.0.1:' + port + req.url) 
}); 

Heroku에 앱을 배포하는 것에 익숙하지 않지만, 나는 상상할 것이다. 이것은 비슷한 과정이 될 것이다. 나는 두 가지 표현식 앱이 필요하다면 100 % 확신하지는 않지만 어쨌든 http와 https를 추가했습니다.

+0

답장을 보내 주셔서 감사합니다. 시도했지만 타이프 스크립트를 올바르게 구현하지 않았습니다. –

+0

죄송합니다. 도움이 될 수 없습니다. –

관련 문제