«npm install bcrypt» завершается с ошибкой «Ошибка: не удается найти модуль 'nan'" - PullRequest
0 голосов
/ 18 января 2019

Я пытаюсь заставить мой существующий проект Angular работать на новом ноутбуке, и его запуск и запуск сводят меня с ума. Вот что я сделал:

git init 
git clone <project>
cd <project directory>
delete package-lock.json
npm install
npm install --global --production windows-build-tools
npm install bcrypt

Предпоследний шаг - убедиться, что зависимости bcrypt установлены на https://github.com/kelektiv/node.bcrypt.js/wiki/Installation-Instructions (поймал меня ранее). Но независимо от того, что я пытаюсь, я получаю ошибку, указанную в конце этого поста.

Я проверил папку node_modules, и зависимость 'nan' существует. несмотря на это, я попытался установить его снова (локально и глобально на ошибка узла не может найти модуль, уже установленный ), и он установился нормально. 'nan' также указан в файле package.json.

Я пытался:
* This: Ошибка: не удается найти модуль 'nan'
* Удаление узла как это: Как полностью удалить node.js из Windows а также удаление всех установок python, которые я могу найти на компьютере (включая установку v3, которая, по моему мнению, могла быть конфликтующей, но, похоже, это не было проблемой).
* Кроме этого Google выходит пустым.
* Перерыв и ожидание божественного вдохновения тоже не сработали.

Вот ошибка:

node-pre-gyp WARN Using request for node-pre-gyp https download
node-pre-gyp WARN Tried to download(404): https://github.com/kelektiv/node.bcrypt.js/releases/download/v3.0.3/bcrypt_lib-v3.0.3-node-v64-win32-x64-unknown.tar.gz
node-pre-gyp WARN Pre-built binaries not found for bcrypt@3.0.3 and node@10.15.0 (node-v64 ABI, unknown) (falling back to source compile with node-gyp)
internal/modules/cjs/loader.js:583
    throw err;
    ^

Error: Cannot find module 'nan'
    at Function.Module._resolveFilename (internal/modules/cjs/loader.js:581:15)
    at Function.Module._load (internal/modules/cjs/loader.js:507:25)
    at Module.require (internal/modules/cjs/loader.js:637:17)
    at require (internal/modules/cjs/helpers.js:22:18)
    at [eval]:1:1
    at Script.runInThisContext (vm.js:96:20)
    at Object.runInThisContext (vm.js:303:38)
    at Object.<anonymous> ([eval]-wrapper:6:22)
    at Module._compile (internal/modules/cjs/loader.js:689:30)
    at evalScript (internal/bootstrap/node.js:587:27)
gyp: Call to 'node -e "require('nan')"' returned exit status 1 while in binding.gyp. while trying to load binding.gyp
gyp ERR! configure error
gyp ERR! stack Error: `gyp` failed with exit code: 1
gyp ERR! stack     at ChildProcess.onCpExit (C:\Program Files\nodejs\node_modules\npm\node_modules\node-gyp\lib\configure.js:345:16)
gyp ERR! stack     at ChildProcess.emit (events.js:182:13)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (internal/child_process.js:240:12)
gyp ERR! System Windows_NT 10.0.17134
gyp ERR! command "C:\\Program Files\\nodejs\\node.exe" "C:\\Program Files\\nodejs\\node_modules\\npm\\node_modules\\node-gyp\\bin\\node-gyp.js" "configure" "--fallback-to-build" "--module=C:\\project\\node_modules\\bcrypt\\lib\\binding\\bcrypt_lib.node" "--module_name=bcrypt_lib" "--module_path=C:\\project\\node_modules\\bcrypt\\lib\\binding" "--napi_version=3" "--node_abi_napi=napi" "--napi_build_version=0" "--node_napi_label=node-v64" "--python=C:\\Users\\xxxxx\\.windows-build-tools\\python27\\python.exe"

РЕДАКТИРОВАТЬ 1

Пакет nan установлен по умолчанию. Когда я запускаю npm list nan, я получаю:

aconcagua@0.0.0 C:\project
+-- @angular-devkit/build-angular@0.8.9
| `-- node-sass@4.11.0
|   `-- nan@2.12.1  deduped
+-- @angular/compiler-cli@6.1.10
| `-- chokidar@1.7.0
|   `-- UNMET OPTIONAL DEPENDENCY fsevents@1.2.6
|     `-- nan@2.12.1  deduped
`-- nan@2.12.1

Я также попробовал это и добавил переменные окружения, но не повезло.

Ответы [ 2 ]

0 голосов
/ 22 января 2019

Единственный способ, которым я мог решить эту проблему, это сбросить настройки windows (10) и начать заново. Новый ноутбук, так что не слишком больно. Тем не менее, было бы лучше выяснить, что не так и исправить это ...

0 голосов
/ 18 января 2019

Попробуйте вручную установить nan в правильный подкаталог, т.е.

cd $(npm root -g)/npm && npm install nan
...