1 Einführung
HTTP
ist unsicher, wir müssen SSL
darauf installieren, um es in HTTPS
umzuwandeln. In diesem Artikel wird anhand von Beispielen die Integration von Springboot
in HTTPS
vorgestellt. HTTP
是不安全的,我们需要给它套上SSL
,让它变成HTTPS
。本文章将用实例介绍Springboot
整合HTTPS
。
2 密码学基础
要谈https
就要谈Security
2 Grundlagen der KryptographieWenn Sie über https
sprechen möchten, müssen Sie über Sicherheit
sprechen, und das haben Sie natürlich auch Um über Sicherheit zu sprechen, sind einige Kenntnisse der Kryptographie erforderlich.
2.1 Kryptosystem
Um ein kryptografisches System einzurichten, muss es aus fünf Leerzeichen bestehen: Klartext M: Informationen vor der Verschlüsselung oder Entschlüsselung; Chiffretext C: Klartext nach der Verschlüsselung; -
Schlüssel K: besteht aus Verschlüsselungsschlüssel und Entschlüsselungsschlüssel; Verschlüsselung E: Umwandlung von Klartext in Chiffretext; Entschlüsselung D: Umwandlung von Chiffretext in Klartext.
Wie in der Abbildung gezeigt:
2.2 Zwei Verschlüsselungsmethoden
2.2.1 Symmetrische Verschlüsselung
Symmetrische Verschlüsselung oder Einzelschlüsselverschlüsselung bedeutet, dass der Verschlüsselungsschlüssel und der Entschlüsselungsschlüssel gleich sind (bzw Einfaches Berechnen einer Verschlüsselungsmethode aus der anderen.
Die Hauptvorteile der symmetrischen Verschlüsselung sind: schnelle Verschlüsselungs- und Entschlüsselungsvorgänge und hohe Effizienz;
Einschränkungen: komplexe Schlüsselverteilung, schwierige Schlüsselverwaltung, schlechte Offenheit sicherer Kommunikationssysteme und digitale Signaturen; AES-Algorithmus;
Ein kleines Beispiel:
明文为48,加密算法f(x)=8x+71,
则密文C=8*48+71=455
则解密算法为f(x)=(x-71)/8;
则解密后的明文M=(455-71)/8=48;
Nach dem Login kopieren
2.2.2 Asymmetrische Verschlüsselung
Asymmetrische Verschlüsselung bedeutet, dass für die Verschlüsselung bzw. Entschlüsselung unterschiedliche Schlüssel verwendet werden und der Entschlüsselungsschlüssel nicht aus der Verschlüsselungsmethode des Verschlüsselungsschlüssels abgeleitet werden kann.
Hauptvorteile: einfache Schlüsselverteilung, einfache Verwaltung, gute Systemoffenheit und digitale Signaturen möglich;
Repräsentative Algorithmen: RSA-Algorithmus, ECC-Algorithmus; ein großes Beispiel
:
Die Schritte sind wie folgt:
Schritt
Beschreibung Formel | Hinweis |
|
| 1
Finde zwei Primzahlen
P, Q |
| 🏜 |
| 4
Berechnen Sie den öffentlichen Schlüssel E | 1 E * D % φ(N) = 1 |
|
6 | Verschlüsselung | C = M^ E mod N | C: Chiffretext M: Klartext
|
7 Entschlüsselung |
M =C^D mod N |
C: Chiffretext M: Klartext |
|
其中,公钥=(E , N) ,私钥=(D, N),对外,我们只暴露公钥。
1.找出两个质数
随便找两个质数,我们找P=5,Q=11。
2.计算公共模数
公共模数N=P*Q=5*11=55
3.计算欧拉函数
φ(N) = (P-1)(Q-1)=4*10=40
4.计算公钥E
1 <p>至此,整个非对称加密过程演示了一遍,希望大家能理解,特别是非对称加密,因为<strong>HTTPS</strong>使用的是非对称加密。实际的使用算法更复杂,密钥长度会更大。</p><h3 id="yisu3h-to139">2.3 证书</h3><p>要使用SSL,需要有证书,这个证书文件是包含公钥密钥,也就是非对称加密中要使用的。</p><p>获取证书有两种方式:</p>
Nach dem Login kopieren
为方便起见,在本次实例中使用自签证书,两种证书整合过程并无差异。
3 Springboot整合HTTPS
3.1 先让Web跑起来
作为一个Web应用,我们先让它跑起来,然后再整合https
。
(1)引入Web依赖:
<dependency>
<groupid>org.springframework.boot</groupid>
<artifactid>spring-boot-starter-web</artifactid></dependency>
Nach dem Login kopieren
(2)配置端口:
server.port=80
Nach dem Login kopieren
(3)实现Contrlloer
:
@RestControllerpublic class HelloController {@GetMapping("/hello")public String hello() {return "Welcome to www.pkslow.com";
}
}
Nach dem Login kopieren
完成上面工作后,启动应用即可。
访问http://localhost/hello 得到下面结果,说明整个Web应用起来了。
3.2 生成密钥文件jks
通过命令行生成密钥文件如下:
keytool -genkey -alias localhost -keyalg RSA -keysize 2048 -sigalg SHA256withRSA -keystore localhost.jks -dname CN=localhost,OU=Test,O=pkslow,L=Guangzhou,C=CN -validity 731 -storepass changeit -keypass changeit
Nach dem Login kopieren
命令行重要参数的意义:
执行完以上命令后,就会生成localhost.jks
文件,把该文件放到classpath
下即可,当然也可以放到其它位置,配置文件指定正确即可。
3.3 重新配置并重启
按照实际情况重新配置application.properties
文件:
server.port=443server.ssl.enabled=trueserver.ssl.key-store-type=jksserver.ssl.key-store=classpath:localhost.jksserver.ssl.key-store-password=changeitserver.ssl.key-alias=localhost
Nach dem Login kopieren
重启后访问如下:
发现有红色警告,因为这是自签名的cert
,并不被Chrome
所认可,所以会校验失败。以前的Chrome
版本只是警告,但还是可以访问的,现在新版本的已经不能访问了。
通过Postman
来访问便可:
3.4 使用PKS12格式
如果想使用PKCS12替换JKS,命令和配置可以参考下面:
生成密钥:
keytool -genkey -alias localhost -keyalg RSA -keysize 2048 -sigalg SHA256withRSA -storetype PKCS12 -keystore localhost.p12 -dname CN=localhost,OU=Test,O=pkslow,L=Guangzhou,C=CN -validity 731 -storepass changeit -keypass changeit
Nach dem Login kopieren
配置文件如下:
server.port=443server.ssl.enabled=trueserver.ssl.key-store-type=PKCS12server.ssl.key-store=classpath:localhost.p12server.ssl.key-store-password=changeitserver.ssl.key-alias=localhost
Nach dem Login kopieren
Das obige ist der detaillierte Inhalt vonSo integrieren Sie https in Springboot. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!