前端开发本地配置 HTTPS 全面详细教程

分为两步:生成证书、本地服务配置使用证书

一、HTTPS 的基本概念

HTTPS 是一种安全的 HTTP 协议,它通过 SSL/TLS 对数据进行加密,确保数据在传输过程中不被窃取或篡改。在前端开发中,某些功能(如 Geolocation API、Web Push API 等)需要在 HTTPS 环境下才能正常使用。

二、生成证书

1. 使用 mkcert(推荐)

mkcert 是一个简单易用的工具,可以为本地开发生成受信任的证书。

  • 安装 mkcert

    • macOS
      brew install mkcert
      brew install nss  # 兼容 Firefox
      
    • Windows
      使用 Chocolatey 安装:
      choco install mkcert
      
  • 生成证书

    mkcert -install  # 安装本地 CA
    mkcert localhost 127.0.0.1 ::1  # 为本地生成证书
    

    这将在当前目录下生成两个文件:localhost.pemlocalhost-key.pem

2. 使用 OpenSSL

如果需要更灵活的证书生成,可以使用 OpenSSL。

  • 生成证书
    openssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 365 -nodes
    
    这将生成 key.pem(私钥)和 cert.pem(证书)。

三、配置开发服务器

1. Vue CLI
  • 修改 vue.config.js
    const fs = require('fs');
    module.exports = {devServer: {https: {key: fs.readFileSync('path/to/localhost-key.pem'),cert: fs.readFileSync('path/to/localhost.pem')}}
    };
    
  • 启动开发服务器
    npm run serve
    
2. Vite
  • 修改 vite.config.js
    import { defineConfig } from 'vite';
    import fs from 'fs';
    export default defineConfig({server: {https: {key: fs.readFileSync('path/to/localhost-key.pem'),cert: fs.readFileSync('path/to/localhost.pem')}}
    });
    
  • 启动开发服务器
    npm run dev
    
3. Node.js
  • 创建 HTTPS 服务器
    const https = require('https');
    const fs = require('fs');
    const options = {key: fs.readFileSync('path/to/localhost-key.pem'),cert: fs.readFileSync('path/to/localhost.pem')
    };
    https.createServer(options, (req, res) => {res.writeHead(200);res.end('Hello, HTTPS!');
    }).listen(443);
    
  • 运行服务器
    node server.js
    
