javascript - 如何为在 Express 中运行的应用程序配置 SSL 证书?
问题描述
我正在尝试配置我创建的 Express 服务器,以传递 SSL 证书并从 http 转到 https。
我阅读了 Express 文档,但找不到解决方案。他们向我提出了一些东西,比如 Lets Encrypt,但它不支持 Node.js 我不知道我是否应该修改我已经修改以运行应用程序的 hosts 文件,或者我必须做什么。我看到了一个表格,但它只适用于 Unix 系统。我展示了我配置服务器文件的方式,以防他们可以帮助我,花了三天时间寻找没有成功的方法。我看到的不支持 Node.js。谢谢
我编辑问题:抱歉没有提供更多细节,问题是我的应用程序不在生产中,我的域是临时的:michaelgram.test。我认为 Lets Encrypt 不会授予我证书。我不知道还能做什么。问题是应用程序托管在本地,在我的计算机上
我再次编辑:原谅,忘了说我的目的是为一个应用程序创建证书,您可以在其中注册到 Facebook 并尝试我的同事提供的方法,但它没有奏效,感谢新的 facebook政策。如果您有其他想法,那么我的域名将是 michaelgram.test,谢谢并原谅不便,因为问题没有做好。
let express = require('express');
let aws = require('aws-sdk');
let multer = require('multer');
let multerS3 = require('multer-s3');
let ext = require('file-extension');
let cookieParser = require('cookie-parser');
let bodyParser = require('body-parser');
let expressSession = require('express-session');
let passport = require('passport');
let michaelgram = require('michaelgram-client');
let auth = require('./auth')
let config = require('./config');
let port = process.env.PORT || 5050;
let client = michaelgram.createClient(config.client);
let s3 = new aws.S3({
accessKeyId: config.aws.accessKey,
secretAccessKey: config.aws.secretKey
});
let storage = multerS3({
s3: s3,
bucket: 'michaelgram',
acl: 'public-read',
metadata: function (req, file, cb) {
cb(null, { fieldName: file.fieldname })
},
key: function (req, file, cb) {
cb(null, +Date.now() + '.' + ext(file.originalname))
}
});
let upload = multer({ storage: storage }).single('picture');
let app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(expressSession({
secret: config.secret,
resave: false,
saveUninitialized: false
}))
app.use(passport.initialize())
app.use(passport.session())
app.set('view engine', 'pug');
app.use(express.static('public'));
passport.use(auth.localStrategy);
passport.use(auth.facebookStrategy);
passport.deserializeUser(auth.deserializeUser);
passport.serializeUser(auth.serializeUser);
app.get('/', function (req, res) {
res.render('index', { title: 'Michaelgram' });
})
app.get('/signup', function (req, res) {
res.render('index', { title: 'Michaelgram - Signup' });
})
app.post('/signup', function (req, res) {
let user = req.body;
client.saveUser(user, function (err, usr) {
if (err) return res.status(500).send(err.message)
debugger
res.redirect('/signin');
});
});
app.get('/signin', function (req, res) {
res.render('index', { title: 'Michaelgram - Signin' });
})
app.post('/login', passport.authenticate('local', {
successRedirect: '/',
failureRedirect: '/signin'
}));
app.get('/auth/facebook', passport.authenticate('facebook', { scope: 'email' }));
app.get('/auth/facebook/callback', passport.authenticate('facebook', {
successRedirect: '/',
failureRedirect: '/signin'
}));
function ensureAuth (req, res, next) {
if (req.isAuthenticated()) {
return next()
}
res.status(401).send({ error: 'not authenticated' })
}
app.get('/api/pictures', function (req, res, next) {
let pictures = [ ];
setTimeout(function () {
res.send(pictures);
}, 2000)
});
app.post('/api/pictures', ensureAuth,function (req, res) {
upload(req, res, function (err) {
if (err) {
return res.send(500, "Error uploading file");
}
res.send('File uploaded');
})
})
app.get('/api/user/:username', (req, res) => {
const user = {
username: 'miguelito',
avatar: '',
pictures: [ ]
}
res.send(user);
})
app.get('/:username', function (req, res) {
res.render('index', { title: `Michaelgram - ${req.params.username}` });
})
app.get('/:username/:id', function (req, res) {
res.render('index', { title: `Michaelgram - ${req.params.username}` });
})
app.listen(port, function (err) {
if (err) return console.log('Hubo un error'), process.exit(1);
console.log('Michaelgram escuchando en el puerto 5050');
})
解决方案
准备好密钥和 crt 后,您只需参考它们启动应用程序。这些名称只是使用letsencrypt的默认命名。
var options = {
key: fs.readFileSync(__dirname + '/components/ssl/privkey.pem'),
cert: fs.readFileSync(__dirname + '/components/ssl/fullchain.pem')
};
server = require('https').createServer(options, app);
推荐阅读
- excel - 从 VBA Excel 中的列中获取随机值
- javascript - 如何收听 Chrome 扩展的 (Metamask) 按钮?
- r - R 中的 Keras:在多次训练后释放内存
- c# - 用于 cosmos db json 中嵌套对象的 Linq
- flutter - 父状态改变时播放动画的正确方法
- sql - 日期和时间转换为小时和分钟
- python - 我可以在没有其他 URL 请求的情况下从 Selenium 下载图像吗?
- excel - 为 Excel VBA 动态分配 CSV
- php - VS Code 中的 php 版本错误
- python - 使用 ipywidgets 启动/退出程序