SSL证书配置
1.1 tomcat配置SSL证书
tomcat配置
# 上传证书
cp ../abc.com.cn.jks ./conf/
# 修改配置
server.xml
<Connector port="443" protocol="HTTP/1.1" SSLEnabled="true"
maxThreads="150" scheme="https" secure="true"
keystoreFile="conf/domains.jks"
keystorePass="xxxxxx" //证书密钥 ,密码文本那个
clientAuth="false" sslProtocol="TLS" />
<Connector port="8088" protocol="HTTP/1.1" SSLEnabled="true" maxThreads="150" scheme="https" secure="true" keystoreFile="/data01/abc/abc_web/tomcat/ssl/abc.com.cn.jks" keystorePass="abc" clientAuth="false" sslProtocol="TLS" connectionTimeout="20000" maxHttpHeaderSize="81920" relaxedQueryChars="<>[\]{|}" URIEncoding="utf-8" />
# 修改配置
web.xml
<login-config>
<!-- Authorization setting for SSL -->
<auth-method>CLIENT-CERT</auth-method>
<realm-name>Client Cert Users-only Area</realm-name>
</login-config>
<security-constraint>
<!-- Authorization setting for SSL -->
<web-resource-collection >
<web-resource-name >SSL</web-resource-name>
<url-pattern>/*</url-pattern>
</web-resource-collection>
<user-data-constraint>
<transport-guarantee>CONFIDENTIAL</transport-guarantee>
</user-data-constraint>
</security-constraint>
1.2 node.js 配置SSL证书
node.js 配置SSL证书
xxx.xxx.xxx.xxx
/home/abc/java_web/ws/ws
# 上传SSL证书
./ssl/abc.com.cn.key
./ssl/abc.com.cn.pem
代码修改
# ########################################## 代码 ####################################
/** 用于开发环境的服务启动 **/
const path = require("path"); // 获取绝对路径有用
const express = require("express"); // express服务器端框架
// const http = require("http");
const https = require("https");
const fs = require("fs");
const httpsOption = {
key : fs.readFileSync(__dirname + "/ssl/abc.com.cn.key"),
cert: fs.readFileSync(__dirname + "/ssl/abc.com.cn.pem")
}
const compression = require("compression");
const app = express(); // 实例化express服务
// const PORT = 8088; // 服务启动端口号
app.use(compression());
// http.createServer(app).listen(80);
/** express 跨域中间件 **/
const allowCrossDomain = function(req, res, next) {
res.header("Access-Control-Allow-Origin", "*"); //自定义中间件,设置跨域需要的响应头。
res.header("Access-Control-Allow-Headers", "Content-Type");
res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS");
res.header("Access-Control-Allow-Credentials", "true");
next();
};
app.use(allowCrossDomain); //运用跨域的中间件
/** express 跨域中间件 **/
// 如果是生产环境,则运行build文件夹中的代码
app.use(express.static("dist"));
app.get("*", function(req, res) {
res.sendFile(path.join(__dirname, "dist", "index.html"));
});
/** express 404 错误处理 **/
app.use(function(req, res, next) {
var err = null;
try {
decodeURIComponent(req.path);
} catch (e) {
err = e;
}
if (err) {
return res.redirect(["http://", req.get("Host"), "/404"].join(""));
}
next();
});
/** 启动服务 **/
// app.listen(PORT, () => {
// console.log("本地服务启动地址: http://localhost:%s", PORT);
// });
https.createServer(httpsOption, app).listen(8088);
1.3 nginx配置
nginx配置
server {
listen 443 ssl;
server_name 132.151.6.10;
ssl_certificate /home/g/.local/share/mkcert/rootCA.crt;
ssl_certificate_key /home/g/.local/share/mkcert/rootCA.key;
# 停止通信时,加密会话的有效期,在该时间段内不需要重新交换密钥
ssl_session_timeout 5m;
# TLS握手时,服务器采用的密码套件
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
# 服务器支持的TLS版本
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
# 开启由服务器决定采用的密码套件
ssl_prefer_server_ciphers on;
location / {
......
}
}
server {
listen 80;
server_name 132.151.6.10;
# 将请求改写为HTTPS(这里写你配置了HTTPS的域名)
rewrite ^(.*)$ https://132.151.6.10;
}
# 验证配置文件是否有效
sbin/nginx -t
# 重启
nginx -s reload
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!