Where an electron application's sessionStorage and localStorage stored?
Asked Answered
D

3

23

I am running an electron app, where in its renderer process I use HTML5 localStorage.
I'm interested to know where in my file-system is this localStorage actually stored (I believe it is in SQLite format).
I saw the answer for where is a browser localStorage stored, here: Where the sessionStorage and localStorage stored?

I'm asking this because I would like to be able to run 2 instances of this electron application, so that each application will have different settings in which I save in localStorage.
Specifically I'm most interested in windows 10, but an answer wrapping all OS will be great.

Depute answered 11/5, 2017 at 10:33 Comment(0)
D
20

It's stored in the AppData folder, which you can find by looking at the value of require('electron').app.getPath('userData').

This means the data persists even if the app is deleted. If you're running two instances, you'll need to find some way of distinguishing between them so they don't trample on each other's data.

Disputatious answered 11/5, 2017 at 11:0 Comment(1)
Excellent, that worked for me. BTW, the way I was able to launch 2 instances of the application where each loads different settings stored in localStorage, was to launch each with a different domain, e.g. a different port on localhost - thus each receives a different localStorage.Depute
P
13

I had to use the following in my Electron app to get it working:

  const remote = require('electron').remote;
  const app = remote.app;
  app.getPath('userData');

However, the path where it stores the data is under:

\Local Storage\leveldb\

So your entire path will look something like:

C:\Users\<USER-NAME>\AppData\Roaming\<APP-NAME>\Local Storage\leveldb\

Log File : Not Sqlite DB Even though the browser (FireFox in my case) stores localStorage data in a sqlite file, it seems that Electron does not.

Instead, it saves the data in a an odd .log file mine was named 000003.log.

Here's what it looks like after I ran three localStorage.setItem() commands from my app's console.

example .log file

Here's a look at the console of my Electron app where I ran the three commands. You can match up the commands with the data in the 000003.log file if you look closely at the images.

console localStorage.setItem

Further Proof This Is the Storage Location/Mechanism

If I run localStorage.getItem("fakeData") in my console then the value is returned.

localStorage.getItem

However, if you :

  1. close the Electron app (have to close app because it has log file locked)
  2. delete (or move) the 000003.log file (or whatever yours is named)
  3. Start the Electron app again
  4. open the console
  5. make a call to localStorage.getItem("fakeData")

You will get no value returned.

null is returned

Now to complete the cycle:

  1. stop your Electron app
  2. copy the log file back into your leveldb\ directory (you'll have to overwrite one that was created with your last start)
  3. start your Electron app
  4. open the console
  5. run the localStorage.getItem() again.

You'll see the value again.

LevelDB : Google Thing

I was contemplating that crazy format and then I thought about the name of that final directory (leveldb). I did a duckduckgo and found this: https://github.com/google/leveldb

So I'm guessing that is the format since Electron is using the Chrome engine.

From Wikipedia :

LevelDB is an open-source on-disk key-value store written by Google fellows Jeffrey Dean and Sanjay Ghemawat. Inspired by Bigtable, LevelDB is hosted on GitHub under the New BSD License and has been ported to a variety of Unix-based systems, macOS, Windows, and Android.

Penicillate answered 19/9, 2019 at 15:45 Comment(0)
S
1

With this code you add a sub-section to the Help section that when's clicked it will open the Local Storage folder in the file explorer.

In the main.js in /electron:

const {
  app,
  BrowserWindow,
  screen: electronScreen,
  shell,
  Menu,
} = require('electron');
...

const menuTemplate = [
  {
    role: 'help',
    submenu: [
      {
        label: 'Open Local Storage Folder',
        click: () => {
          const userData = app.getPath('userData');
          shell.showItemInFolder(`${userData}/Local Storage/leveldb`);
        },
      },
    ],
  },
];

const menu = Menu.buildFromTemplate(menuTemplate);
Menu.setApplicationMenu(menu);
Scrouge answered 21/12, 2023 at 20:36 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.