Jump to content

Undeletion: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Monkbot (talk | contribs)
m Task 18 (cosmetic): eval 10 templates: hyphenate params (22×);
Unnecessary
 
(14 intermediate revisions by 11 users not shown)
Line 1: Line 1:
{{short description|Feature for restoring computer files}}
{{Selfref|For undeletion on Wikipedia, see [[Wikipedia:Undeletion]].}}


{{refimprove|date=February 2017}}
{{more citations needed|date=February 2017}}
'''Undeletion''' is a feature for restoring [[computer file]]s which have been removed from a [[file system]] by [[file deletion]]. Deleted data can be recovered on many file systems, but not all file systems provide an undeletion feature. Recovering data without an undeletion facility is usually called [[data recovery]], rather than undeletion. Although undeletion can help prevent users from accidentally losing data, it can also pose a [[computer security]] risk, since users may not be aware that deleted files remain accessible.
'''Undeletion''' is a feature for restoring [[computer file]]s which have been removed from a [[file system]] by [[file deletion]]. Deleted data can be recovered on many file systems, but not all file systems provide an undeletion feature. Recovering data without an undeletion facility is usually called [[data recovery]], rather than undeletion. Undeletion can both help prevent users from accidentally [[data loss|losing data]], or can pose a [[computer security]] risk, since users may not be aware that deleted files remain accessible.


