练习nginx 的https的搭建

一、要求

1.防火墙不能关闭, 让其开发http协议和https协议

2.该网站具备账户验证

3.https

二、试验步骤

1、开启防火墙,并检查防火墙状态

2、防火墙配置开放HTTP/HTTPS

3、安装nginx,并启动 systemctl enable nginx

4、创建SSL证书和密钥

5、创建密码文件用于HTTP认证

6、将密码文件复制到Nginx配置目录并设置权限

将密码文件复制到/etc/nginx/passwd

cp passwd /etc/nginx/passwd
设置密码文件权限为644

chmod 644 /etc/nginx/passwd
验证密码文件是否成功复制

ls -la /etc/nginx/passwd

7、创建完整的Nginx HTTPS配置文件

vi /etc/nginx/nginx.conf

TypeScript 复制代码
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;
 
include /usr/share/nginx/modules/*.conf;
 
events {
    worker_connections 1024;
}
 
http {
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
 
    access_log  /var/log/nginx/access.log  main;
 
    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;
 
    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;
 
    # Load modular configuration files from the /etc/nginx/conf.d directory.
    # See http://nginx.org/en/docs/ngx_core_module.html#include
    # for more information.
    include /etc/nginx/conf.d/*.conf;
 
    server {
        listen       80;
        server_name  _;
        root         /usr/share/nginx/html;
 
        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;
 
        location / {
        }
 
        error_page 404 /404.html;
            location = /40x.html {
        }
 
        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }
    }
 
    # HTTPS server configuration
    server {
        listen 443 ssl http2;
        server_name www.haqimi.com www.manbo.com;
        root /usr/share/nginx/html;
 
        # SSL certificate configuration
        ssl_certificate /etc/nginx/ssl/lyh.crt;
        ssl_certificate_key /etc/nginx/ssl/lyh.key;
 
        # SSL protocol and cipher configuration
        ssl_protocols TLSv1.2 TLSv1.3;
        ssl_prefer_server_ciphers on;
        ssl_ciphers "ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-CHACHA20-POLY1305";
        ssl_session_cache shared:SSL:1m;
        ssl_session_timeout 10m;
 
        # HTTP Basic Authentication
        auth_basic "input your passwd";
        auth_basic_user_file /etc/nginx/passwd;
 
        location / {
            index index.html index.htm;
        }
    }
 
    # HTTP to HTTPS redirect
    server {
        listen 80;
        server_name www.haqimi.com www.manbo.com;
        return 301 https://$host$request_uri;
    }
}

8、创建SSL证书目录,复制证书和密钥到SSL目录

mkdir -p /etc/nginx/ssl

cp lyh.crt /etc/nginx/ssl/

cp lyh.key /etc/nginx/ssl/

9、重启Nginx服务以应用新配置、检查Nginx服务状态、测试Nginx配置文件语法是否正确

bash 复制代码
systemctl restart nginx
systemctl status nginx
nginx -t

10、开放http80的端口和https443的端口

root@localhost \~\]# firewall-cmd --add-port=80/tcp --permanent \[root@localhost \~\]# firewall-cmd --add-port=443/tcp --permanent \[root@localhost \~\]# firewall-cmd --reload ![](https://i-blog.csdnimg.cn/direct/666f844d728d43ddbd78bf4158017805.png) 11、添加域名解析记录到/etc/hosts,并用curl -I http://www.haqimi.com测试 ![](https://i-blog.csdnimg.cn/direct/56846947b307483092668758b8a4c0d5.png) 12、浏览器验证 ![](https://i-blog.csdnimg.cn/direct/01933cb293f040318cce38246e3d8de6.png) ![](https://i-blog.csdnimg.cn/direct/9f2572f848dd41419b85e4810b70eb5a.png)

相关推荐
HalvmånEver2 分钟前
Linux:线程 ID 与地址空间布局:深入理解线程内存分布(线程七)
linux·运维·服务器·操作系统·线程
北京阿法龙科技有限公司7 分钟前
工业场景下AR+AI图像识别:精准选型赋能运维与质检
运维·人工智能·ar
小oo呆30 分钟前
【学习心得】CMD终端设置Proxy的几个要点
运维·服务器·网络
Forget_855038 分钟前
RHEL——制作母盘
linux·运维·服务器
释怀不想释怀1 小时前
Linux命令--echo~反引号符~重定向符(>>)~tail命令
linux·运维·服务器
Max_uuc1 小时前
【C++ 硬核】给单片机装上“反射”:手写极简属性系统 (Property System) 自动化 CLI 开发
运维·自动化
路由侠内网穿透.1 小时前
fnOS 飞牛云 NAS 本地部署私人影视库 MoonTV 并实现外部访问
运维·服务器·网络·数据库·网络协议
Doro再努力2 小时前
【Linux05】Linux权限管理深度解析(二)
linux·运维·服务器
Gofarlic_oms12 小时前
通过Kisssoft API接口实现许可证管理自动化集成
大数据·运维·人工智能·分布式·架构·自动化
Suchadar3 小时前
Docker基础命令(二)——数据卷管理端口映射与容器互联
运维·docker·容器