当前位置: 首页 > news >正文

SpringBoot:SSL证书部署+SpringBoot实现HTTPS安全访问

一、前言

  SSL协议介于TCP/IP协议栈的第四层(传输层)和第七层(应用层)之间,为基于TCP的应用层协议(如HTTP)提供安全连接。它通过在客户端和服务器之间建立一个加密的通道,确保数据在传输过程中的机密性、完整性和身份验证。

  HTTPS(Hypertext Transfer Protocol Secure)是一种安全的通信协议,它在HTTP的基础上加入了SSL(Secure Sockets Layer,安全套接层)或其继任者TLS(Transport Layer Security,传输层安全)协议层,以确保数据在客户端和服务器之间的传输过程中得到加密和保护。

二、SSL工作原理

握手阶段

  客户端发送Client Hello消息到服务器端,包括客户端支持的SSL版本、会话ID、随机数、密码算法列表和压缩方法等参数。

  服务器收到Client Hello后,发送Server Hello消息,包括选择的SSL版本、服务器产生的随机数、会话ID、从客户端建议的密码套件中挑出的密码算法和压缩算法等

  服务器向客户端发送自己的证书,客户端验证服务器的身份,并取出证书中的公钥。

  根据选择的密码套件,双方进行密钥交换和协商,生成用于加密和MAC的会话密钥。

安全数据传输阶段

  在已经建立的SSL数据通道里,双方使用协商好的加密算法和会话密钥,对传输的数据进行加密和MAC计算,确保数据的机密性和完整性。

三、模拟https请求

1.生成签名证书

在操作之前,先确保jdk环境都是没问题的。

在这里插入图片描述

使用keytool(Java开发工具包的一部分)来生成一个自签名证书和私钥,或者从受信任的证书颁发机构(CA)获取一个证书。

keytool -genkeypair -alias mysslkey -keyalg RSA -keystore D:/keystore.p12 -storetype PKCS12 -keysize 2048 -validity 180 -dname "CN=xiaoming, OU=weiwei, O=xiaowei, L=hai, ST=dai, C=CN" -storepass 123456 -keypass 123456

执行命令之后。生成如下的文件:
在这里插入图片描述

参数说明
-alias mysslkey:证书的别名。

-keyalg RSA:密钥算法。

-keystore keystore.p12:生成秘钥库的存储路径和名称。

-storetype PKCS12:指定密钥库类型为PKCS12。

-keysize 2048:密钥大小。

-validity 180:证书有效期(天)。

-dname:证书的信息。CN:姓名;OU:组织单位名称;O:组织名称;L:省/市/自治区名称;C:国家/地区代码。

-storepass 123456:密钥库的密码。

-keypass 123456:私钥的密码(可以与密钥库密码相同)。

springboot application.properties中配置

server.port=8443
server.ssl.key-store=classpath:keystore.p12
server.ssl.key-store-password=123456
server.ssl.keyStoreType=PKCS12
server.ssl.keyAlias=mysslkey
server.ssl.enabled=true

配置说明
server.port:HTTPS监听的端口。
server.ssl.key-store:密钥库文件的路径(相对于类路径)。
server.ssl.key-store-password:密钥库的密码。
server.ssl.keyStoreType:密钥库的类型(如PKCS12)。
server.ssl.keyAlias:证书的别名。
server.ssl.enabled:启用SSL

将keystore.p12文件导入到src/main/resources中
这样它就可以被classpath:前缀正确地引用。

在这里插入图片描述

访问本地地址结果如下
因为使用的是自签名证书,所以浏览器会显示安全警告
在这里插入图片描述

点击继续前往
在这里插入图片描述

四、总结

  SSL和HTTPS在网络安全领域发挥着重要作用。通过部署SSL证书并使用HTTPS协议,网站可以保护用户数据的安全性和机密性,增强用户信任感。

http://www.lryc.cn/news/540103.html

相关文章:

  • selenium爬取苏宁易购平台某产品的评论
  • Spark提交任务
  • 游戏引擎学习第113天
  • token是什么
  • 23. AI-大语言模型-DeepSeek赋能开发-Spring AI集成
  • IPv6报头40字节具体怎么分配的?
  • 驱动开发、移植
  • BFS与Flood Fill:算法原理、实现细节与复杂度分析
  • 计算机网络基础杂谈(局域网、ip、子网掩码、网关、DNS)
  • 雷龙CS SD NAND(贴片式TF卡)测评体验
  • 【Alertmanager】alertmanager告警系统原理剖析与应用实战,应有尽有非常全面
  • Java——权限修饰符
  • 一周学会Flask3 Python Web开发-redirect重定向
  • python面向对象:方法
  • 物联网简介集合
  • centos下使用pyenv管理python版本
  • C++:类与对象,定义类和构造函数
  • 【Java消息队列】应对消息丢失、重复、顺序与积压的全面策略
  • 解锁机器学习核心算法|神经网络:AI 领域的 “超级引擎”
  • Android14(13)添加墨水屏手写API
  • flyway的ignoreMigrationPatterns
  • 25年2月通信基础知识补充:多普勒频移与多普勒扩展、3GPP TDL信道模型
  • 华为动态路由-OSPF-骨干区
  • 接口测试-API测试中常用的协议(中)
  • 植物大战僵尸杂交版v3.2.1最新版本(附下载链接)
  • java每日精进 2.20 MQ相关复健
  • 【设计模式精讲】结构型模式之代理模式(静态代理、JDK动态代理、cglib动态代理)
  • 京东广告基于 Apache Doris 的冷热数据分层实践
  • win11 安装pyenv来管理python
  • 【AI】GitHub Copilot