==Support==
==Support==
Not all file systems or operating systems support undeletion. Undeletion is possible on all [[File Allocation Table|FAT]] file systems, with undeletion utilities provided since [[MS-DOS 5.0]]<ref>{{cite web |url=http://support.microsoft.com/kb/80496 |title=When Not to Use MS-DOS 5.0 CHKDSK and UNDELETE Commands |publisher=Support.microsoft.com |date=2006-11-16 |access-date=2012-01-09 |url-status=live |archive-url=https://web.archive.org/web/20120202192509/http://support.microsoft.com/kb/80496 |archive-date=2012-02-02 }}</ref><ref>{{cite web |url=http://support.microsoft.com/kb/96824 |title=Using a Common UNDELETE.INI File with Undelete |publisher=Support.microsoft.com |date=1999-11-16 |access-date=2012-01-09 |url-status=live |archive-url=https://web.archive.org/web/20090826172844/http://support.microsoft.com/kb/96824 |archive-date=2009-08-26 }}</ref> and [[DR DOS 6.0]] in 1991. It is not supported by most modern [[UNIX]] file systems, though [[AdvFS]] is a notable exception. The [[ext2]] file system has an add-on program called e2undel<ref>{{cite web|access-date=2020-07-02|title=the e2undel home page|url=http://e2undel.sourceforge.net/|website=e2undel.sourceforge.net}}</ref> which allows file undeletion. The similar [[ext3]] file system does not officially support undeletion, but utilities like ext4magic,<ref>{{cite web|access-date=2020-07-02|url=http://ext4magic.sourceforge.net/ext4magic_en.html|title=Ext4magic|website=ext4magic.sourceforge.net}}</ref> extundelete,<ref>{{cite web|access-date=2020-07-02|title=extundelete: An ext3 and ext4 file undeletion utility|url=http://extundelete.sourceforge.net/|website=extundelete.sourceforge.net}}</ref> [[PhotoRec]] and ext3grep<ref>{{cite web|access-date=2020-07-02|title=Google Code Archive - Long-term storage for Google Code Project Hosting.|url=https://code.google.com/archive/p/ext3grep|website=code.google.com}}</ref> was written to automate the undeletion on [[ext3]] volumes.<ref>{{cite web |author=Carlo Wood |url=http://www.xs4all.nl/~carlo17/howto/undelete_ext3.html |title=HOWTO recover deleted files on an ext3 file system |publisher=Xs4all.nl |date=2008-02-07 |access-date=2012-01-09 |url-status=dead |archive-url=https://web.archive.org/web/20100919000253/http://www.xs4all.nl/~carlo17/howto/undelete_ext3.html |archive-date=2010-09-19 }}</ref> Undelete was proposed in [[ext4]], but is yet to be implemented.<ref>[http://ext4.wiki.kernel.org/index.php/New_ext4_features New ext4 features] {{webarchive |url=https://web.archive.org/web/20081218220019/http://ext4.wiki.kernel.org/index.php/New_ext4_features |date=December 18, 2008 }}</ref> However, a trash bin feature was posted as a patch on December 4, 2006.<ref>{{cite web |url=http://article.gmane.org/gmane.linux.file-systems/11944 |title=Secure Deletion and Trash-Bin Support for Ext4 |publisher=Article.gmane.org |access-date=2012-01-09 |url-status=live |archive-url=https://web.archive.org/web/20080709050655/http://article.gmane.org/gmane.linux.file-systems/11944 |archive-date=2008-07-09 }}</ref> The Trash bin feature uses undelete
Not all file systems or operating systems support undeletion. Undeletion is possible on all [[File Allocation Table|FAT]] file systems, with undeletion utilities provided since [[MS-DOS 5.0]]<ref>{{cite web |url=http://support.microsoft.com/kb/80496 |title=When Not to Use MS-DOS 5.0 CHKDSK and UNDELETE Commands |publisher=Support.microsoft.com |date=2006-11-16 |access-date=2012-01-09 |url-status=live |archive-url=https://web.archive.org/web/20120202192509/http://support.microsoft.com/kb/80496 |archive-date=2012-02-02 }}</ref><ref>{{cite web |url=http://support.microsoft.com/kb/96824 |title=Using a Common UNDELETE.INI File with Undelete |publisher=Support.microsoft.com |date=1999-11-16 |access-date=2012-01-09 |url-status=live |archive-url=https://web.archive.org/web/20090826172844/http://support.microsoft.com/kb/96824 |archive-date=2009-08-26 }}</ref> and [[DR DOS 6.0]] in 1991. It is not supported by most modern [[UNIX]] file systems, though [[AdvFS]] is a notable exception. The [[ext2]] file system has an add-on program called e2undel<ref>{{cite web|access-date=2020-07-02|title=the e2undel home page|url=http://e2undel.sourceforge.net/|website=e2undel.sourceforge.net}}</ref> which allows file undeletion. The similar [[ext3]] file system does not officially support undeletion, but utilities like ext4magic,<ref>{{cite web|access-date=2020-07-02|url=http://ext4magic.sourceforge.net/ext4magic_en.html|title=Ext4magic|website=ext4magic.sourceforge.net}}</ref> extundelete,<ref>{{cite web|access-date=2020-07-02|title=extundelete: An ext3 and ext4 file undeletion utility|url=http://extundelete.sourceforge.net/|website=extundelete.sourceforge.net}}</ref> [[PhotoRec]] and ext3grep<ref>{{cite web|access-date=2020-07-02|title=Google Code Archive - Long-term storage for Google Code Project Hosting.|url=https://code.google.com/archive/p/ext3grep|website=code.google.com}}</ref> were written to automate the undeletion on [[ext3]] volumes.<ref>{{cite web |author=Carlo Wood |url=http://www.xs4all.nl/~carlo17/howto/undelete_ext3.html |title=HOWTO recover deleted files on an ext3 file system |publisher=Xs4all.nl |date=2008-02-07 |access-date=2012-01-09 |url-status=dead |archive-url=https://web.archive.org/web/20100919000253/http://www.xs4all.nl/~carlo17/howto/undelete_ext3.html |archive-date=2010-09-19 }}</ref> Undelete was proposed in [[ext4]], but is yet to be implemented.<ref>[http://ext4.wiki.kernel.org/index.php/New_ext4_features New ext4 features] {{webarchive |url=https://web.archive.org/web/20081218220019/http://ext4.wiki.kernel.org/index.php/New_ext4_features |date=December 18, 2008 }}</ref> However, a trash bin feature was posted as a patch on December 4, 2006.<ref>{{cite web |url=http://article.gmane.org/gmane.linux.file-systems/11944 |title=Secure Deletion and Trash-Bin Support for Ext4 |publisher=Article.gmane.org |access-date=2012-01-09 |url-status=live |archive-url=https://web.archive.org/web/20080709050655/http://article.gmane.org/gmane.linux.file-systems/11944 |archive-date=2008-07-09 }}</ref> The Trash bin feature uses undelete
attributes in ext2/3/4 and Reiser file systems.<ref>{{cite web |url=http://thread.gmane.org/gmane.linux.file-systems/11966 |title=Gmane Loom |publisher=Thread.gmane.org |access-date=2012-01-09 |url-status=live |archive-url=https://web.archive.org/web/20160111185612/http://thread.gmane.org/gmane.linux.file-systems/11966 |archive-date=2016-01-11 }}</ref>
attributes in ext2/3/4 and Reiser file systems.<ref>{{cite web |url=http://thread.gmane.org/gmane.linux.file-systems/11966 |title=Gmane Loom |publisher=Thread.gmane.org |access-date=2012-01-09 |url-status=live |archive-url=https://web.archive.org/web/20160111185612/http://thread.gmane.org/gmane.linux.file-systems/11966 |archive-date=2016-01-11 }}</ref>


Line 24: Line 24:


====FreeDOS====
====FreeDOS====
The [[FreeDOS]] version of UNDELETE was developed by Eric Auer and is licensed under the [[GNU General Public License|GPL]].<ref>http://www.ibiblio.org/pub/micro/pc-stuff/freedos/files/distributions/1.2/repos/pkg-html/undelete.html</ref>
The [[FreeDOS]] version of UNDELETE was developed by Eric Auer and is licensed under the [[GNU General Public License|GPL]].<ref>{{cite web|url=http://www.ibiblio.org/pub/micro/pc-stuff/freedos/files/distributions/1.2/repos/pkg-html/undelete.html |title=FreeDOS 1.2 Updates Package - Undelete (FreeDOS Base) |publisher=Ibiblio.org |date=2009-04-05 |accessdate=2022-09-04}}</ref>


===Graphical programs===
===Graphical programs===
Line 38: Line 38:


== Mechanics ==
== Mechanics ==
The workings of undeletion depend on the file system on which the deleted file was stored. Some file systems, such as [[Hierarchical File System|HFS]], cannot provide an undeletion feature because no information about the deleted file is retained (except by additional software, which is not usually present). Some file systems, however, do not erase all traces of a deleted file, including FAT file systems:
The workings of undeletion depend on the file system on which the deleted file was stored. Some file systems, such as [[Hierarchical File System (Apple)|HFS]], cannot provide an undeletion feature because no information about the deleted file is retained (except by additional software, which is not usually present). Some file systems, however, do not erase all traces of a deleted file, including FAT file systems:


=== FAT file systems ===
=== FAT file systems ===
Line 58: Line 58:
Until the MFT entry is reused or overwritten, the file can be easily recovered: data recovery software can find the "lost" MFT entry and derive full information about the lost file from it.
Until the MFT entry is reused or overwritten, the file can be easily recovered: data recovery software can find the "lost" MFT entry and derive full information about the lost file from it.


Note however, when the SSD [[TRIM]] function is enabled, file content may be destroyed shortly after deletion to reuse SSD memory cells. This makes file content recovery impossible (only name, date and file size information will remain on the disk).
Note however, when the SSD [[Trim (computing)|TRIM]] function is enabled, file content may be destroyed shortly after deletion to reuse SSD memory cells. This makes file content recovery impossible (only name, date and file size information will remain on the disk).


==Prevention==
==Prevention==
Line 66: Line 66:
== See also ==
== See also ==
* [[Backup]]
* [[Backup]]
* [[Deletion review|Deletion of articles on Wikipedia § Deletion review and undeletion]]
* [[List of data recovery software]]
* [[List of data recovery software]]
* [[Paper shredder#Unshredding|Paper shredder]]
* [[Paper shredder#Unshredding and forensics|Paper shredder]]
* [[Rollback (data management)]]
* [[Rollback (data management)]]
* [[Undo]]
* [[Undo]]
Line 75: Line 76:


==External links==
==External links==
* [https://www.recoverytoolbox.com/undelete.html Undelete Free]
* [http://www.officerecovery.com/freeundelete/ FreeUndelete]
* [http://www.officerecovery.com/freeundelete/ FreeUndelete]
* [http://www.digitalfilerecovery.com Media Investigator]
* [http://www.digitalfilerecovery.com Media Investigator]

Latest revision as of 04:19, 12 August 2024

Undeletion is a feature for restoring computer files which have been removed from a file system by file deletion. Deleted data can be recovered on many file systems, but not all file systems provide an undeletion feature. Recovering data without an undeletion facility is usually called data recovery, rather than undeletion. Undeletion can both help prevent users from accidentally losing data, or can pose a computer security risk, since users may not be aware that deleted files remain accessible.

Support

[edit]

Not all file systems or operating systems support undeletion. Undeletion is possible on all FAT file systems, with undeletion utilities provided since MS-DOS 5.0[1][2] and DR DOS 6.0 in 1991. It is not supported by most modern UNIX file systems, though AdvFS is a notable exception. The ext2 file system has an add-on program called e2undel[3] which allows file undeletion. The similar ext3 file system does not officially support undeletion, but utilities like ext4magic,[4] extundelete,[5] PhotoRec and ext3grep[6] were written to automate the undeletion on ext3 volumes.[7] Undelete was proposed in ext4, but is yet to be implemented.[8] However, a trash bin feature was posted as a patch on December 4, 2006.[9] The Trash bin feature uses undelete attributes in ext2/3/4 and Reiser file systems.[10]

Command-line tools

[edit]

Norton Utilities

[edit]

Norton UNERASE was an important component in Norton Utilities version 1.0 in 1982.

MS-DOS

[edit]

Microsoft included a similar UNDELETE program in versions 5.0 to 6.22 of MS-DOS, but applied the Recycle Bin approach instead in later operating systems using FAT.

DR DOS

[edit]

DR DOS 6.0 and higher support UNDELETE as well, but optionally offer additional protection utilizing the FAT snapshot utility DISKMAP and the resident DELWATCH deletion tracking component, which actively maintains deleted files' date and time stamps and keeps the contents of deleted files from being overwritten unless running out of disk space. DELWATCH also supports undeletion of remote files on file servers. Since Novell DOS 7 the kernel will store the first letter of deleted files in the directory entries in order to further assist undeletion tools in recovering the original name.

PTS-DOS

[edit]

PTS-DOS offers the same feature, configurable by a SAVENAME CONFIG.SYS directive.

FreeDOS

[edit]

The FreeDOS version of UNDELETE was developed by Eric Auer and is licensed under the GPL.[11]

Graphical programs

[edit]

Graphical user environments often take a different approach to undeletion, instead using a "holding area" for files to be deleted. Undesired files are moved to this holding area, and all of the files in the holding area are deleted periodically or when a user requests it. This approach is used by the Trash can in Macintosh operating systems and by the recycle bin in Microsoft Windows. This is a natural continuation of the approach taken by earlier systems, such as the limbo group used by LocoScript.[12] This approach is not subject to the risk that other files being written to the filesystem will disrupt a deleted file very quickly; permanent deletion will happen on a predictable schedule or with manual intervention only.

Another approach is offered by programs such as Norton GoBack (formerly Roxio GoBack): a portion of the hard disk space is set aside for file modification operations to be recorded in such a way that they may later be undone. This process is usually much safer in aiding recovery of deleted files than the undeletion operation as described below.

Similarly, file systems that support "snapshots" (like ZFS or btrfs), can be used to make snapshots of the whole file system at regular intervals (e.g. every hour), thus allowing recovery of files from an earlier snapshot.

Limitations

[edit]

Undeletion is not fail-safe. In general, the sooner undeletion is attempted, the more likely it will be successful. This is because the more a system is used, the more data is written to the drive and potentially allocated to that deleted space. Fragmentation of the deleted file may also reduce the probability of recovery, depending on the type of file system (see below). A fragmented file is scattered across different parts of the disk, instead of being in a contiguous area.

Mechanics

[edit]

The workings of undeletion depend on the file system on which the deleted file was stored. Some file systems, such as HFS, cannot provide an undeletion feature because no information about the deleted file is retained (except by additional software, which is not usually present). Some file systems, however, do not erase all traces of a deleted file, including FAT file systems:

FAT file systems

[edit]

When a file is "deleted" using a FAT file system, the directory entry remains almost unchanged except for the first character of the file name, preserving most of the "deleted" file's name, along with its time stamp, file length and — most importantly — its physical location on the disk. The list of disk clusters occupied by the file will, however, be erased from the File Allocation Table, marking those sectors available for use by other files created or modified thereafter. In case of FAT32, it is additionally erased field responsible for upper 16 bits of file start cluster value.

When undeletion operation is attempted, the following conditions must be met for a successful recovery of the file:

  • The entry of the deleted file must still exist in the directory, meaning that it must not yet be overwritten by a new file (or folder) that has been created in the same directory. Whether this is the case can fairly easily be detected by checking whether the remaining name of the file to be undeleted is still present in the directory.
  • The clusters formerly used by the deleted file must not be overwritten yet by other files. This can fairly well be verified by checking that the clusters are not marked as used in the File Allocation Table. However, if, in the meantime, a new file had been written to the disk, using those sectors, and then deleted again, freeing those sectors again, this cannot be detected automatically by the undeletion program. In this case an undeletion operation, even if appearing successful, might fail because the recovered file contains different data.
  • For FAT32 devices, the lower 16 bits of the physical address is normally retained in the directory entry, but the high bits of the address are zeroed down. Many recovery programs ignore this fact and fail to recover data correctly.

Chances of recovering deleted files is often higher on FAT12 and FAT16 as compared to FAT32 volumes due to the typically larger cluster sizes used by the former systems and due to loss of upper 16 bits of logical cluster address for FAT32.

If the undeletion program cannot detect clear signs of the above requirements not being met, it will restore the directory entry as being in use and mark all consecutive clusters, beginning with the one as recorded in the old directory entry, as used in the File Allocation Table. It is then up to the user to open the recovered file and to verify that it contains the complete data of the formerly deleted file.

Recovery of fragmented files (after the first fragment) is therefore not normally possible by automatic processes, only by manual examination of each (unused) block of the disk. This requires detailed knowledge of the file system, as well as the binary format of the file type being recovered, and is therefore only done by recovery specialists or forensics professionals.

NTFS file systems

[edit]

NTFS stores file information as a set of fixed-size records (typically, 1KB) within the so-called Master File Table (MFT). File name and file allocation information are encapsulated into these records, providing complete information about each specific file. When the system deletes a file, the entry in the Master File Table is released to be either unlinked or reused, but it still remains on disk. Until the MFT entry is reused or overwritten, the file can be easily recovered: data recovery software can find the "lost" MFT entry and derive full information about the lost file from it.

Note however, when the SSD TRIM function is enabled, file content may be destroyed shortly after deletion to reuse SSD memory cells. This makes file content recovery impossible (only name, date and file size information will remain on the disk).

Prevention

[edit]

Data erasure is a term that refers to software-based methods of preventing file undeletion.

See also

[edit]

References

[edit]
  1. ^ "When Not to Use MS-DOS 5.0 CHKDSK and UNDELETE Commands". Support.microsoft.com. 2006-11-16. Archived from the original on 2012-02-02. Retrieved 2012-01-09.
  2. ^ "Using a Common UNDELETE.INI File with Undelete". Support.microsoft.com. 1999-11-16. Archived from the original on 2009-08-26. Retrieved 2012-01-09.
  3. ^ "the e2undel home page". e2undel.sourceforge.net. Retrieved 2020-07-02.
  4. ^ "Ext4magic". ext4magic.sourceforge.net. Retrieved 2020-07-02.
  5. ^ "extundelete: An ext3 and ext4 file undeletion utility". extundelete.sourceforge.net. Retrieved 2020-07-02.
  6. ^ "Google Code Archive - Long-term storage for Google Code Project Hosting". code.google.com. Retrieved 2020-07-02.
  7. ^ Carlo Wood (2008-02-07). "HOWTO recover deleted files on an ext3 file system". Xs4all.nl. Archived from the original on 2010-09-19. Retrieved 2012-01-09.
  8. ^ New ext4 features Archived December 18, 2008, at the Wayback Machine
  9. ^ "Secure Deletion and Trash-Bin Support for Ext4". Article.gmane.org. Archived from the original on 2008-07-09. Retrieved 2012-01-09.
  10. ^ "Gmane Loom". Thread.gmane.org. Archived from the original on 2016-01-11. Retrieved 2012-01-09.
  11. ^ "FreeDOS 1.2 Updates Package - Undelete (FreeDOS Base)". Ibiblio.org. 2009-04-05. Retrieved 2022-09-04.
  12. ^ "Langford in PCW TODAY column #6". Ansible.co.uk. Archived from the original on 2012-02-14. Retrieved 2012-01-09.
[edit]