前端開發本地配置 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.pswp.cn/pingmian/78723.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/78723.shtml
英文地址,請注明出處:http://en.pswp.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。想知道它是如何做到的嗎&…