JavaWeb学习笔记(四)--Tomcat体系结构和软件密码学基础

一、Tomcat体系结构

Tomcat启动时先启动一个Server,Server启动后会启动一个Service,Service会创建多个连接器,当服务器接收到浏览器的HTTP请求时,会使用对应的连接器,连接器不直接处理请求,而是把请求转发给Engine,引擎根据Host中配置的Context来确定当前的URL是否能够映射到对应的web应用中,再到对应的web应用找查找浏览器需要的资源。

从Tomcat的server.xml也可以看其组织结构:

<?xml version="1.0" encoding="UTF-8"?>

<Server port="8005" shutdown="SHUTDOWN">
  
  <Service name="Catalina">
   
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

    <Engine name="Catalina" defaultHost="localhost">

      <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
     
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log" suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />

      </Host>
      
    </Engine>
  </Service>
</Server>

二、软件密码学基础

待补充

三、配置Tomcat的https连接器

3.1 生成数字证书

使用JDK自带的命令,完成后会在C盘用户目录生成.keystore文件

keytool -genkey -alias tomcat -keyalg RSA

3.2 配置https连接器

将上面生成的证书拷贝到Tomcat的conf目录中,在servlet.xml中增加https连接器

<Connector port="8443" protocol="org.apache.coyote.http11.Http11Protocol" 
               SSLEnabled="true" maxThreads="150" scheme="https" secure="true" 
               clientAuth="false" sslProtocol="TLS" keystoreFile="conf/.keystore" 
               keystorePass="123456"/>    

启动服务器,用IE访问https://localhost:8443(Chrome怎么安装证书没弄明白),报警告后继续访问,可以看到Tomcat的主页。

3.3 安装数字证书

点击查看证书,并安装证书,放到受信任的根证书发布机构,关闭浏览器,再重新访问https://localhost:8443,就不会有警告了:

 3.3 删除数字证书

删除后重启浏览器,就又会有警告了。

猜你喜欢

转载自www.cnblogs.com/songchj-bear/p/10324225.html