我刚刚通过nodejs.org上的包安装了node和npm,每当我尝试使用npm搜索或安装某个东西时,它会抛出以下错误,除非我执行命令。我觉得这是权限问题?我已经是管理员了。

npm ERR! Error: EACCES, open '/Users/chietala/.npm/-/all/.cache.json'
npm ERR!  { [Error: EACCES, open '/Users/chietala/.npm/-/all/.cache.json']
npm ERR!   errno: 3,
npm ERR!   code: 'EACCES',
npm ERR!   path: '/Users/chietala/.npm/-/all/.cache.json' }
npm ERR! 
npm ERR! Please try running this command again as root/Administrator.

npm ERR! System Darwin 12.2.0
npm ERR! command "node" "/usr/local/bin/npm" "search" "bower"
npm ERR! cwd /Users/chietala
npm ERR! node -v v0.10.4
npm ERR! npm -v 1.2.18
npm ERR! path /Users/chietala/.npm/-/all/.cache.json
npm ERR! code EACCES
npm ERR! errno 3
npm ERR! stack Error: EACCES, open '/Users/chietala/.npm/-/all/.cache.json'
npm ERR! 
npm ERR! Additional logging details can be found in:
npm ERR!     /Users/chietala/npm-debug.log
npm ERR! not ok code 0

当前回答

我将我的用户帐户设置为/usr/local目录的所有者,这样就可以在那里发出正常命令。

sudo chown-R$USER/usr/local

参考:http://howtonode.org/introduction-to-npm

其他回答

你可以试试这个,在ubuntu和mac上工作

sudo chown -R $(whoami) /usr/local/lib/node_modules

当您运行npm install-g somepackage时,可能会收到EACES错误,要求您以root/Administrator身份再次运行该命令。这是权限问题。

很容易修复,打开终端(应用程序>实用程序>终端)

sudo chown -R $USER /usr/local/lib/node_modules

**我强烈建议您不要将包管理与sudo一起使用(sudo npm-g install something),因为稍后可能会遇到一些问题**

参考:http://foohack.com/2010/08/intro-to-npm/

我喜欢使用ubuntu组来实现这一点,而不是更改所有者。这很简单。

首先使用apt-get安装nodejs和npmsudo apt-get更新和sudo apt-get安装nodejs npm找出登录者,即用户名,运行以下命令在终端中查看哇哦您可以使用一个非常简单的命令查看分配给您的组列表,通常第一个组是您的用户名本身组运行以下命令以允许登录用户访问sudo chmod 777-R/usr/local&&sudo chgrp$(whoami)-R/usr/local更新npm和nodejsnpm安装-g npm

你已经做好了准备,你的用户可以在没有sudo的情况下运行npm命令

您也可以参考此链接https://askubuntu.com/a/1115373/687804

我在安装凹槽时遇到了这个问题(https://github.com/twitter/recess)为Bootstrap 3编译CSS。

安装凹槽时:

-npm install recess -g

你需要解锁主目录中的权限,比如Noah说:sudo chown-R`whoami`~/.npm您还需要对node_modules目录的写入权限,如Xilo因此,如果它仍然不起作用,请尝试:sudo chown-R“whoami”/usr/local/lib/node_modules如果仍然看到错误,可能还需要更正/usr/local权限:sudo chown-R“whoami”/usr/local

请注意,如本文所述,如果您在Mac上,/usr/local/实际上不是一个系统目录,因此,这个答案实际上对Mac用户来说非常“安全”。然而,如果您使用的是Linux,请参阅Christopher Will下面的答案,以获得一个多用户友好、系统目录安全(但更复杂)的解决方案。

我通过将所有者从root更改为用户名来解决问题

sudo chown-Rme:me/home/me/.config/configstore/

用您的用户名和组更改我。