Misplaced Pages

LAN Manager: Difference between revisions

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 19:29, 2 December 2020 edit2a01:170:1154:fc:ed97:687c:3124:56fc (talk) Algorithm← Previous edit Latest revision as of 22:18, 15 September 2024 edit undoGuy Harris (talk | contribs)Extended confirmed users76,841 edits Undid revision 1241895353 by 84.232.151.154 (talk) - MOS:TENSE.Tag: Undo 
(46 intermediate revisions by 28 users not shown)
Line 1: Line 1:
{{short description|Depreciated Microsoft networking system with broken security}} {{Short description|Microsoft network operating system}}
{{Refimprove|date=December 2009}}
{{Infobox OS {{Infobox OS
| name = LAN Manager<!-- Name of program or distribution --> | name = LAN Manager<!-- Name of program or distribution -->
| logo = <!-- filename only (no wikilink, no Image:/File:) --> | logo = <!-- filename only (no wikilink, no Image:/File:) -->
| logo caption = | logo caption =
| logo size = | logo size =
| logo alt = | logo alt =
| screenshot = <!-- filename only (no wikilink, no Image:/File:) --> | screenshot = <!-- filename only (no wikilink, no Image:/File:) -->
| caption = | caption =
| screenshot_size = | screenshot_size =
| screenshot_alt = | screenshot_alt =
| collapsible = | collapsible =
| version of = <!-- For articles about releases of operating systems ONLY --> | version of = <!-- For articles about releases of operating systems ONLY -->
| developer = ], ]<!-- Name of main developer or sponsor--> | developer = ], ]<!-- Name of main developer or sponsor-->
| family = ]<!-- "Unix-like" or "Microsoft Windows" --> | family = ]<!-- "Unix-like" or "Microsoft Windows" -->
| working state = Discontinued<!-- "Current", "Discontinued" (operating systems), or "No longer supported" (releases) --> | working state = Discontinued<!-- "Current", "Discontinued" (operating systems), or "No longer supported" (releases) -->
| source model = ]<!-- "Open source", "Closed source", or "Shared source" --> | source model = ]<!-- "Open source", "Closed source", or "Shared source" -->
| released = {{Start date and age|1987}} | released = {{Start date and age|1987}}
| discontinued = Yes<!-- DON'T use this for articles about releases of operating systems --> | discontinued = Yes<!-- DON'T use this for articles about releases of operating systems -->
| RTM date = <!-- {{Start date and age|YYYY|MM|DD|df=yes/no}} ONLY for articles about OS releases --> | RTM date = <!-- {{Start date and age|YYYY|MM|DD|df=yes/no}} ONLY for articles about OS releases -->
| GA date = <!-- {{Start date and age|YYYY|MM|DD|df=yes/no}} ONLY for articles about OS releases --> | GA date = <!-- {{Start date and age|YYYY|MM|DD|df=yes/no}} ONLY for articles about OS releases -->
| latest release version = 2.2a | latest release version = 2.2a
| latest release date = {{Start date and age|1994}} | latest release date = {{Start date and age|1994}}
| latest preview version = | latest preview version =
| latest preview date = <!-- {{Start date and age|YYYY|MM|DD|df=yes/no}} --> | latest preview date = <!-- {{Start date and age|YYYY|MM|DD|df=yes/no}} -->
| marketing target = ] | marketing target = ]ing
| programmed in = | programmed in =
| language = <!-- Supported human languages (English, French, Italian, Arabic, ...) --> | language = <!-- Supported human languages (English, French, Italian, Arabic, ...) -->
| update model = Re-installation<!-- APT, Windows Update, etc. --> | update model = Re-installation<!-- APT, Windows Update, etc. -->
| package manager = None<!-- dpkg, rpm, Windows installer, etc. --> | package manager = None<!-- dpkg, rpm, Windows installer, etc. -->
| supported platforms = ]<!-- IA-32, x64, Itanium, ARM, etc. --> | supported platforms = ]<!-- IA-32, x64, Itanium, ARM, etc. -->
| kernel type = <!-- Hybrid, Monolithic, Microkernel, Exokernel, Nanokernel, etc. --> | kernel type = <!-- Hybrid, Monolithic, Microkernel, Exokernel, Nanokernel, etc. -->
| userland = | userland =
| ui = | ui =
| license = ] | license = ]
| preceded by = ], Xenix-NET, ] | preceded by = ], Xenix-NET, ]
| succeeded by = | succeeded by = ]
| website = <!-- {{URL|www.example.org}} --> | website = <!-- {{URL|www.example.org}} -->
| support status = <!-- For articles about releases of operating systems ONLY --> | support status = <!-- For articles about releases of operating systems ONLY -->
| other articles = | other articles =
| prog_language = | prog_language =
}} }}
'''LAN Manager''' was a ] (NOS) available from multiple vendors and developed by ] in cooperation with ]. It was designed to succeed 3Com's ] ] software which ran atop a heavily modified version of ]. '''LAN Manager''' is a discontinued ] (NOS) available from multiple vendors and developed by ] in cooperation with ]. It was designed to succeed 3Com's ] ] software which ran atop a heavily modified version of ].


==History== ==History==
LAN Manager was based on the ] operating system co-developed by ] and ]. It originally used the ] (SMB) protocol atop either the ] (NBF) protocol or a specialized version of the ] (XNS) protocol. These legacy protocols had been inherited from previous products such as ] for ], ] for ], and the afore-mentioned 3+Share. A version of LAN Manager for Unix-based systems called '''LAN Manager/X''' was also available. The LAN Manager ] operating system was co-developed by ] and ], using the ] (SMB) protocol. It originally used SMB atop either the ] (NBF) protocol or a specialized version of the ] (XNS) protocol. These legacy protocols had been inherited from previous products such as ] for ], ] for ], and the afore-mentioned 3+Share. A version of LAN Manager for Unix-based systems called '''LAN Manager/X''' was also available. LAN Manager/X was the basis for ]'s ] product for ], ] and ].<ref name="samba">{{cite web|url=http://de.openvms.org/TUD2005/02_Advanced_Server_and_Samba_Andy_Goldstein.pdf|title=Samba and OpenVMS|author=Andy Goldstein|date=2005|access-date=2021-01-01|website=de.openvms.org|archive-url=https://web.archive.org/web/20210207063545/http://de.openvms.org/TUD2005/02_Advanced_Server_and_Samba_Andy_Goldstein.pdf|archive-date=2021-02-07|url-status=dead}}</ref>


In 1990, Microsoft announced LAN Manager 2.0 with a host of improvements, including support for ] as a transport protocol. The last version of LAN Manager, 2.2, which included an MS-OS/2 1.31 base operating system, remained Microsoft's strategic server system until the release of ] in 1993. In 1990, Microsoft announced LAN Manager 2.0 with a host of improvements, including support for ] as a transport protocol for SMB, using ] (NBT). The last version of LAN Manager, 2.2, which included an MS-OS/2 1.31 base operating system, remained Microsoft's strategic server system until the release of ] in 1993.<ref>{{Cite web |title=DOS SMB Client Performance {{!}} OS/2 Museum |url=https://www.os2museum.com/wp/dos-smb-client-performance/ |access-date=2023-08-28 |language=en-US}}</ref>


===Versions=== ===Versions===
Line 65: Line 64:
* ] * ]


==Password hashing algorithm== <!-- If you change the name of this section, please make sure you update links on all pages, redirects, etc. that point to it. Thank you. -->
==LM hash details==
<!--copied from ] to achieve merge-->
LM hash (also known as LanMan hash or LAN Manager hash) is a compromised password ] that was the primary hash that Microsoft LAN Manager and ] versions prior to ] used to store user ]s. Support for the legacy LAN Manager protocol continued in later versions of Windows for ], but was recommended by Microsoft to be turned off by administrators; as of Windows Vista, the protocol is disabled by default, but continues to be used by some non-Microsoft ] implementations.

==Algorithm==
The LM hash is computed as follows:<ref>{{cite web The LM hash is computed as follows:<ref>{{cite web
| url=https://technet.microsoft.com/en-us/library/dd277300.aspx#ECAA | url=https://learn.microsoft.com/previous-versions/tn-archive/dd277300(v=technet.10)#the-lmhash
| title=Chapter 3 - Operating System Installation: The LMHash | title=Chapter 3 - Operating System Installation
| at=The LMHash
| work=] | work=]
| date=24 March 2009
| accessdate=2015-05-12}}</ref><ref name="davenport">{{cite web | access-date=2023-10-16}}</ref><ref name="davenport">{{cite web
| url=http://davenport.sourceforge.net/ntlm.html#theLmResponse | url=http://davenport.sourceforge.net/ntlm.html#theLmResponse
| title=The NTLM Authentication Protocol and Security Support Provider: The LM Response | title=The NTLM Authentication Protocol and Security Support Provider: The LM Response
Line 80: Line 77:
| first=Eric | first=Eric
| year=2006 | year=2006
| accessdate=2015-05-12}}</ref> | access-date=2015-05-12}}</ref>
# The user's password is restricted to a maximum of fourteen characters.<ref group="Notes">If the password is more than fourteen characters long, the LM hash cannot be computed.</ref> # The user's password is restricted to a maximum of fourteen characters.<ref group="Notes">If the password is more than fourteen characters long, the LM hash cannot be computed.</ref>
# The user’s password is converted to ]. # The user's password is converted to ].
# The user's password is encoded in the System OEM ].<ref>{{cite web # The user's password is encoded in the System OEM ].<ref>{{cite web
| url=https://msdn.microsoft.com/nl-nl/goglobal/cc563921%28en-us%29.aspx | url=https://msdn.microsoft.com/nl-nl/goglobal/cc563921%28en-us%29.aspx
| title=List of Localized MS Operating Systems | title=List of Localized MS Operating Systems
| work=] | work=]
| accessdate=2015-05-12}}</ref> | access-date=2015-05-12
| archive-url=https://web.archive.org/web/20150518092309/https://msdn.microsoft.com/nl-nl/goglobal/cc563921(en-us).aspx
| archive-date=2015-05-18
| url-status=dead}}</ref>
# This password is NULL-padded to 14 bytes.<ref name="KB828861">{{cite web # This password is NULL-padded to 14 bytes.<ref name="KB828861">{{cite web
| url=https://support.microsoft.com/kb/828861 | url=https://support.microsoft.com/kb/828861
Line 93: Line 93:
| publisher=] | publisher=]
| date=2006-10-30 | date=2006-10-30
| accessdate=2015-05-12}}</ref> | access-date=2015-05-12
| archive-url=https://web.archive.org/web/20140910100521/https://support.microsoft.com/kb/828861
| archive-date=2014-09-10
| url-status=dead}}</ref>
# The “fixed-length” password is split into two 7-byte halves. # The “fixed-length” password is split into two 7-byte halves.
# These values are used to create two ] keys, one from each 7-byte half, by converting the seven bytes into a bit stream with the most significant bit first, and inserting a null bit after every seven bits (so <code>1010100</code> becomes <code>10101000</code>). This generates the 64 bits needed for a DES key. (A DES key ostensibly consists of 64 bits; however, only 56 of these are actually used by the algorithm. The null bits added in this step are later discarded.) # These values are used to create two ] keys, one from each 7-byte half, by converting the seven bytes into a bit stream with the most significant bit first, and inserting a ] after every seven bits (so <code>1010100</code> becomes <code>10101000</code>). This generates the 64 bits needed for a DES key. (A DES key ostensibly consists of 64 bits; however, only 56 of these are actually used by the algorithm. The parity bits added in this step are later discarded.)
# Each of the two keys is used to DES-encrypt the constant ] string “<code>KGS!@#$%</code>”,<ref group="Notes">The string “KGS!@#$%” could possibly mean '''K'''ey of '''G'''len and '''S'''teve and then the combination of '''Shift + 12345'''. Glen Zorn and Steve Cobb are the authors of RFC 2433 (]).</ref> resulting in two 8-byte ciphertext values. The DES CipherMode should be set to ECB, and PaddingMode should be set to <code>NONE</code>. # Each of the two keys is used to DES-encrypt the constant ] string “<code>KGS!@#$%</code>”,<ref group="Notes">The string “KGS!@#$%” could possibly mean '''K'''ey of '''G'''len and '''S'''teve and then the combination of '''Shift + 12345'''. Glen Zorn and Steve Cobb are the authors of RFC 2433 (]).</ref> resulting in two 8-byte ciphertext values. The DES CipherMode should be set to ECB, and PaddingMode should be set to <code>NONE</code>.
# These two ciphertext values are concatenated to form a 16-byte value, which is the LM hash. # These two ciphertext values are concatenated to form a 16-byte value, which is the LM hash.


==Security weaknesses== ==Security weaknesses==
LAN Manager authentication uses a particularly weak method of ] a user's ] known as the LM hash algorithm, stemming from the mid 1980s when viruses transmitted by floppy disks were the major concern.<ref name=SecurityWatch /> Although it is based on ], a well-studied ], the LM hash has several weaknesses in its design.<ref>{{cite web LAN Manager authentication uses a particularly weak method of ] a user's ] known as the LM hash algorithm, stemming from the mid-1980s when viruses transmitted by floppy disks were the major concern.<ref name=SecurityWatch /> Although it is based on ], a well-studied ], the LM hash has several weaknesses in its design.<ref>{{cite web
| url=http://download.microsoft.com/download/f/4/a/f4a67fc8-c499-461d-a025-8155fb4f7a0f/Windows%20Passwords%20Master%201.5%20Handout%20-%20Jesper%20Johansson.ppt | url=http://download.microsoft.com/download/f/4/a/f4a67fc8-c499-461d-a025-8155fb4f7a0f/Windows%20Passwords%20Master%201.5%20Handout%20-%20Jesper%20Johansson.ppt
| title=Windows Passwords: Everything You Need To Know | title=Windows Passwords: Everything You Need To Know
Line 107: Line 110:
| last=Johansson | last=Johansson
| date=2004-06-29 | date=2004-06-29
| accessdate=2015-05-12}}</ref> | access-date=2015-05-12}}</ref>
This makes such hashes crackable in a matter of seconds using ]s, or in a few minutes using ]. Starting with ], it was replaced by ], which is still vulnerable to rainbow tables, and brute force attacks unless long, unpredictable passwords are used, see ]. NTLM is used for logon with local accounts except on domain controllers since Windows Vista and later versions no longer maintain the LM hash by default.<ref name=SecurityWatch>{{cite web|author1=Jesper Johansson|title=The Most Misunderstood Windows Security Setting of All Time|url=https://technet.microsoft.com/en-us/magazine/2006.08.securitywatch.aspx|website=TechNet Magazine|publisher=Microsoft|accessdate=2 November 2015|quote=Although Windows Vista has not been released yet, it is worthwhile to point out some changes in this operating system related to these protocols. The most important change is that the LM protocol can no longer be used for inbound authentication—where Windows Vista is acting as the authentication server.}}</ref> ] is used in Active Directory Environments. This makes such hashes crackable in a matter of seconds using ]s, or in a few minutes using ]. Starting with ], it was replaced by ], which is still vulnerable to rainbow tables, and brute force attacks unless long, unpredictable passwords are used, see ]. NTLM is used for logon with local accounts except on domain controllers since Windows Vista and later versions no longer maintain the LM hash by default.<ref name=SecurityWatch>{{cite web|author1=Jesper Johansson|title=The Most Misunderstood Windows Security Setting of All Time|url=https://learn.microsoft.com/en-us/previous-versions/technet-magazine/cc160954(v=msdn.10)|website=]|date=31 August 2016 |publisher=Microsoft|access-date=16 October 2023|quote=Although Windows Vista has not been released yet, it is worthwhile to point out some changes in this operating system related to these protocols. The most important change is that the LM protocol can no longer be used for inbound authentication—where Windows Vista is acting as the authentication server.}}</ref> ] is used in Active Directory Environments.


The major weaknesses of LAN Manager authentication protocol are:<ref>Rahul Kokcha</ref> The major weaknesses of LAN Manager authentication protocol are:<ref>Rahul Kokcha</ref>
# Password length is limited to a maximum of 14 characters chosen from the ]. # Password length is limited to a maximum of 14 characters chosen from the ].
# Passwords are not case sensitive. All passwords are converted into uppercase before generating the hash value. Hence LM hash treats PassWord, password, PaSsWoRd, PASSword and other similar combinations same as PASSWORD. This practice effectively reduces the LM hash ] to 69 characters. # Passwords are not case sensitive. All passwords are converted into uppercase before generating the hash value. Hence LM hash treats PassWord, password, PaSsWoRd, PASSword and other similar combinations same as PASSWORD. This practice effectively reduces the LM hash ] to 69 characters.
# A 14-character password is broken into 7+7 characters and the hash is calculated for each half separately. This way of calculating the hash makes it dramatically easier to crack, as the attacker only needs to ] 7 characters twice instead of the full 14 characters. This makes the effective strength of a 14-character password equal to only <math>69^{7} \approx 2^{43}</math>, or twice that of a 7-character password, which is 3.7 trillion times less complex than the <math>69^{14} \approx 2^{86}</math> theoretical strength of a 14-character single-case password. As of 2020, a computer equipped with a high-end ] (GPUs) can compute 40 billion LM-hashes per second.<ref>, Mode 3000 LM, accessed November 29, 2020</ref> At that rate, all 7-character passwords from the 95-character set can be tested and broken in half an hour; all 7-character ] passwords can be tested and broken in 2 seconds. # A 14-character password is broken into 7+7 characters and the hash is calculated for each half separately. This way of calculating the hash makes it dramatically easier to crack, as the attacker only needs to ] 7 characters twice instead of the full 14 characters. This makes the effective strength of a 14-character password equal to only <math>2\times69^{7} \approx 2^{44}</math>, or twice that of a 7-character password, which is 3.7 trillion times less complex than the <math>69^{14} \approx 2^{86}</math> theoretical strength of a 14-character single-case password. As of 2020, a computer equipped with a high-end ] (GPUs) can compute 40 billion LM-hashes per second.<ref>, Mode 3000 LM, accessed November 29, 2020</ref> At that rate, all 7-character passwords from the 95-character set can be tested and broken in half an hour; all 7-character ] passwords can be tested and broken in 2 seconds.
#If the password is 7 characters or less, then the second half of hash will always produce same constant value (0xAAD3B435B51404EE). Therefore, a password is less than or equal to 7 characters long can be identified visibly without using tools (though with high speed GPU attacks, this matters less). #If the password is 7 characters or less, then the second half of hash will always produce same constant value (0xAAD3B435B51404EE). Therefore, a password is less than or equal to 7 characters long can be identified visibly without using tools (though with high speed GPU attacks, this matters less).
# The hash value is sent to network servers without ], making it susceptible to ]s such as ]. Without salt, ] ]s, such as a ], are feasible. In 2003, ], an implementation of the rainbow table technique, was published. It specifically targets the weaknesses of LM encryption, and includes pre-computed data sufficient to crack virtually all alphanumeric LM hashes in a few seconds. Many cracking tools, such as ], ], ] and ], now incorporate similar attacks and make cracking of LM hashes fast and trivial. # The hash value is sent to network servers without ], making it susceptible to ]s such as ]. Without salt, ] ]s, such as a ], are feasible. In 2003, ], an implementation of the rainbow table technique, was published. It specifically targets the weaknesses of LM encryption, and includes pre-computed data sufficient to crack virtually all alphanumeric LM hashes in a few seconds. Many cracking tools, such as ], ], ] and ], now incorporate similar attacks and make cracking of LM hashes fast and trivial.
Line 121: Line 124:


While LAN Manager is considered obsolete and current Windows operating systems use the stronger NTLMv2 or ] authentication methods, Windows systems before ]/] enabled the LAN Manager hash by default for ] with legacy LAN Manager and ] or earlier clients, or legacy ]-enabled applications. It has for many years been considered good security practice to disable the compromised LM and NTLMv1 authentication protocols where they aren't needed.<ref name="KB299656">{{cite web While LAN Manager is considered obsolete and current Windows operating systems use the stronger NTLMv2 or ] authentication methods, Windows systems before ]/] enabled the LAN Manager hash by default for ] with legacy LAN Manager and ] or earlier clients, or legacy ]-enabled applications. It has for many years been considered good security practice to disable the compromised LM and NTLMv1 authentication protocols where they aren't needed.<ref name="KB299656">{{cite web
| url=https://support.microsoft.com/kb/299656 | url=https://learn.microsoft.com/en-US/troubleshoot/windows-server/windows-security/prevent-windows-store-lm-hash-password
| title=How to prevent Windows from storing a LAN manager hash of your password in Active Directory and local SAM databases | title=How to prevent Windows from storing a LAN manager hash of your password in Active Directory and local SAM databases
| work=] | work=]
| date=2007-12-03 | date=2007-12-03
| accessdate=2015-05-12}}</ref> | access-date=2023-10-16}}</ref>
Starting with Windows Vista and Windows Server 2008, Microsoft disabled the LM hash by default; the feature can be enabled for local accounts via a security policy setting, and for ] accounts by applying the same setting via domain ]. The same method can be used to turn the feature off in Windows 2000, Windows XP and NT.<ref name="KB299656"/> Users can also prevent a LM hash from being generated for their own password by using a password at least fifteen characters in length.<ref name="KB828861"/> Starting with Windows Vista and Windows Server 2008, Microsoft disabled the LM hash by default; the feature can be enabled for local accounts via a security policy setting, and for ] accounts by applying the same setting via domain ]. The same method can be used to turn the feature off in Windows 2000, Windows XP and NT.<ref name="KB299656"/> Users can also prevent a LM hash from being generated for their own password by using a password at least fifteen characters in length.<ref name="KB828861"/>—NTLM hashes have in turn become vulnerable in recent years to various attacks that effectively make them as weak today as LanMan hashes were back in 1998.{{Citation needed|date=August 2016}}
--
NTLM hashes have in turn become vulnerable in recent years to various attacks that effectively make them as weak today as LanMan hashes were back in 1998.{{Citation needed|date=August 2016}}


==Reasons for continued use of LM hash== ==Reasons for continued use of LM hash==
Many legacy third party ] implementations have taken considerable time to add support for the stronger protocols that Microsoft has created to replace LM hashing because the ] communities supporting these libraries first had to ] the newer protocols—] took 5 years to add ] support, while ] took 10 years. Many legacy third party ] implementations have taken considerable time to add support for the stronger protocols that Microsoft has created to replace LM hashing because the ] communities supporting these libraries first had to ] the newer protocols—] took 5 years to add ] support, while JCIFS took 10 years.


{| class="wikitable" {| class="wikitable"
Line 160: Line 161:
| date=1998-10-25 | date=1998-10-25
| publisher=] | publisher=]
| accessdate=2015-05-12}}</ref> (25 October 1998) | access-date=2015-05-12
| archive-url=https://web.archive.org/web/20150519010408/https://support.microsoft.com/en-us/kb/194507
| archive-date=2015-05-19
| url-status=dead}}</ref> (25 October 1998)
|- |-
| ] | ]
Line 174: Line 178:
| RTM (17 February 2000) | RTM (17 February 2000)
|- |-
| ] | ]
| RTM (14 September 2000) | RTM (14 September 2000)
| Directory services client (released with ] Server, 17 February 2000) | Directory services client (released with ] Server, 17 February 2000)
Line 185: Line 189:
| date=2003-09-24 | date=2003-09-24
| publisher=] | publisher=]
| accessdate=2015-05-12}}</ref> (24 September 2003) | access-date=2015-05-12}}</ref> (24 September 2003)
|- |-
| JCIFS | JCIFS
Line 192: Line 196:
| url=https://jcifs.samba.org/ | url=https://jcifs.samba.org/
| title=The Java CIFS Client Library | title=The Java CIFS Client Library
| accessdate=2015-05-12}}</ref> | access-date=2015-05-12}}</ref>
|- |-
| ] (SMBFS) | ] (SMBFS)
Line 200: Line 204:
| publisher=] | publisher=]
| date=2010-03-15 | date=2010-03-15
| accessdate=2015-05-12}}</ref> | access-date=2015-05-12}}</ref>
| Not supported as of v7.1<ref>{{cite web | Not supported as of v7.1<ref>{{cite web
| url=http://www-01.ibm.com/support/knowledgecenter/ssw_aix_71/com.ibm.aix.networkcomm/smbfs_intro.htm | url=http://www-01.ibm.com/support/knowledgecenter/ssw_aix_71/com.ibm.aix.networkcomm/smbfs_intro.htm
Line 206: Line 210:
| publisher=] | publisher=]
| date=2011-12-05 | date=2011-12-05
| accessdate=2015-05-12}}</ref> | access-date=2015-05-12}}</ref>
|} |}


Line 229: Line 233:
==External links== ==External links==
{{Wikibooks|Reverse Engineering/Cracking Windows XP Passwords}} {{Wikibooks|Reverse Engineering/Cracking Windows XP Passwords}}
* {{webarchive|url=https://web.archive.org/web/20170212195243/http://msdn.microsoft.com/en-us/library/cc237025.aspx|date=2017-02-12|title=1.3.8.1.1 Microsoft LAN Manager}}
*{{cite web
| url=http://msdn.microsoft.com/en-us/library/cc237025.aspx
| archive-url=https://web.archive.org/web/20170212195243/http://msdn.microsoft.com/en-us/library/cc237025.aspx
| archivedate=2017-02-12
| title=Microsoft LAN Manager
}}
* {{cite web
| url=http://lasec.epfl.ch/~oechslin/publications/crypto03.pdf
| title=Making a Faster Cryptanalytic Time-Memory Trade-Off
| first=Philippe
| last=Oechslin
| work=Advances in Cryptology, CRYPTO 2003
| year=2003}}
* {{cite web
| url=http://ophcrack.sourceforge.net/
| title=Ophcrack, a well known password cracker}}
* {{cite web
| url=http://www.oxid.it/cain.html
| title=Cain and Abel, password recovery tool for Microsoft Operating Systems}}
* {{cite web
| url=http://seclists.org/bugtraq/1997/Jul/135
| title=A L0phtCrack Technical Rant
| author=mudge
| date=1997-07-24
| archiveurl=https://web.archive.org/web/20111211173908/http://seclists.org/bugtraq/1997/Jul/135
| archivedate=2011-12-11}}


{{Authentication APIs}} {{Authentication APIs}}
Line 262: Line 241:
{{DEFAULTSORT:Lan Manager}} {{DEFAULTSORT:Lan Manager}}
] ]
] ]
] ]
] ]

Latest revision as of 22:18, 15 September 2024

Microsoft network operating system Operating system
LAN Manager
DeveloperMicrosoft, 3Com
OS familyOS/2
Working stateDiscontinued
Source modelClosed source
Initial release1987; 38 years ago (1987)
Final release2.2a / 1994; 31 years ago (1994)
Marketing targetLocal area networking
Update methodRe-installation
Package managerNone
Platformsx86
LicenseProprietary
Preceded byMS-Net, Xenix-NET, 3+Share
Succeeded byMicrosoft Windows NT 3.1

LAN Manager is a discontinued network operating system (NOS) available from multiple vendors and developed by Microsoft in cooperation with 3Com Corporation. It was designed to succeed 3Com's 3+Share network server software which ran atop a heavily modified version of MS-DOS.

History

The LAN Manager OS/2 operating system was co-developed by IBM and Microsoft, using the Server Message Block (SMB) protocol. It originally used SMB atop either the NetBIOS Frames (NBF) protocol or a specialized version of the Xerox Network Systems (XNS) protocol. These legacy protocols had been inherited from previous products such as MS-Net for MS-DOS, Xenix-NET for MS-Xenix, and the afore-mentioned 3+Share. A version of LAN Manager for Unix-based systems called LAN Manager/X was also available. LAN Manager/X was the basis for Digital Equipment Corporation's Pathworks product for OpenVMS, Ultrix and Tru64.

In 1990, Microsoft announced LAN Manager 2.0 with a host of improvements, including support for TCP/IP as a transport protocol for SMB, using NetBIOS over TCP/IP (NBT). The last version of LAN Manager, 2.2, which included an MS-OS/2 1.31 base operating system, remained Microsoft's strategic server system until the release of Windows NT Advanced Server in 1993.

Versions

  • 1987 – MS LAN Manager 1.0 (Basic/Enhanced)
  • 1989 – MS LAN Manager 1.1
  • 1991 – MS LAN Manager 2.0
  • 1992 – MS LAN Manager 2.1
  • 1992 – MS LAN Manager 2.1a
  • 1993 – MS LAN Manager 2.2
  • 1994 – MS LAN Manager 2.2a

Many vendors shipped licensed versions, including:

Password hashing algorithm

The LM hash is computed as follows:

  1. The user's password is restricted to a maximum of fourteen characters.
  2. The user's password is converted to uppercase.
  3. The user's password is encoded in the System OEM code page.
  4. This password is NULL-padded to 14 bytes.
  5. The “fixed-length” password is split into two 7-byte halves.
  6. These values are used to create two DES keys, one from each 7-byte half, by converting the seven bytes into a bit stream with the most significant bit first, and inserting a parity bit after every seven bits (so 1010100 becomes 10101000). This generates the 64 bits needed for a DES key. (A DES key ostensibly consists of 64 bits; however, only 56 of these are actually used by the algorithm. The parity bits added in this step are later discarded.)
  7. Each of the two keys is used to DES-encrypt the constant ASCII string “KGS!@#$%”, resulting in two 8-byte ciphertext values. The DES CipherMode should be set to ECB, and PaddingMode should be set to NONE.
  8. These two ciphertext values are concatenated to form a 16-byte value, which is the LM hash.

Security weaknesses

LAN Manager authentication uses a particularly weak method of hashing a user's password known as the LM hash algorithm, stemming from the mid-1980s when viruses transmitted by floppy disks were the major concern. Although it is based on DES, a well-studied block cipher, the LM hash has several weaknesses in its design. This makes such hashes crackable in a matter of seconds using rainbow tables, or in a few minutes using brute force. Starting with Windows NT, it was replaced by NTLM, which is still vulnerable to rainbow tables, and brute force attacks unless long, unpredictable passwords are used, see password cracking. NTLM is used for logon with local accounts except on domain controllers since Windows Vista and later versions no longer maintain the LM hash by default. Kerberos is used in Active Directory Environments.

The major weaknesses of LAN Manager authentication protocol are:

  1. Password length is limited to a maximum of 14 characters chosen from the 95 ASCII printable characters.
  2. Passwords are not case sensitive. All passwords are converted into uppercase before generating the hash value. Hence LM hash treats PassWord, password, PaSsWoRd, PASSword and other similar combinations same as PASSWORD. This practice effectively reduces the LM hash key space to 69 characters.
  3. A 14-character password is broken into 7+7 characters and the hash is calculated for each half separately. This way of calculating the hash makes it dramatically easier to crack, as the attacker only needs to brute-force 7 characters twice instead of the full 14 characters. This makes the effective strength of a 14-character password equal to only 2 × 69 7 2 44 {\displaystyle 2\times 69^{7}\approx 2^{44}} , or twice that of a 7-character password, which is 3.7 trillion times less complex than the 69 14 2 86 {\displaystyle 69^{14}\approx 2^{86}} theoretical strength of a 14-character single-case password. As of 2020, a computer equipped with a high-end graphics processor (GPUs) can compute 40 billion LM-hashes per second. At that rate, all 7-character passwords from the 95-character set can be tested and broken in half an hour; all 7-character alphanumeric passwords can be tested and broken in 2 seconds.
  4. If the password is 7 characters or less, then the second half of hash will always produce same constant value (0xAAD3B435B51404EE). Therefore, a password is less than or equal to 7 characters long can be identified visibly without using tools (though with high speed GPU attacks, this matters less).
  5. The hash value is sent to network servers without salting, making it susceptible to man-in-the-middle attacks such as replay the hash. Without salt, time–memory tradeoff pre-computed dictionary attacks, such as a rainbow table, are feasible. In 2003, Ophcrack, an implementation of the rainbow table technique, was published. It specifically targets the weaknesses of LM encryption, and includes pre-computed data sufficient to crack virtually all alphanumeric LM hashes in a few seconds. Many cracking tools, such as RainbowCrack, Hashcat, L0phtCrack and Cain, now incorporate similar attacks and make cracking of LM hashes fast and trivial.

Workarounds

To address the security weaknesses inherent in LM encryption and authentication schemes, Microsoft introduced the NTLMv1 protocol in 1993 with Windows NT 3.1. For hashing, NTLM uses Unicode support, replacing LMhash=DESeach(DOSCHARSET(UPPERCASE(password)), "KGS!@#$%") by NThash=MD4(UTF-16-LE(password)), which does not require any padding or truncating that would simplify the key. On the negative side, the same DES algorithm was used with only 56-bit encryption for the subsequent authentication steps, and there is still no salting. Furthermore, Windows machines were for many years configured by default to send and accept responses derived from both the LM hash and the NTLM hash, so the use of the NTLM hash provided no additional security while the weaker hash was still present. It also took time for artificial restrictions on password length in management tools such as User Manager to be lifted.

While LAN Manager is considered obsolete and current Windows operating systems use the stronger NTLMv2 or Kerberos authentication methods, Windows systems before Windows Vista/Windows Server 2008 enabled the LAN Manager hash by default for backward compatibility with legacy LAN Manager and Windows ME or earlier clients, or legacy NetBIOS-enabled applications. It has for many years been considered good security practice to disable the compromised LM and NTLMv1 authentication protocols where they aren't needed. Starting with Windows Vista and Windows Server 2008, Microsoft disabled the LM hash by default; the feature can be enabled for local accounts via a security policy setting, and for Active Directory accounts by applying the same setting via domain Group Policy. The same method can be used to turn the feature off in Windows 2000, Windows XP and NT. Users can also prevent a LM hash from being generated for their own password by using a password at least fifteen characters in length.—NTLM hashes have in turn become vulnerable in recent years to various attacks that effectively make them as weak today as LanMan hashes were back in 1998.

Reasons for continued use of LM hash

Many legacy third party SMB implementations have taken considerable time to add support for the stronger protocols that Microsoft has created to replace LM hashing because the open source communities supporting these libraries first had to reverse engineer the newer protocols—Samba took 5 years to add NTLMv2 support, while JCIFS took 10 years.

Availability of NTLM protocols to replace LM authentication
Product NTLMv1 support NTLMv2 support
Windows NT 3.1 RTM (1993) Not supported
Windows NT 3.5 RTM (1994) Not supported
Windows NT 3.51 RTM (1995) Not supported
Windows NT 4 RTM (1996) Service Pack 4 (25 October 1998)
Windows 95 Not supported Directory services client (released with Windows 2000 Server, 17 February 2000)
Windows 98 RTM Directory services client (released with Windows 2000 Server, 17 February 2000)
Windows 2000 RTM (17 February 2000) RTM (17 February 2000)
Windows Me RTM (14 September 2000) Directory services client (released with Windows 2000 Server, 17 February 2000)
Samba ? Version 3.0 (24 September 2003)
JCIFS Not supported Version 1.3.0 (25 October 2008)
IBM AIX (SMBFS) 5.3 (2004) Not supported as of v7.1

Poor patching regimes subsequent to software releases supporting the feature becoming available have contributed to some organisations continuing to use LM Hashing in their environments, even though the protocol is easily disabled in Active Directory itself.

Lastly, prior to the release of Windows Vista, many unattended build processes still used a DOS boot disk (instead of Windows PE) to start the installation of Windows using WINNT.EXE, something that requires LM hashing to be enabled for the legacy LAN Manager networking stack to work.

See also

Notes

  1. If the password is more than fourteen characters long, the LM hash cannot be computed.
  2. The string “KGS!@#$%” could possibly mean Key of Glen and Steve and then the combination of Shift + 12345. Glen Zorn and Steve Cobb are the authors of RFC 2433 (Microsoft PPP CHAP Extensions).

References

  1. Andy Goldstein (2005). "Samba and OpenVMS" (PDF). de.openvms.org. Archived from the original (PDF) on 2021-02-07. Retrieved 2021-01-01.
  2. "DOS SMB Client Performance | OS/2 Museum". Retrieved 2023-08-28.
  3. "Chapter 3 - Operating System Installation". Microsoft Docs. 24 March 2009. The LMHash. Retrieved 2023-10-16.
  4. Glass, Eric (2006). "The NTLM Authentication Protocol and Security Support Provider: The LM Response". Retrieved 2015-05-12.
  5. "List of Localized MS Operating Systems". Microsoft Developer Network. Archived from the original on 2015-05-18. Retrieved 2015-05-12.
  6. ^ "Cluster service account password must be set to 15 or more characters if the NoLMHash policy is enabled". Microsoft. 2006-10-30. Archived from the original on 2014-09-10. Retrieved 2015-05-12.
  7. ^ Jesper Johansson (31 August 2016). "The Most Misunderstood Windows Security Setting of All Time". Microsoft Docs. Microsoft. Retrieved 16 October 2023. Although Windows Vista has not been released yet, it is worthwhile to point out some changes in this operating system related to these protocols. The most important change is that the LM protocol can no longer be used for inbound authentication—where Windows Vista is acting as the authentication server.
  8. Johansson, Jasper M. (2004-06-29). "Windows Passwords: Everything You Need To Know". Microsoft. Retrieved 2015-05-12.
  9. Rahul Kokcha
  10. Benchmark Hashcat v6.1.1 on RTX 2070S (SUPER), Mode 3000 LM, accessed November 29, 2020
  11. ^ "How to prevent Windows from storing a LAN manager hash of your password in Active Directory and local SAM databases". Microsoft Docs. 2007-12-03. Retrieved 2023-10-16.
  12. "Windows NT 4.0 Service Pack 4 Readme.txt File (40-bit)". Microsoft. 1998-10-25. Archived from the original on 2015-05-19. Retrieved 2015-05-12.
  13. "The Samba Team announces the first official release of Samba 3.0". SAMBA. 2003-09-24. Retrieved 2015-05-12.
  14. "The Java CIFS Client Library". Retrieved 2015-05-12.
  15. "AIX 5.3 Networks and communication management: Server Message Block file system". IBM. 2010-03-15. p. 441. Retrieved 2015-05-12.
  16. "AIX 7.1 Networks and communication management: Server Message Block file system". IBM. 2011-12-05. Retrieved 2015-05-12.

External links

Authentication
Authentication
APIs
Authentication
protocols
Network operating systems (NOS)
Current
Historic
Operating systems by Microsoft
Desktop / Server
Mobile
Embedded / IoT
Network
Others
Categories:
LAN Manager: Difference between revisions Add topic