news 2026/2/12 12:28:46

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
解决 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
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/11 15:27:44

Vue3 - Diff算法理解

Vue 版本:以 vue3.x 代码为参考,主要梳理 diff 算法的核心流程。 Vue 3 的 diff 算法借鉴了纯文本 diff 算法的思想,参考了 viv 和 inferno 框架的实现,只对需要处理的节点本身进行 diff 操作。通过预处理和最长递增子序列&#x…

作者头像 李华
网站建设 2026/2/10 11:05:35

3个颠覆性突破让开源CMS成为中小企业数字化转型的秘密武器

在数字化转型浪潮中,中小企业的IT预算往往捉襟见肘,而Directus作为一款完全开源的内容管理平台,正以零许可成本和高度灵活的技术架构,为预算有限的企业提供了一条全新的数字化路径。这款基于Node.js构建的现代化CMS,不…

作者头像 李华
网站建设 2026/2/3 9:18:22

PapersGPT for Zotero 终极安装指南:5步快速配置AI文献助手

PapersGPT for Zotero 终极安装指南:5步快速配置AI文献助手 【免费下载链接】papersgpt-for-zotero Zotero chat PDF with DeepSeek, GPT, ChatGPT, Claude, Gemini 项目地址: https://gitcode.com/gh_mirrors/pa/papersgpt-for-zotero PapersGPT for Zotero…

作者头像 李华
网站建设 2026/2/7 16:03:36

15-2.【Linux系统编程】进程信号 - 信号保存(信号处理流程的三种状态:未决、阻塞、递达,信号保存由未决表完成、sigset_t信号集类型及相关函数)

目录3. 保存信号-内核通过 “未决信号集” 为每个进程存储已产生但未处理的信号3.1 信号处理流程中的不同状态3.2 信号在内核中的表示3.3 sigset_t信号集类型3.4 信号集操作函数3.4.1 sigprocmask读取或更改进程的信号屏蔽字3.4.2 sigpending读取当前进程的未决信号集3.4.3 综合…

作者头像 李华
网站建设 2026/2/3 6:51:48

31、国际化文本输入方法详解

国际化文本输入方法详解 1. 字体集与字符显示 当 XFontSet 缺少字符集时,每个不可用的字符会使用 XCreateFontSet 返回的默认字符串来绘制。对于无效码点的行为则未作定义。 2. 输入方法概述 输入方法涵盖多个方面,包括输入方法概述、管理、功能、值、输入上下文功能与值…

作者头像 李华
网站建设 2026/2/6 13:12:59

33、本地化与国际化文本函数详解

本地化与国际化文本函数详解 在处理国际化文本输入时,有许多关键的概念和函数需要我们去理解和掌握。下面将详细介绍这些内容,包括输入方法值、输入上下文函数以及输入上下文值等方面。 输入方法相关函数与值 XUnregisterIMInstantiateCallback 函数:该函数用于移除之前…

作者头像 李华