4. Nginx
  • 修改 Nginx 配置文件
    server {listen 443 ssl;server_name localhost;ssl_certificate /path/to/localhost.pem;ssl_certificate_key /path/to/localhost-key.pem;location / {proxy_pass http://localhost:8080;}
    }
    
  • 重启 Nginx
    sudo nginx -t
    sudo systemctl restart nginx
    

四、浏览器访问与信任证书

  • 访问 HTTPS 网站
    打开浏览器,访问 https://localhost。如果使用的是自签名证书,浏览器会提示证书不受信任。你可以选择“继续访问”或“添加例外”来绕过警告。
  • 信任证书
    如果使用的是 mkcert 生成的证书,浏览器会自动信任,不会显示安全警告。

五、注意事项

  1. 更新项目配置
    确保项目中所有资源(如图片、脚本、样式表等)都使用 HTTPS 加载。
  2. 生产环境准备
    在生产环境中,建议使用由权威证书颁发机构(如 Let’s Encrypt)签发的证书。
  3. 测试功能
    测试需要 HTTPS 环境的功能,如 Geolocation、Web Push 等。

通过以上步骤,你可以在本地开发环境中成功配置 HTTPS,确保开发过程中的安全性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/78723.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

day10 python机器学习全流程实践

在机器学习的实践中,数据预处理与模型构建是极为关键的环节。本文将回顾数据预处理的全流程,并基于处理后的数据完成简单的机器学习建模与评估,暂不涉及复杂的调参过程。 一、预处理流程回顾 机器学习的成功,很大程度上依赖于高…

4月28号

初认web前端: web标准: HTML:

【Linux系统】systemV共享内存

system V共享内存 在Linux系统中,共享内存是一种高效的进程间通信(IPC)机制,它允许两个或者多个进程共享同一块物理内存区域,这些进程可以将这块区域映射到自己的虚拟地址空间中。 共享内存区是最快的IPC形式。一旦这…

(七)RestAPI 毛子(Http 缓存/乐观锁/Polly/Rate limiting/异步大文件上传)

文章目录 项目地址一、Http Cache1.1 服务注册1.2 Validation with ETag1. 添加ETagMiddleware中间件2. 创建内存ETag存储器3. 服务注册4. 测试二、使用ETag实现乐观锁2.1 添加乐观锁方法2.2 修改Controller2.3 测试乐观锁三、Rate Limiting3.1 添加速率控制服务1. 在Program里…

2025.4.26_STM32_SPI

1.SPI简介 2.硬件电路 所有SPI设备的SCK(时钟)、MOSI(主机输出从机输入)、MISO(主机输入从机输出)分别连在一起。SCK线只能被主机控制,和I2C相同。 主机另外引出多条SS控制线,分别接到各从机的SS引脚 (SS不用的时候为高电平,当主机需要选中某…

JAVA:单例模式

单例模式是设计模式之一 设计模式,就像古代打仗,我们都听过孙子兵法,把计谋概括下来弄成一种模式,形成一种套路。 软件开发中也有很多场景,多数类似的问题场景,解决方案就形成固定的模式,单例…

脑机接口:重塑人类未来的神经增强革命

引言 人类对大脑的探索从未停止,而脑机接口(Brain-Computer Interface, BCI)的崛起,正在将科幻电影中的“意念操控”变为现实。 这项技术通过解码脑电信号,实现人脑与外部设备的直接交互,不仅为医疗康复带来…

从SOA到微服务:架构演进之路与实践示例

一、架构演进背景 在软件开发领域,架构风格随着业务需求和技术发展不断演进。从早期的单体架构,到面向服务架构(SOA),再到如今的微服务架构,每一次变革都是为了解决当时面临的核心问题。 二、SOA架构解析 2.1 SOA核心概念 SOA&…

可灵AI 2.0上线:重新定义AI创作?好莱坞级特效触手可及

2025年4月15日,快手正式发布可灵AI 2.0,这款被誉为“让好莱坞特效师颤抖”的AI工具,以物理引擎级动态生成和电影语言自由操控两大核心技术,彻底颠覆了内容创作的想象边界。上线24小时内,全球用户已用它生成超过100万条…

Mysql存储引擎、锁机制

Mysql存储引擎 InnoDB​(MySQL 5.5 及以后版本中的默认存储引擎) ​​事务支持​​:支持 ​​ACID 事务​​,适合需要高可靠性的场景(如支付、订单)。 ​​锁机制​​:默认使用 ​​行级锁​​…

飞蛾扑火算法优化+Transformer四模型回归打包(内含MFO-Transformer-LSTM及单独模型)

飞蛾扑火算法优化Transformer四模型回归打包(内含MFO-Transformer-LSTM及单独模型) 目录 飞蛾扑火算法优化Transformer四模型回归打包(内含MFO-Transformer-LSTM及单独模型)预测效果基本介绍程序设计参考资料 预测效果 基本介绍 …

音视频开发---视频编码基础

一、视频编码的必要性 1. 存储与传输成本高 未经编码压缩的原始视频的数据量极大,例如:一般电影的亮度信号采样频率为13.5MHz;色度信号的频带通常为亮度信号的一半或更少,为6.75MHz或3.375MHz。以4:2:2的采样频率为例,Y信号采用13.5MHz,色度信号U和V采用6.75MHz采样,…

手动安装OpenSSL1.1.1

根据报错信息 Could not build the ssl module! Python requires a OpenSSL 1.1.1 or newer,说明当前系统中的 OpenSSL 版本低于 1.1.1,或者 Python 编译时未找到符合要求的 OpenSSL 库。以下是分步解决方案: 1. 检查当前 OpenSSL 版本 首先…

[原创](现代Delphi 12指南):[macOS 64bit App开发]: 跨平台开发同样支持retain()引用计数器处理.

[作者] 常用网名: 猪头三 出生日期: 1981.XX.XX 企鹅交流: 643439947 个人网站: 80x86汇编小站 编程生涯: 2001年~至今[共24年] 职业生涯: 22年 开发语言: C/C++、80x86ASM、Object Pascal、Objective-C、C#、R、Python、PHP、Perl、 开发工具: Visual Studio、Delphi、XCode、…

从 “制造” 到 “品牌”:官网建设助力中国企业突围东南亚

在全球产业链重构与区域经济一体化的浪潮下,中国企业出海已从“战略选项”升级为“生存刚需”。东南亚市场因其地理邻近性、人口红利及政策开放性,成为许多中企出海的“首站试验田”。然而,如何在这一文化多元、竞争激烈的市场中建立品牌认知…

iPhone闹钟无法识别调休致用户迟到,苹果客服称会记录反馈

iPhone闹钟无法识别调休致用户迟到,苹果客服称会记录反馈 基于 6 个来源 因“五一”劳动节调休,4月27日(周日)本应上班,不少iPhone用户却因闹钟未响迟到,“调休”“当苹果闹钟遇到调休”话题登上热搜。苹…

Ubuntu 磁盘空间占用清理(宝塔)

目录 前言1. 基本知识2. 实战 前言 🤟 找工作,来万码优才:👉 #小程序://万码优才/r6rqmzDaXpYkJZF 爬虫神器,无代码爬取,就来:bright.cn 本身自搭建了一个宝塔,突然一下子多了好些空…

杰理-安卓通过map获取时间的时候,部分手机切换sbc和aac时候单耳无声音

杰理-安卓通过map获取时间的时候,部分手机切换sbc和aac时候单耳无声音 #if USER_SUPPORT_PROFILE_MAPif(tws_api_get_role()0){ //主机才获取,否则切换sbc 和 aac 的时候影响单耳无声音user_send_cmd_prepare(USER_CTRL_MAP_READ_TIME,0,NULL);} #endif…

Android 进阶开发:深入掌握 ProgressBar 的使用与高级技巧

一、前言 在 Android 开发中,ProgressBar 是一个非常常见且功能强大的控件,用于向用户反馈操作的进度。虽然它的基础用法简单,但对于进阶开发者来说,如何通过自定义动画、插值器、样式和逻辑控制来提升用户体验,是一个值得深入研究的方向。 本文将带你从 基本使用入手,…

AGILE:开启LLM Agent强化学习的创新框架

在大语言模型(LLMs)蓬勃发展的今天,基于LLMs构建的智能体成为研究热点。但如何将各组件整合优化仍是难题。本文提出的AGILE框架给出了创新解法,它不仅统一多组件,还让智能体性能超越GPT-4。想知道它是如何做到的吗&…