Ranter
Join devRant
Do all the things like
++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
Sign Up
Pipeless API
From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
Learn More
Comments
-
Root797013yShort answer because I’m not well enough to get into details, but yes, sort of. That’s the gist.
A little less short answer: that’s not quite how it works, but you’re thinking along the correct lines. -
Yes and (likely) no.
Arbitrary SQLite queries were indeed memory unsafe in the past. But websites must be protected from those anyway, as it would lead to a loss of security anyway.
Your example does not have those.
Excluding vulnerabilities in the query language, a regular (especially read only) query _should_ not change the engine state leading to remote code execution.
It is a theoretic attack vector, but I doubt it is more than that: For code execution you usually have to modify the the return address or modify executable memory - and a regular call to a non attacker controlled query should not do any of this.
I'm not saying this is impossible, but it is nothing I'd worry about (neither as an attack nor website owner). -
killames5703yBut probably not
You’d be trying something like a sql injection attack and feeding byte code to its compiler -
@killames I'm thinking more along the lines how particular requests may leave partial states behind.
And by chaining multiple requests like this, these otherwise harmless bugs in engine state may be combine into an attack vector proper.
Related Rants
I've been wondering about SQLite, how it decides to execute your SQL and then generates byte code to do it.
Hypothetically if you were sufficiently familiar with the quarks of SQLite at a low enough level, one could craft web requests on sites running it, such that the results of each subsequent request, leave the SQLite engine in a particular state, no?
Suppose previous states, when interleaved with subsequent carefully crafted states, lead to execution and injection vulnerabilities.
Arent ideas like this what lead to the randomization of jump addresses in modern architectures?
question
vulnerabilities
sqlite
sql