ffmpeg.wasm
                                
                                 ffmpeg.wasm copied to clipboard
                                
                                    ffmpeg.wasm copied to clipboard
                            
                            
                            
                        ReferenceError: SharedArrayBuffer is not defined
Describe the bug
Getting a ReferenceError: SharedArrayBuffer is not defined error after [info] ffmpeg-core.js script loaded
To Reproduce Simply initialize FFmpeg on Firefox
Expected behavior It should work as usual on Firefox, but it cannot properly initialize
Screenshots

Desktop (please complete the following information):
- OS: Windows 10 x64 21H1
- Browser: Firefox 92.0.1
Additional context This is my repository
as the Readme states:
SharedArrayBuffer is only available to pages that are cross-origin isolated. So you need to host your own server with
Cross-Origin-Embedder-Policy: require-corpandCross-Origin-Opener-Policy: same-originheaders to use ffmpeg.wasm.
SharedArrayBuffer is not available until you do add these headers
and in Safari it will never be available, because SharedArrayBuffer is disabled there
https://caniuse.com/sharedarraybuffer
The reason I made my browser extension in the first place is that it doesn't need a server to work but instead use the user's computational power
as the Readme states:
SharedArrayBuffer is only available to pages that are cross-origin isolated. So you need to host your own server with
Cross-Origin-Embedder-Policy: require-corpandCross-Origin-Opener-Policy: same-originheaders to use ffmpeg.wasm.SharedArrayBuffer is not available until you do add these headers
and in Safari it will never be available, because SharedArrayBuffer is disabled there
https://caniuse.com/sharedarraybuffer
I add these headers when getting my html page and it works.But now I have trouble with add third party JS in my page,which will be blocked by cross-origin isolated. Any work around method to use third party JS in my video edit page(with wasm)?
Dumb question from someone who knows nothing - what would it take / would it even be possible to rewrite this not to use SharedArrayBuffer?
Given the current state of how difficult it is to use, seems like if it's possible, it'd be worth it.
Even if you manage to rewrite it in a different way, I doubt the progress of releases A couple of pull requests have been merged (including my #232), but the last release was on June 14
If there is someone using vite for development environment. https://github.com/chaosprint/vite-plugin-cross-origin-isolation
@Fanna1119 This doesn't solve the issue in a live environment
Hello, in react easier way is using this library: https://create-react-app.dev/docs/proxying-api-requests-in-development/#configuring-the-proxy-manually
With this you can create a proxy, in the proxy you will be able to set the headers, example bellow:
module.exports = function (app) {
    app.use(function (req, res, next) {
        res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
        res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
        next();
    });
    app.use(
        '/api',
        createProxyMiddleware({
          target: 'http://localhost:8080',
          changeOrigin: true,
        })
      );
};
I really don't know how to deal with this in SPAs production env, but for server-client applications it should work fine (for example react SSR).
Safari now has support for SharedArrayBuffer as of March 2022 https://caniuse.com/sharedarraybuffer
Hello, in react easier way is using this library: https://create-react-app.dev/docs/proxying-api-requests-in-development/#configuring-the-proxy-manually
With this you can create a proxy, in the proxy you will be able to set the headers, example bellow:
I had to tune your example for it to work with React. Beware that even when running a Typescript react project, you need to write this as a setupProxy.JS (and not .TS):
module.exports = function (app) {
    app.use(function (req, res, next) {
        res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
        res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
        next();
    });
};
For SPAs, you don't need to create a proxy middleware, you just need to intercept the req/resp and add your headers.
Also, you don't need to install http-proxy-middleware at all for this to work. It just works straight out of the box on React apps.
For developing in vite, you can set the vite.config.js:
export default {
  server: {
    headers: {
      'Cross-Origin-Embedder-Policy': 'require-corp',
      'Cross-Origin-Opener-Policy': 'same-origin',
    },
  },
};
Anyone who's using Next.js,
here's my next.config.js file and it works perfectly
// next.config.js
/** @type {import('next').NextConfig} */
const nextConfig = {
  reactStrictMode: true,
  async headers() {
    return [
      {
        source: '/',
        headers: [
          {
            key: 'Cross-Origin-Embedder-Policy',
            value: 'require-corp',
          },
          {
            key: 'Cross-Origin-Opener-Policy',
            value: 'same-origin',
          },
        ],
      },
    ];
  },
};
module.exports = nextConfig;
I've created a setupProxy.js file for my React app, and have installed http-proxy-middleware suggested on the link, but the following code doesn't seem to work for me.
module.exports = function (app) {
    app.use(function (req, res, next) {
        res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
        res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
        next();
    });
};
It doesn't seem like this module.exports is getting called when I run npm start I continue to get the error Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined.
I'm trying to follow along this React/ffmpeg WASM tutorial. I'm using Chrome 103, ffmpeg wasm 0.10.0, snowpack 2.1, react 17.0.2
as the Readme states:
SharedArrayBuffer is only available to pages that are cross-origin isolated. So you need to host your own server with
Cross-Origin-Embedder-Policy: require-corpandCross-Origin-Opener-Policy: same-originheaders to use ffmpeg.wasm.SharedArrayBuffer is not available until you do add these headers
and in Safari it will never be available, because SharedArrayBuffer is disabled there
https://caniuse.com/sharedarraybuffer
It is now available though, no?
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer#browser_compatibility
module.exports = function (app) {
    app.use(function (req, res, next) {
        res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
        res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
        next();
    });
};
It is working on my side (React : 17.0.2, ffmpeg wasm: 0.10.3, chrome 103), but all the social logins (google, Microsoft, apple) does not work. All return the error saying pop up is closed by user.
Will be any solutions?
anyone use UmiJS ?
Permanant solution of Shared Array buffer is not define in react js when i am include fbsdk in my project
#484 #483 #190 #482 #402 #121 #469
for someone working with php, writing this code to the php file that contains the html document worked for me.
<?php
header("Cross-Origin-Embedder-Policy: require-corp");
header("Cross-Origin-Opener-Policy: same-origin");
?>
Has anyone found a solution for Nuxt 3? It did not manage to overcome this issue.
Whenever I load ffmpeg, I get the error, and establishing these headers did not help.
f1f71c-7747-4977-969e-ea0d6790910b:22 Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined at b2f1f71c-7747-4977-969e-ea0d6790910b:22:175 at Object.load (createFFmpeg.js:117:20) at async load (app.vue:15:3) (
For next js ,having following type of config worked for me.
`/** @type {import('next').NextConfig} */ const nextConfig = { reactStrictMode: true, async headers() { return [ { source: '/', headers: [ { key: 'Cross-Origin-Embedder-Policy', value: 'require-corp', }, { key: 'Cross-Origin-Opener-Policy', value: 'same-origin', }, ], }, ] }
webpack(config, { webpack }) { config.module.rules.push({ test: /.svg$/, use: ['@svgr/webpack'], })
config.plugins.push(
  new webpack.IgnorePlugin({
    resourceRegExp: /^\.\/wordlists\/(?!english)/,
    contextRegExp: /bip39\/src$/,
  })
)
config.resolve.alias = {
  ...config.resolve.alias,
  assets: getSharedPath('assets'),
  components: getSharedPath('components'),
  containers: getSharedPath('containers'),
  layouts: getSharedPath('layouts'),
  lib: getSharedPath('lib'),
  screens: getSharedPath('screens'),
  store: getSharedPath('store'),
  styles: getSharedPath('styles'),
}
return config
} env: {
}, }
module.exports = nextTranslate(withTM(withPWA(nextConfig)))`
All the sudden, like right now, the headers are not enough. There's an experimental Chrome flag but even that doesn't expose the SharedMemoryBuffer. It worked yesterday and even 10 minutes ago...
This WAS my workaround - https://vercel.com/guides/fix-shared-array-buffer-not-defined-nextjs-react
I have all the headers set via php. I confirmed the headers were set in the response.
header("Cross-Origin-Opener-Policy: same-origin"); header("Cross-Origin-Embedder-Policy: require-corp");
Broken in Edge/Chrome.
Firefox is still okay.
WebView2 browser is okay - https://learn.microsoft.com/en-us/microsoft-edge/webview2/samples/webview2browser?source=recommendations
I restarted my Chrome and the issue seems to have gone away. So I'm not sure what caused it. It's just odd that Chrome/Edge had the issue at the same time.
I had the same issue just start recently on a Chrome 114 build using a different wasm project. Previously I had NOT enabled:
Cross-Origin-Opener-Policy
I only enabled
Cross-Origin-Embedder-Policy
and everything worked. Now the Opener policy seems to be required also.
Has anyone found a solution for Nuxt 3? It did not manage to overcome this issue.
Whenever I load ffmpeg, I get the error, and establishing these headers did not help.
f1f71c-7747-4977-969e-ea0d6790910b:22 Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined at b2f1f71c-7747-4977-969e-ea0d6790910b:22:175 at Object.load (createFFmpeg.js:117:20) at async load (app.vue:15:3) (
I am also using nuxt 3. DId you find a solution for this?
Has anyone found a solution for Nuxt 3? It did not manage to overcome this issue. Whenever I load ffmpeg, I get the error, and establishing these headers did not help.
f1f71c-7747-4977-969e-ea0d6790910b:22 Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined at b2f1f71c-7747-4977-969e-ea0d6790910b:22:175 at Object.load (createFFmpeg.js:117:20) at async load (app.vue:15:3) (I am also using nuxt 3. DId you find a solution for this?
Sadly not @dataexcess. I had to move to React to make it work.
Has anyone found a solution for Nuxt 3? It did not manage to overcome this issue. Whenever I load ffmpeg, I get the error, and establishing these headers did not help.
f1f71c-7747-4977-969e-ea0d6790910b:22 Uncaught (in promise) ReferenceError: SharedArrayBuffer is not defined at b2f1f71c-7747-4977-969e-ea0d6790910b:22:175 at Object.load (createFFmpeg.js:117:20) at async load (app.vue:15:3) (I am also using nuxt 3. DId you find a solution for this?
Sadly not @dataexcess. I had to move to React to make it work.
Hey! Using this nuxt plugin "nuxt-security" fixed it for me ! :D
https://snyk.io/blog/adding-security-to-nuxt-3/
I can still reproduce the issue. If you use a lot of memory by using a canvas element and capture a lot of frames with getImageData into memory, somehow the added memory knocks out the settings. And even if both headers are present you get the SharedMemoryBuffer error.
I thought the workaround was to kill all your browser instances and relaunch. But it still happens so I have to use one of the browsers that still works.
Hmmm Firefox is showing duplicate headers, that might be the problem.
I had a .htaccess adding the headers and php adding the headers. So if you have a duplicate header it is discarded and SharedMemoryBuffer goes away.
After I fixed the duplicate header issue, it's working normally.
For anyone trying to find a solution when hosting on netlify for instance, you can use : https://github.com/gzuidhof/coi-serviceworker which makes it available.
So, ive run into this issue too now. I added the stuff to my htaccess but its not working. When running the included example server on my local machine it works but when running it on my remote system under apache2, firefox keeps complaining. I have tried putting it in the .htaccess, in php and even tried writing it from javascript after the page loaded (which doesnt work btw but still tried it because i am really desperate to get this working). For htaccess and php it shows up in firefox when looking at the header but the browser seems to just ignore it and throws the error anyways. The same happens in chrome too. If anyone can help me out with that id be really thankful.
I think this issue could be closed because there are multiple solutions presented. According to the third point in https://caniuse.com/?search=SharedArrayBuffer, this is the way to enable support. If this doesn't work for your browser, consider opening an issue in the browser's issue tracker.
How to solve this issue using Github Pages?