JavaScript

Fix “Error:0308010C:digital envelope routines::unsupportedFixing” in Node.js

Advertisements

Node 17 introduced OpenSSL v3.0, which brought in some breaking changes, and the “Error: error:0308010C:digital envelope routines::unsupported” is a result of one such change. It can be solved by passing in a “–openssl-legacy-provider” flag when running the application.

Setting the NODE_OPTIONS environment variable

We can set the environment variable that allows us to continue using the legacy provider. These are called legacy because they are not supported anymore and have security vulnerabilities. This is the quickest fix in the short term but one that should not be used long-term.

export NODE_OPTIONS=--openssl-legacy-provider
Bash

Or if we were using Windows:

export NODE_OPTIONS=--openssl-legacy-provider
Bash

React scripts

For react-scripts, setting the environment variable is not enough. We need to pass the flag using Webpack to the scripts themselves. This can be done using the package.json commands:

{
  "scripts": {
    "start": "react-scripts start --openssl-legacy-provider",
  }
}
JavaScript

Note: You might run into the “node: –openssl-legacy-provider is not allowed in node_options” error on other projects on the machine if you only set NODE_OPTIONS and do not fix the underlying issue.

Upgrade Node and npm packages

As mentioned earlier, the legacy options are a quick fix but one that we should avoid. Instead, we should upgrade to the latest versions to be more secure.

Upgrading OpenSSL on our machine

We might need to update the local version of OpenSSL installed on our machine before upgrading packages that rely on it. For Mac, we need to run:

brew update
brew upgrade openssl
Bash

And for Ubuntu/Debian:

sudo apt-get update
sudo apt-get upgrade openssl
Bash

And CentOS/RHEL:

sudo yum update openssl
Bash

Finding packages that rely on older OpenSSL

To find out which package is using an outdated version of OpenSSL, we can run the command:

npm audit fix
Bash

It will audit our project’s dependency tree and try fixing packages with known vulnerabilities.

There is also a –force flag if we want to force it to fix the packages with known vulnerabilities.

npm audit fix --force
Bash

The force flag can potentially break our project.

The yarn equivalent for these is:

yarn-audit-fix
Bash

Upgrading to Webpack 5

Webpack v5.61.0 fixed the “error:0308010C:digital envelope routines::unsupported” error. So we might want to upgrade to a version higher than that using:

npm i webpack@latest
Bash

Or

yarn add webpack@latest
Bash

React scripts

React scripts similarly fixed the “error:0308010C:digital envelope routines::unsupported” error in v5. So we can upgrade to them using:

npm i react-scripts@latest
Bash

Or

yarn add react-scripts@latest
Bash

Similarly, if we were using some other CLI, we’d need to re-install the version that stopped relying on the outdated OpenSSL version.

After updating the packages, we might still end up in an error state because of cached dependencies. To clean our cache, we need to run the following command:

npm cache clean --force
Bash

And do a clean install thereafter.

npm i
Bash

Downgrade to v16

This is yet another short-term solution, which is a last resort, but sometimes things are not working, and we don’t have the time to figure it out. In those cases, we can just downgrade to Node 16 and not bother with the “error:0308010C:digital envelope routines::unsupported” error at all. If using nvm, we need to run:

nvm install 16.13.0
nvm use 16.13.0
Bash

And those are all the possible ways to fix the “Error:0308010C:digital envelope routines::unsupportedFixing” error in Node.js. Let us know in the comments below if you have any questions or are stuck with something.

Saransh Kataria

Born in Delhi, India, Saransh Kataria is the brain behind Wisdom Geek. Currently, Saransh is a software developer at a reputed firm in Austin, and he likes playing with new technologies to explore different possibilities. He holds an engineering degree in Computer Science. He also shares his passion for sharing knowledge as the community lead at Facebook Developer Circle Delhi, NCR which is a developer community in Delhi, India.

Share
Published by
Saransh Kataria

Recent Posts

Remapping keyboard keys to avoid Carpal Tunnel

I am terrible at optimizing my keyboard layout for anything. But off lately, my little…

2 months ago

Fixing cookies are blocked for a website with shields down on Brave

I recently switched completely to the Brave browser and have set ad blocking to aggressive…

6 months ago

Generating a QR code using Node.js

I was preparing a slide deck for a hackathon and decided to put in a…

7 months ago

How to clear the global npx cache

I have been using npx a lot lately, especially whenever I want to use a…

7 months ago

Copy/Pasting output from the terminal

Manually copy-pasting the output of a terminal command with a mouse/trackpad feels tedious. It is…

8 months ago

How To Get The Hash of A File In Node.js

While working on a project, I wanted to do an integrity check of a file…

8 months ago
Advertisements