Spring Data MongoDB nosql injection

Ajris :

I have a question. Are queries in mongo repositories in spring data safe from NoSQL injection attack? Is it possible to successfully perform such attack on spring-boot application ? For example if I create interface which extends MongoRepository with my own methods, are default queries generated in safe way that such attack is not possible? Thanks

Ajris :

I created small Spring Boot application with one mongo repository. I performed some basic NoSQL injection attacks on it, and just to be sure that they work, I did it also using Robo3T and checked that output was as I expected. For example, making query like:

db.getCollection('user').find({
"login":"f1", 
"password" : { '$ne': null } })

would give me all users with that login which exists in database. I made this attacks with doing such { '$ne': null } for String field type.(also I did some other attacks with other types, but i will explain my other conclusions later) As I figured out, in that way, it's impossible to provide our own commands. Spring just made this look like:

"password":"{ '$ne': null }"

and whenever we try to maybe end it with "", it would just add \ to our query, for example:

{ "login" : "f1", "password" : "\"end earlier\"" }

I also checked making other requests(mostly from here: https://github.com/cr0hn/nosqlinjection_wordlists/blob/master/mongodb_nosqli.txt as I found it here https://www.owasp.org/index.php/Testing_for_NoSQL_injection, maybe these links would help someone), however none of them was successful. So as far as I am concerned they were prepared on such cases like NoSQL Injection and they secured it. However, I would be grateful if someone could uphold or disagree with my opinion(which was based on performed attacks) and provide some more proofs or examples. Thanks.

Collected from the Internet

Please contact [email protected] to delete if infringement.

edited at
0

Comments

0 comments
Login to comment

Related

TOP Ranking

  1. 1

    Failed to listen on localhost:8000 (reason: Cannot assign requested address)

  2. 2

    Loopback Error: connect ECONNREFUSED 127.0.0.1:3306 (MAMP)

  3. 3

    How to import an asset in swift using Bundle.main.path() in a react-native native module

  4. 4

    pump.io port in URL

  5. 5

    Compiler error CS0246 (type or namespace not found) on using Ninject in ASP.NET vNext

  6. 6

    BigQuery - concatenate ignoring NULL

  7. 7

    ngClass error (Can't bind ngClass since it isn't a known property of div) in Angular 11.0.3

  8. 8

    ggplotly no applicable method for 'plotly_build' applied to an object of class "NULL" if statements

  9. 9

    Spring Boot JPA PostgreSQL Web App - Internal Authentication Error

  10. 10

    How to remove the extra space from right in a webview?

  11. 11

    java.lang.NullPointerException: Cannot read the array length because "<local3>" is null

  12. 12

    Jquery different data trapped from direct mousedown event and simulation via $(this).trigger('mousedown');

  13. 13

    flutter: dropdown item programmatically unselect problem

  14. 14

    How to use merge windows unallocated space into Ubuntu using GParted?

  15. 15

    Change dd-mm-yyyy date format of dataframe date column to yyyy-mm-dd

  16. 16

    Nuget add packages gives access denied errors

  17. 17

    Svchost high CPU from Microsoft.BingWeather app errors

  18. 18

    Can't pre-populate phone number and message body in SMS link on iPhones when SMS app is not running in the background

  19. 19

    12.04.3--- Dconf Editor won't show com>canonical>unity option

  20. 20

    Any way to remove trailing whitespace *FOR EDITED* lines in Eclipse [for Java]?

  21. 21

    maven-jaxb2-plugin cannot generate classes due to two declarations cause a collision in ObjectFactory class

HotTag

Archive