《开发环境使用HTTPS调试》

🤖 作者简介:水煮白菜王 ,一位资深前端劝退师 👻

👀 文章专栏: 前端专栏 ,记录一下平时在博客写作中,总结出的一些开发技巧✍。

感谢支持💕💕💕

近期文章:
《mkcert介绍及使用》

目录

在开发环境中, 有时会需要模拟https环境,来调试硬件及其他业务要求必须使用https访问。本地需要使用自签SSL证书使用的CA证书添加到系统或浏览器的可信CA证书,解决浏览器的信任。为了更方便开的发调试,我们来使用一种更加方便生成本地https证书,并且信任自签CA的方案 mkcert

直接看操作👀下面的正文👉 [正文](#直接看操作👀下面的正文👉 正文)

mkcert

mkcert是一个使用go语言编写,用于生成本地开发环境中的受信任的 SSL/TLS 证书,具有跨平台,支持多域名,自动信任CA等一系列方便的特性可供开发者快速地为本地域名设置安全的https环境。

这对于在本地开发环境中测试 HTTPS 连接非常有用,因为它可以为你的本地开发域名生成自签名的证书,并通过一个根证书(CA)使其在你的系统上被信任。

create-ca 和 create-cert

create-ca 和 create-cert 是 mkcert 工具中使用的子命令。mkcert 主要通过这两个子命令来生成根证书(CA)和为特定域名生成证书。

在日常使用中,mkcert 的默认用法已经涵盖了 create-ca 和 create-cert 的功能,因此通常不需要单独使用这两个子命令。

create-ca

create-ca 子命令用于生成一个根证书(CA)。这个根证书将被用来签发其他证书。在 mkcert 中,通常不需要显式地使用 create-ca,因为 mkcert 会在第一次运行时自动创建根证书并安装它。

powershell 复制代码
mkcert -create-ca

这将生成一个根证书,通常位于 ~/.local/share/mkcert/rootCA.pem 文件中。

create-cert

create-cert 子命令用于为特定的域名生成证书。这些证书是由前面生成的根证书签发的,因此会被系统信任。

powershell 复制代码
mkcert -create-cert example.local

这将为 example.local 生成一个证书和对应的私钥,通常位于 example.local.pem 和 example.local-key.pem 文件中。

正文 为快速搭建本地开发https环境 以及 更好地理解 mkcert 的工作原理,我们以 `create-ca` 和 `create-cert` 的过程生成的文件进行配置 。下面一把流操作最后在在项目config配置文件引入

1.为系统安装mkcert

powershell 复制代码
 npm install -g mkcert    

2.查看版本检验是否安装成功

powershell 复制代码
mkcert --version

3.创建证书颁发机构

将生成一个根证书 ca.crt 和对应的私钥 ca.key

powershell 复制代码
mkcert create-ca

4.创建证书

为特定域名生成的证书cert.crt、对应的私钥cert.key

powershell 复制代码
mkcert create-cert

5.对生成ca.crt进行安装

注意的是安装证书存储选择受信任的根证书颁发机构,其他操作闭眼睛一路通过即可




6.在项目config配置文件devServer下引入对应的证书文件

javascript 复制代码
<!-- Vue 2 Code -->
const path = require('path')
const fs = require('fs') // 处理读写模块

module.exports = {
	
	// ...
	devServer: {
		// ...
		https: {
			cert: fs.readFileSync(path.join(__dirname, './cert.crt')), 
			key: fs.readFileSync(path.join(__dirname, './cert.key'))  
		},
	},
}

7.运行项目验证

8.vue3 + vite

Vue3也可以向上面Vue2一样配置https,但没必要这么操作臃肿,vue3使用vite插件vite-plugin-basic-ssl来配置https,如果真没有用vite😂,那这是天命人了😇

powershell 复制代码
npm install -D @vitejs/plugin-basic-ssl
powershell 复制代码
import { defineConfig } from "vite";
import basicSsl from '@vitejs/plugin-basic-ssl'
 
export default defineConfig(()=>{
	server: {
	    https: true, //开启https
   		// ...
   },
   plugins: [
   		basicSsl(), //加载插件
   		// ...
   ]
})

如果你觉得这篇文章对你有帮助,请点赞 👍、收藏 👏 并关注我!👀

相关推荐
下雪天的夏风8 分钟前
TS - tsconfig.json 和 tsconfig.node.json 的关系,如何在TS 中使用 JS 不报错
前端·javascript·typescript
永乐春秋9 分钟前
WEB攻防-JavaWweb项目&JWT身份攻击&组件安全&访问控制
安全
小黑爱编程17 分钟前
【LInux】HTTPS是如何实现安全传输的
linux·安全·https
diygwcom19 分钟前
electron-updater实现electron全量版本更新
前端·javascript·electron
Hello-Mr.Wang36 分钟前
vue3中开发引导页的方法
开发语言·前端·javascript
程序员凡尘1 小时前
完美解决 Array 方法 (map/filter/reduce) 不按预期工作 的正确解决方法,亲测有效!!!
前端·javascript·vue.js
云卓科技1 小时前
无人机之控制距离篇
科技·安全·机器人·无人机·制造
云卓科技1 小时前
无人机之飞行高度篇
科技·安全·机器人·无人机·制造
编程零零七4 小时前
Python数据分析工具(三):pymssql的用法
开发语言·前端·数据库·python·oracle·数据分析·pymssql
GEEKVIP5 小时前
Android 恢复挑战和解决方案:如何从 Android 设备恢复删除的文件
android·笔记·安全·macos·智能手机·电脑·笔记本电脑