You can scan all files that are in
uploads directory and see which ones are actually in Media Library and which ones are just sitting there. Then you can select files you want to import to the database and therefore make them available in Media Library.
You can also use FTP to upload your files to
uploads directory and bring those files into Media Library.
Please read before adding a support topic. Reviews are not intended for support or suggestions.
This plugin makes database changes (
wp_postmetatables), and it was primarily developed to help other developers that are aware of the consequences.
“1 file first”
Please be careful and try to import only one file first, to see if it works.
“All at once”
This plugin is focused on scanning, selecting, and importing all files at once. So it might not be great for huge amounts of files, since it can use up a lot of memory. Future versions will hopefully solve that problem. For now, you can try to go to Settings -> Media Sync and set it to scan only a specific directory.
“Your setup is unique”
Please keep in mind that each WordPress installation is unique, so it’s quite possible this plugin will not work in your case. If that happens, please turn on debugging in settings of this plugin, try to figure out why you have that problem, and then describe what you found in the Support section. The more details we have – it’s more likely the problem will be solved.
- various hidden files (.DS_Store, .htaccess),
- WP generated thumbnails (files ending with for example -100×100.jpg),
- WP generated scaled images (files ending with -scaled),
- optimized .webp versions of original images (.jpg.webp),
- retina thumbnails (-100×email@example.com).
This is now configurable with a custom hook function and it can totally overwrite these rules or add additional ones.
media-syncdirectory to the
- Activate the plugin through the ‘Plugins’ menu in WordPress
Stuck at importing / spins endlessly
Please try to increase
php.inion server (as described here). Or if you have too many files, try going to Settings -> Media Sync and change “Scan directory” to some inner folder.
Files not showing up in Media Library
Please make sure “Dry Run” option is NOT checked. This is a safety mechanism to make sure you know what you’re doing, so be careful, try it first with just one file.
Please first try to turn on debugging in Settings -> Media Sync and check Network tab in Chrome DevTools to see what is going on in the background. Then report actual errors since it’s hard to help without knowing the error which is causing the problem.
Contributors & Developers
“Media Sync” is open source software. The following people have contributed to this plugin.Contributors
- Ignore optimized .webp versions of original images (e.g. .jpg.webp) and retina thumbnails (e.g. -100×firstname.lastname@example.org) by default. It’s still possible to customize it with
- New option to set custom Batch Size. This might help with errors due to server limits (e.g. max_execution_time).
- Fix selecting multiple files without clicking on checkbox (e.g. shift-select).
- Minor code cleanup.
- Update supported WordPress version to 6.2.
- Create a custom
wp_postmetatable to be able to differentiate files imported using this plugin. Could be useful to clean up the database later on.
- Extend plugin access to “Editor” and “Author” roles.
- If debugging is turned on, AJAX requests for import are now
htmlwhich is rendered directly in UI.
- New filter hook (
media_sync_filter_before_update_metadata) which can be used to customize how metadata is updated or to run additional actions after file import.
- Handle files with quotes (apostrophes) or other special characters in the file name.
- Continue importing other selected files if there was an error with some of the files.
- Show errors in UI instead of alert.
- Better error handling and fallback when finding mime type
- Fix meta data errors caused by invalid mime types
- Much better error handling while importing
- Optimized directory scanning to use less memory
- New option to turn on debugging for this plugin
- Changed parameters passed to
- Now requires PHP 5.5
- Fix handling big (“-scaled.jpg”) images introduced in WordPress 5.3. These files will now be skipped and won’t be imported multiple times.
- Add handy “Re-scan” button.
- Fix issues when importing files containing special characters
- Always convert backslashes (“\”) to forward slashes (“/”) to fix various issues when using Windows Server.
- Important backslash (“\”) vs forward slash (“/”) fix for use on Windows Server.
- New option to set “Scan directory” in settings which will allow checking only certain sub directory.
- New hook function
media_sync_filter_is_scan_object_ignoredwhich can be used to overwrite which files are ignored by default or to just skip additional files.
- Fix Smart File Time on Windows server
- Reduce the maximum number of items to import per batch from 20 to 10.
So batch sizes are now: 1 (importing 1 to 10 items); 5 (importing 11 to 100 items) or 10 (importing more than 100 items)
- [IMPORTANT] Date of imported Media Library items now defaults to the current date.
But there are options to choose before importing and also a possibility to overwrite that using the custom hook.
- New options page with the option to disable and hide “Dry Run”.
- Fix Media Library filter that was showing all items when the filter didn’t find any result.
- Reduce the number of items to import per batch
- Support multisite network by changing required access capability from
- Another fix for get_current_screen error
- Fix get_current_screen error
- New option to clean up Media Library from items that are missing actual files (using custom Media Library filter)
- New filter when scanning uploads directory which can help to show only files missing from Media Library
- Fix PHP short array syntax
- Update required PHP version to 5.4
- Date of imported Media Library item is now set based on file modification timestamp
- Add plugin localization
- Add Serbian translation
- Various improvements and fixes
- Fix sorting of directories and files
- Minor wording changes and code cleanup
- Fix error on activation
- Initial plugin features