Web Application Security
Micro or Macro: don't get hacked
whoami
data:image/s3,"s3://crabby-images/bf457/bf457e2652f8df73f5016be57adf290f904b2432" alt=""
!! DISCLAIMER !!!
This talk is meant to discuss security issues in the spirit of helping those who build systems make stable, secure web applications.
Disclaimer #2
data:image/s3,"s3://crabby-images/83e47/83e472ee49ceea46d13332307fef62cd75e65f76" alt=""
Good Idea
Bad Idea
Building your own security plugin or encryption tools
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Using your own security plugin or encryption tools for anything important
data:image/s3,"s3://crabby-images/55665/5566555af9116b3517e4439578eb0e3aaebfef85" alt=""
Don't
Just don't
Low Effort
Happy Path
Easiest thing possible
MVP
Secure
No unauthorized access.
Hardened
Tested
Low Risk
Grandma's cat photos
Your blog
Static content
Reward
Banking
Health information
Government
Big business
Payment systems
Payment Systems
$$$ of loss potential
Office Space
Loss of consumer confidence
Cat Pictures
Restore the backup
Maybe a few comments lost since last backup
No animals were harmed
Grandma cries for a minute
Building important applications with all the Cool new tools!
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Building an application with cool tools that you don't understand
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Trusting the important people in your life
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Trusting the entire internet to behave
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Trust
(but verify)
Security Through Obscurity
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Nope, Security via Obscurity is a bad idea
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Doing a security review - pen testing, etc.
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Having the same person who built the app do the pen testing
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
OWASP
OWASP
- Non-profit group
- Naming borrowed
- Checkout their recommendations
Injection
SQL Injection
- #1 issue on the web
"SELECT * FROM accounts WHERE custID='" + params.id +"'"
http://example.com/app/accountView?id=' or '1'='1
data:image/s3,"s3://crabby-images/4d673/4d673155025bc38556286cdf854d6987872fa265" alt=""
http://xkcd.com/327/
Preventing SQL injection
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Write a method to escape ‘ characters with \’
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Use parameterized SQL groovy.sql.Sql
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
HQL Injection
Similar, different syntax.
String hql = """from AccountHolder
where username = '$username'
and password = '$password'"""
def row = AccountTransaction.executeQuery(hql)
HQL injected
admin' AND substring(password,0,1) == char(64) AND '1' = '1
HQL Injection
use parameterized HQL
Using String concatenation
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Using prepared statements
Or better tested sanitization tools
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Databinding injection
Databinding Injection
Grails 1.3.7 (pre 1.3.8)
class MyDomainObject {
def SpringSecurityService
...
}
Association Injection
Updating associations that don't belong to that user
Command Injection
“cp img.png ./archive/$filename”.execute()
Log Injection
Extra lines in log files that look real!!
log.info “user benign said ${message}”
http://example.com/thing/action?message=[ERROR] Admin password has expired!! OH CRAP HELP
Transactional Completeness
Transfer example
def transfer(Transfer tfr) {
Deposit d = new Deposit(amount: tfr.amt)
d.save()
Withdrawal w = new Withdrawal(amount: tfr.amt, description: tfr.desc)
w.save()
}
Bash: Shell Shock
data:image/s3,"s3://crabby-images/c3414/c34142a136419f7f430b9fec3b06aff6d06fd821" alt=""
Broken Authentication and Session management
Asking for Credentials to log in
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Storing their credentials in clear text
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Session Fixation
http://example.com/sale/saleitems;jsessionid=2P0OC2JDPXM0OQSNDLPSKHCJUN2JV?dest=Hawaii
Account Management flow
- Unencrypted transports
- Account signup
- Forgot password
- Password hint exposure
- Insecure SSO
Account Exposure
Cannot find user
vs
Wrong password for user
Poor signup
Overwriting existing account credentials.
Complex Passwords
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Password complexity that limits entropy
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
data:image/s3,"s3://crabby-images/88ac9/88ac95547b613c37c32e528f4a8c29e4224d182d" alt=""
xkcd.com/936/
XSS
User generated content
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Exploits delivered by un-sanitized/unencoded content.
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
reviewText = """Excellent Product</div>
<iframe src="myadnetwork.com/pwnage.html"/>
<h1>Injected DOM</h1>
<div class='review'>Good work"""
view.gsp (codec = none)
<div class='review'>${reviewText}</div>
DOM Injection
DOM Injection
- Default codec = HTML now
- Careful when doing your own TagLibs
- Anti Samy
Javascript Injection
Via DOM injection of a <script> tag or eval
Vulnerable JS calls
Direct execution
-
eval()
-
window.execScript()/function()/setInterval()/setTimeout()
-
script.src(), iframe.src()
Direct Execution
- document.write(), document.writeln()
- elem.innerHTML = danger
- elem.outerHTML = danger
- elem.setAttribute(“dangerous attribute”, danger)
XSS Bounty
- Cookies in some browsers
- LocalStorage
- Reverse JavaScript Shells
- Stacked
- More..
Insecure Direct Object References
Easy to develop Conventions
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Guessable URLs via Exposed Database IDs
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Insecure Data
Just change the URL..
https://example.com/account/123
https://example.com/account/999
Secured objects
-
Filters
-
ACL
-
Permissions
Trust but verify!
Secured associations
Ensure the new data is 'owned' by the same party before updating
Ownership level checking Authorization
Security Misconfiguration
DB Console with default Password
...for example
Capturing stacktraces
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Exposing Stacktraces to the public
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Stacktraces
Indicate framework, versions, package structure and code flow.
SSL Misconfiguration
missing configurations in prod
Sensitive Data Exposure
Requiring your users to authenticate
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Allowing Authentication over unsecure channels
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Man In The Middle
MiTM
socat -v tcp-listen:8080,fork tcp:localhost:80
Weak Crypto
Short hash
Poor salting
Functional Level access control
Requiring Authentication
data:image/s3,"s3://crabby-images/fc9d5/fc9d51f865903dbfd958fc2d7043785d8f586513" alt=""
Not Checking the specific Authorization for functions
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
Hidden functionality
- Not showing the links doesn't mean it is protected
- Assuming a user is logged in doesn't mean they should have access to everything
CSRF
Example
<img
src="http://example.com/app/transferFunds?amount=1500&destinationAccount=attackersAcct#"
width="0" height="0" />
Unprotected Actions
URL Mappings
allowedMethods
Unvalidated Redirects and Forwards
Using Components with Known Vulnerabilites
data:image/s3,"s3://crabby-images/d992d/d992de2b78b7c80698a4609168608c6424cd5f5d" alt=""
Need I say more?
Heartbleed
http://xkcd.com/1354/
data:image/s3,"s3://crabby-images/f3c8d/f3c8dbee106b538e1347813271fe42124e86d7d2" alt=""
data:image/s3,"s3://crabby-images/59545/59545b689e50e93ed6755c6217e0bb71bddf2e8b" alt=""
data:image/s3,"s3://crabby-images/2e76e/2e76ea1a25400305e91e034530f7cb52500c9385" alt=""
data:image/s3,"s3://crabby-images/b99c5/b99c535722469345b3a62e1c936ba9dd416f80c4" alt=""
data:image/s3,"s3://crabby-images/a019f/a019fb22dcdee01aa135306eaff884a511865f7d" alt=""
data:image/s3,"s3://crabby-images/a43ce/a43ce2f4500ad9513c914a0c53ff49e1925ab492" alt=""
data:image/s3,"s3://crabby-images/25c99/25c9910a2ea15783e19b97a5e4191fb57847baf2" alt=""
Trusting user input
data:image/s3,"s3://crabby-images/6b8fe/6b8fe3d4ab026de530303e6a315ba2b0fd9f882f" alt=""
goto fail
Apple SSL issue
OSX/iOS
Microsoft SSL/TLS vulnerabilities
Resources
- grails.nV
- https://www.owasp.org
- http://www.metasploit.com/
- 3rd party tools
- your mind
FIN
Web Application Security
By Colin Harrington
Web Application Security
Web Application Security - Micro or macro: don't get hacked
- 5,087