我刚刚通过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

当前回答

如果sudo chown-R$(whoami)~/.npm不适合您,或者您需要非终端命令解决方案。

问题是您的用户帐户没有node_modules文件夹的写入权限,因此您可以执行以下操作

打开finder并按cmd+shift+g,这将打开带有url的文件夹编写以下路径/usr/local/lib/node_modules并按go右键单击node_modules文件夹并选择Get Info向下滚动到共享权限部分(&P)解锁以进行更改。按+并添加用户帐户确保在权限下拉列表中选择“读写”

现在,您应该能够在没有sudo的情况下安装软件包,并且应该解决权限问题

其他回答

这就是我在Windows 8.1上解决问题的方法:

转到nodejs安装(通常为C:\Program Files\nodejs)右键单击node_modules文件夹并转到财产单击“安全”选项卡,然后进行高级在顶部,您将看到“所有者:系统”,单击更改输入您需要权限的用户,然后单击“确定”选中高级设置底部的复选框“将所有子对象权限条目替换为此对象的可继承权限条目”,然后单击“确定”执行所需的npm安装/更新

要正确配置NPM,请运行以下命令:

npm config set prefix '~/.npm_packages'
PATH=$PATH:$HOME/.npm_packages/bin; export PATH

对于Mac(采用Christoper Will的答案)

Mac OS X 10.9.4

系统首选项>用户和组>(解锁)>按+:新建帐户>“组”帐户名:nodegrp创建组后,勾选要包含在此组中的用户sudo chgrp-R nodegrp/usr/local/lib/node_modules/sudo chgrp nodegrp/usr/bin/nodesudo chgrp节点组/usr/bin/npmsudo chown-R$(whoami):nodegrp~/.npm

我在安装凹槽时遇到了这个问题(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下面的答案,以获得一个多用户友好、系统目录安全(但更复杂)的解决方案。

其他答案是建议将系统目录的所有权或权限更改为特定用户。我强烈反对这样做,这可能会变得非常尴尬,可能会搞乱整个系统!

这里有一种更通用、更安全的方法,也支持多用户。

为节点用户创建新组,并将所需用户添加到此组。然后将依赖于节点的文件/目录的所有权设置为此组。

# Create new group
sudo groupadd nodegrp 

# Add user to group (logname is a variable and gets replaced by the currently logged in user)
sudo usermod -a -G nodegrp `logname`

# Instant access to group without re-login
newgrp nodegrp

# Check group - nodegrp should be listed as well now
groups

# Change group of node_modules, node, npm to new group 
sudo chgrp -R nodegrp /usr/lib/node_modules/
sudo chgrp nodegrp /usr/bin/node
sudo chgrp nodegrp /usr/bin/npm

# (You may want to change a couple of more files (like grunt etc) in your /usr/bin/ directory.)

现在,您可以以用户身份轻松安装模块

npm install -g generator-angular

某些模块(咕噜、弓箭手、溜溜球等)仍需要作为根安装。这是因为它们在/user/bin/中创建符号链接。

Edit

3年后,我建议使用节点版本管理器。它为你节省了很多时间和麻烦。