Errore con la finestra mobile e reagire, digitale busta routine::non supportato

0

Domanda

Mi sono iscritto a un mobile e il corso di istruttore ha fornito un progetto starter con alcuni piuttosto vecchio reagire codice.

Ho dockerized il progetto react, ecco la semplice Dockerfile:

FROM node

WORKDIR /app

COPY package.json .

RUN npm i

COPY . .

EXPOSE 3000

CMD ["npm", "start"]

Poi ho costruito l'immagine:

docker build -t goals-react .

E corse come un contenitore in allegato modalità:

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

Questo è l'output che ho ricevuto:

> [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

Ho pensato che fosse perché il progetto react stava usando una vecchia versione di reagire, così ho aggiornato il pacchetto.json file con i seguenti comandi:

npx npm-check-updates -u
npm install

Quindi ho cancellato e ricreato l'immagine, e poi corse in un nuovo contenitore:

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

Ma con mia grande sorpresa, ho ricevuto lo stesso errore. Così ho cercato su google digital envelope routines::unsupported e ho trovato ancora un altro stackoverflow discussione.

Ho eseguito il seguente comando:

export NODE_OPTIONS=--openssl-legacy-provider

Poi ho ricostruito l'immagine e riavviato il contenitore, ma senza alcun risultato. Ho deciso di leggere il messaggio di errore più a fondo e sembra essere un webpack errore. Sono andato al webpack pagina di github, e mi resi conto che qualcun altro ha avuto lo stesso problema, proprio qui, tuttavia, la questione è chiusa. Hanno anche raccomandato il comando di cui sopra, ma che, ovviamente, non funziona per me.

Grazie in anticipo per tutte le risposte e l'aiuto.

Modifica:

Come richiesto da @MikiBelavista, qui è il pacchetto.file json:

{
  "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

Migliore risposta

1

Cambiare la vostra linea

"start": "react-scripts start",

per

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

Ma essere consapevoli di che OpenSSL implementazioni di algoritmi che sono stati ritenuti legacy. Più OpenSSl

2021-11-24 07:37:17
0

Aggiornamento del pacchetto.json "start" script:

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

Assicurarsi che si ricostruisce la finestra mobile immagine, altrimenti si otterrà lo stesso errore.

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

In altre lingue

Questa pagina è in altre lingue

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