Erro com janela de encaixe e reagir, digital envelope rotinas::não suportado

0

Pergunta

Eu tenho matriculados em uma janela de encaixe do curso e o professor tem fornecido uma partida de projeto com algumas bastante antigas reagir código.

Eu dockerized a reagir projeto, aqui é o simples Dockerfile:

FROM node

WORKDIR /app

COPY package.json .

RUN npm i

COPY . .

EXPOSE 3000

CMD ["npm", "start"]

Aí, eu fiz a imagem:

docker build -t goals-react .

E correu para um recipiente anexadas modo:

docker run --name goals-app --rm -p 3000:3000 goals-react

Esta é a saída que eu recebi:

> [email protected] start
> react-scripts start

ℹ 「wds」: Project is running at http://172.17.0.4/
ℹ 「wds」: webpack output is served from
ℹ 「wds」: Content not from webpack is served from /app/public
ℹ 「wds」: 404s will fallback to /

Starting the development server...

Error: error:0308010C:digital envelope routines::unsupported
    at new Hash (node:internal/crypto/hash:67:19)      
    at Object.createHash (node:crypto:130:10)
    at module.exports (/app/node_modules/webpack/lib/util/createHash.js:135:53)
    at NormalModule._initBuildHash (/app/node_modules/webpack/lib/NormalModule.js:417:16)
    at handleParseError (/app/node_modules/webpack/lib/NormalModule.js:471:10)
    at /app/node_modules/webpack/lib/NormalModule.js:503:5
    at /app/node_modules/webpack/lib/NormalModule.js:358:12
    at /app/node_modules/loader-runner/lib/LoaderRunner.js:373:3
    at iterateNormalLoaders (/app/node_modules/loader-runner/lib/LoaderRunner.js:214:10)
    at iterateNormalLoaders (/app/node_modules/loader-runner/lib/LoaderRunner.js:221:10)
/app/node_modules/react-scripts/scripts/start.js:19
  throw err;
  ^

Error: error:0308010C:digital envelope routines::unsupported
    at new Hash (node:internal/crypto/hash:67:19)      
    at Object.createHash (node:crypto:130:10)
    at module.exports (/app/node_modules/webpack/lib/util/createHash.js:135:53)
    at NormalModule._initBuildHash (/app/node_modules/webpack/lib/NormalModule.js:417:16)
    at /app/node_modules/webpack/lib/NormalModule.js:452:10
    at /app/node_modules/webpack/lib/NormalModule.js:323:13
    at /app/node_modules/loader-runner/lib/LoaderRunner.js:367:11
    at /app/node_modules/loader-runner/lib/LoaderRunner.js:233:18
    at context.callback (/app/node_modules/loader-runner/lib/LoaderRunner.js:111:13)
    at /app/node_modules/babel-loader/lib/index.js:59:103 {
  opensslErrorStack: [ 'error:03000086:digital envelope routines::initialization error' ],
  library: 'digital envelope routines',
  reason: 'unsupported',
  code: 'ERR_OSSL_EVP_UNSUPPORTED'
}

Node.js v17.1.0

Achei que era porque a reagir projeto foi utilizar uma versão antiga de reagir, então eu atualizei o pacote.json arquivo com os seguintes comandos:

npx npm-check-updates -u
npm install

Então eu removida e recriada a imagem e, em seguida, correu para um novo recipiente:

docker rmi goals-react
docker build -t goals-react .
docker run --name goals-app --rm -p 3000:3000 goals-react

Mas, para minha surpresa, recebi o mesmo erro. Então, eu pesquisei digital envelope routines::unsupported e eu encontrei ainda outra stackoverflow discussão.

Eu executei o seguinte comando:

export NODE_OPTIONS=--openssl-legacy-provider

Então eu reconstruiu a imagem e reiniciado o recipiente, mas sem sucesso. Eu decidi ler a mensagem de erro mais a fundo e parece ser um webpack erro. Eu fui para o webpack github página e percebi que alguém tinha o mesmo problema, aqui, no entanto, a questão está fechada. Eles também recomendado o comando acima, mas que, obviamente, não funciona para mim.

Agradecemos antecipadamente por qualquer feedback e ajuda.

Editar:

Conforme solicitado pelo @MikiBelavista, aqui está o pacote.json arquivo:

{
  "name": "frontend",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@testing-library/jest-dom": "^5.15.1",
    "@testing-library/react": "^12.1.2",
    "@testing-library/user-event": "^13.5.0",
    "react": "^17.0.2",
    "react-dom": "^17.0.2",
    "react-scripts": "4.0.3"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },
  "eslintConfig": {
    "extends": "react-app"
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  }
}

docker node.js reactjs webpack
2021-11-24 04:43:15
2

Melhor resposta

1

Mudar sua linha

"start": "react-scripts start",

para

"start": "react-scripts --openssl-legacy-provider start"

Mas esteja ciente de que o OpenSSL implementações de algoritmos, que têm sido consideradas legado. Mais OpenSSl

2021-11-24 07:37:17
0

O pacote de actualização.json "iniciar" script para ler:

"start": "react-scripts --openssl-legacy-provider start"

Certifique-se de reconstruir a janela de encaixe imagem, caso contrário, você obterá o mesmo erro.

docker build --pull --rm -f "Dockerfile" -t yourappname:latest "."
2021-12-08 21:53:56

Em outros idiomas

Esta página está em outros idiomas

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................