要在本地主机上使用自签名证书进行客户端身份验证,可以使用以下步骤和代码示例:
openssl req -newkey rsa:2048 -nodes -keyout server.key -x509 -days 365 -out server.crt
这将生成一个名为server.key的私钥文件和一个名为server.crt的自签名证书文件。
const https = require('https');
const fs = require('fs');
const options = {
key: fs.readFileSync('server.key'),
cert: fs.readFileSync('server.crt'),
requestCert: true,
rejectUnauthorized: false // 忽略证书验证(仅限开发环境)
};
https.createServer(options, (req, res) => {
if (req.client.authorized) {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('Hello, authorized client!\n');
} else {
res.writeHead(401, { 'Content-Type': 'text/plain' });
res.end('Sorry, unauthorized client.\n');
}
}).listen(443);
const https = require('https');
const fs = require('fs');
const options = {
hostname: 'localhost',
port: 443,
path: '/',
method: 'GET',
ca: fs.readFileSync('server.crt')
};
const req = https.request(options, (res) => {
res.on('data', (data) => {
process.stdout.write(data);
});
});
req.end();
请确保将server.crt证书文件复制到客户端代码示例的目录中。
现在,当您运行服务器代码示例时,它将在本地主机的443端口上创建一个HTTPS服务器。然后,当您运行客户端代码示例时,它将发送一个HTTPS请求到服务器,并使用自签名证书进行服务器身份验证。
注意:上述示例中的证书和私钥文件是使用openssl生成的自签名证书和私钥。在实际生产环境中,您可能需要使用受信任的证书颁发机构(CA)签署的证书。