express 配置 https 服务

1、将下载解压后包含.key和 .pem 两个文件的文件夹上传到自己的项目中。

2、将以下代码复制粘贴到www文件中,https端口根据需求自己修改 

#!/usr/bin/env node

/**
 * Module dependencies.
 */

var app = require('../app');
var debug = require('debug')('test:server');
var http = require('http');

//增加
var http = require('http');
var fs = require('fs')
var https = require('https')
var path = require('path')
var express = require('express')
//增加

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

//增加
const options = {
  key: fs.readFileSync(path.join(__dirname, '../mybird.cloud.key')),
  cert: fs.readFileSync(path.join(__dirname, '../mybird.cloud_bundle.pem'))
}
app.set('porthttps',443)  
//增加

var port = normalizePort(process.env.PORT || '80');
app.set('port', port);

/**
 * Create HTTP server.
 */

var server = http.createServer(app);

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

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

//增加
https.createServer(options,app).listen(app.get('porthttps'),function(){
  console.log('443端口运行');
})
//增加

/**
 * 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();
  var bind = typeof addr === 'string'
    ? 'pipe ' + addr
    : 'port ' + addr.port;
  debug('Listening on ' + bind);
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Express上启用HTTPS服务,需要执行以下步骤: 1. 生成SSL证书 可以使用openssl命令生成自签名SSL证书。在终端中输入以下命令: ``` openssl req -nodes -new -x509 -keyout server.key -out server.cert ``` 这将生成一个名为“server.key”的私钥文件和一个名为“server.cert”的自签名SSL证书文件。 2. 在Express配置HTTPSExpress中,我们需要使用Node.js内置的https模块来启用HTTPS服务。首先,我们需要引入https模块: ``` const https = require('https'); ``` 接下来,在创建Express应用程序之前,我们需要将SSL证书和私钥加载到内存中: ``` const fs = require('fs'); const privateKey = fs.readFileSync('server.key', 'utf8'); const certificate = fs.readFileSync('server.cert', 'utf8'); const credentials = {key: privateKey, cert: certificate}; ``` 然后,我们可以像通常一样创建Express应用程序: ``` const express = require('express'); const app = express(); ``` 最后,我们可以使用https模块的createServer方法来创建HTTPS服务器并将其连接到Express应用程序: ``` const httpsServer = https.createServer(credentials, app); httpsServer.listen(443, () => { console.log('HTTPS Server running on port 443'); }); ``` 这将启动一个HTTPS服务器,并在端口443上监听传入的请求。 完整的Express应用程序代码如下所示: ``` const https = require('https'); const fs = require('fs'); const privateKey = fs.readFileSync('server.key', 'utf8'); const certificate = fs.readFileSync('server.cert', 'utf8'); const credentials = {key: privateKey, cert: certificate}; const express = require('express'); const app = express(); app.get('/', (req, res) => { res.send('Hello World!'); }); const httpsServer = https.createServer(credentials, app); httpsServer.listen(443, () => { console.log('HTTPS Server running on port 443'); }); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值