解决 pnpm dev 报错:系统禁止运行脚本的问题

概述

在使用 pnpm dev 命令启动项目时,很多开发者会遇到 PowerShell 拦截脚本运行的报错,本文将详细解析问题原因,并提供多种可行的解决方法。

一、问题现象

执行 pnpm dev 命令后,终端抛出如下错误:

复制代码
pnpm : 无法加载文件 C:\Users\flybird\AppData\Roaming\npm\pnpm.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.com/fwlink/?LinkID=135170 中的 about_Execution_Policies。
所在位置 行:1 字符: 1
+ pnpm dev
+ ~~~~
    + CategoryInfo          : SecurityError: (:) [],PSSecurityException
    + FullyQualifiedErrorId : UnauthorizedAccess

二、问题原因

该错误的核心是 Windows PowerShell 的执行策略限制 。PowerShell 为了系统安全,默认会限制脚本的运行权限,防止恶意脚本执行。而 pnpm 的启动依赖 .ps1 脚本文件,当执行策略为严格模式时,脚本就会被直接拦截。

三、解决方法

方法 1:临时解除当前会话限制(推荐,仅本次生效)

此方法仅对当前打开的 PowerShell 窗口生效,关闭窗口后权限自动恢复,兼顾安全性和便捷性。

1、以普通用户身份打开 PowerShell(无需管理员权限)。

2、执行以下命令,将当前用户的执行策略设置为 RemoteSigned

复制代码
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser

3、终端弹出确认提示时,输入 Y 并按下回车键。

4、重新执行 pnpm dev 命令,即可正常启动项目。

方法 2:永久解除限制(需管理员权限)

如果需要长期使用 pnpm,不想每次都配置权限,可以选择此方法,全局解除本地机器的脚本运行限制。

1、右键点击 PowerShell,选择以管理员身份运行

2、执行以下命令,设置本地机器的执行策略:

复制代码
Set-ExecutionPolicy RemoteSigned -Scope LocalMachine

3、输入 Y 确认策略修改。

4、关闭当前 PowerShell 窗口,重新打开后执行 pnpm dev 即可。

方法 3:绕过 PowerShell,使用 CMD 终端

如果不想修改 PowerShell 执行策略,也可以换用 Windows 自带的 CMD 命令提示符,CMD 不受 PowerShell 执行策略的约束。

  1. 按下 Win + R,输入 cmd 并回车,打开命令提示符。
  2. 在 CMD 中切换到项目根目录,直接执行 pnpm dev 命令即可。

四、补充说明

1、关于 RemoteSigned 策略 该策略是兼顾安全与实用的选择,它允许运行本地创建 的脚本(如 pnpm 的 .ps1 文件),但要求远程下载的脚本必须带有数字签名,能有效防范恶意脚本。

2、检查 pnpm 是否安装成功若修改执行策略后仍报错,可能是 pnpm 未正确安装,可执行以下命令重新全局安装:

复制代码
npm install -g pnpm

**3、恢复默认严格策略(可选)**如果后续担心安全风险,想要恢复 PowerShell 的默认限制,可执行以下命令:

复制代码
Set-ExecutionPolicy Restricted -Scope CurrentUser
相关推荐
૮・ﻌ・2 小时前
Vue3:组合式API、Vue3.3新特性、Pinia
前端·javascript·vue3
前端不太难2 小时前
RN + TypeScript 项目越写越乱?如何规范架构?
前端·javascript·typescript
神算大模型APi--天枢6462 小时前
全栈自主可控:国产算力平台重塑大模型后端开发与部署生态
大数据·前端·人工智能·架构·硬件架构
苏打水com2 小时前
第十五篇:Day43-45 前端性能优化进阶——从“可用”到“极致”(对标职场“高并发场景优化”需求)
前端·css·vue·html·js
@大迁世界2 小时前
08.CSS if() 函数
前端·css
Moment2 小时前
小米不仅造车,还造模型?309B参数全开源,深度思考完胜DeepSeek 🐒🐒🐒
前端·人工智能·后端
苏打水com2 小时前
第十六篇:Day46-48 前端安全进阶——从“漏洞防范”到“安全体系”(对标职场“攻防实战”需求)
前端·javascript·css·vue.js·html
5C242 小时前
从思想到实践:前端工程化体系与 Webpack 构建架构深度解析
前端·前端工程化
咕噜企业分发小米2 小时前
如何平衡服务器内存使用率和系统稳定性?
java·服务器·前端