Secure coding in PHP Training Course
This course equips PHP developers with the essential skills needed to build applications resilient against modern internet-based threats. Through PHP-centric examples that extend beyond the OWASP Top Ten, the curriculum covers a wide array of injection attacks, script injections, vulnerabilities in PHP session handling, insecure direct object references, file upload issues, and more. PHP-specific vulnerabilities are categorized into standard types such as missing or improper input validation, flawed error and exception handling, misuse of security features, and time- and state-related problems. Regarding the latter, we examine attacks such as open_basedir circumvention, denial-of-service via magic floats, and hash table collision attacks. In each scenario, participants will learn the critical techniques and functions required to mitigate these risks.
A significant emphasis is placed on client-side security, addressing issues related to JavaScript, Ajax, and HTML5. The course introduces several PHP security extensions, including hash, mcrypt, and OpenSSL for cryptography, as well as Ctype, ext/filter, and HTML Purifier for input validation. Best practices for hardening PHP configuration (php.ini settings), Apache, and the broader server environment are also detailed. Finally, an overview of various security testing tools and techniques available to developers and testers is provided, including security scanners, penetration testing tools, exploit kits, sniffers, proxy servers, fuzzing tools, and static source code analyzers.
Both the introduction of vulnerabilities and configuration best practices are reinforced with hands-on exercises. These demonstrations illustrate the impact of successful attacks, show how to apply mitigation strategies, and introduce the use of various extensions and tools.
Participants completing this course will be able to:
- Grasp the fundamental concepts of security, IT security, and secure coding.
- Identify web vulnerabilities beyond the OWASP Top Ten and understand how to prevent them.
- Recognize client-side vulnerabilities and apply secure coding practices.
- Develop a practical understanding of cryptography.
- Utilize various built-in security features of PHP.
- Identify typical coding errors and learn how to avoid them.
- Stay informed about recent vulnerabilities affecting the PHP framework.
- Gain practical experience in using security testing tools.
- Access resources and further reading on secure coding practices.
Audience
Developers
This course is available as onsite live training in Norway or online live training.Course Outline
- IT security and secure coding
- Web application security
- Web application vulnerabilities
- Client-side security
- Client-side security
- Practical cryptography
- PHP security services
- PHP Environment
- Principles of security and secure coding
- Common coding errors and vulnerabilities
- Security testing techniques and tools
- Knowledge sources
Open Training Courses require 5+ participants.
Secure coding in PHP Training Course - Booking
Secure coding in PHP Training Course - Enquiry
Secure coding in PHP - Consultancy Enquiry
Testimonials (3)
I genuinely enjoyed the real life examples.
Marios Prokopiou
Course - Secure coding in PHP
All topics were well covered and presented with a lot of examples. Ahmed was very efficient and managed to keep us focused and attracted at all times.
Kostas Bastas
Course - Secure coding in PHP
The subject of the course was very interesting and gave us many ideas.
Anastasios Manios
Course - Secure coding in PHP
Upcoming Courses
Related Courses
AdaBoost Python for Machine Learning
14 HoursThis instructor-led, live training in Norway (available online or on-site) is designed for data scientists and software engineers who wish to employ AdaBoost to create boosting algorithms for machine learning using Python.
By the conclusion of this training, participants will be able to:
- Establish the necessary development environment to initiate the creation of machine learning models with AdaBoost.
- Comprehend the ensemble learning approach and how to execute adaptive boosting.
- Learn the process of constructing AdaBoost models to enhance machine learning algorithms in Python.
- Utilize hyperparameter tuning to improve the accuracy and performance of AdaBoost models.
Network Security and Secure Communication
21 HoursImplementing a secure networked application can be challenging, even for developers who have previously utilized various cryptographic building blocks (such as encryption and digital signatures). To help participants grasp the role and application of these cryptographic primitives, a solid foundation is first laid regarding the core requirements of secure communication: secure acknowledgment, integrity, confidentiality, remote identification, and anonymity. This includes presenting typical problems that can undermine these requirements alongside real-world solutions.
Given that cryptography is a critical aspect of network security, the most important cryptographic algorithms in symmetric cryptography, hashing, asymmetric cryptography, and key agreement are also discussed. Rather than presenting an in-depth mathematical background, these elements are explored from a developer's perspective, illustrating typical use-case examples and practical considerations related to cryptography, such as public key infrastructures. Security protocols in various areas of secure communication are introduced, with an in-depth discussion on the most widely-used protocol families, such as IPSEC and SSL/TLS.
Typical cryptographic vulnerabilities are discussed, both in relation to certain crypto algorithms and cryptographic protocols (e.g., BEAST, CRIME, TIME, BREACH, FREAK, Logjam, Padding oracle, Lucky Thirteen, POODLE, and similar), as well as the RSA timing attack. In each case, the practical considerations and potential consequences of each problem are described, again, without delving into deep mathematical details.
Finally, as XML technology is central to data exchange for networked applications, the security aspects of XML are described. This includes the usage of XML within web services and SOAP messages, alongside protection measures such as XML signature and XML encryption. The discussion also covers weaknesses in these protection measures and XML-specific security issues, such as XML injection, XML external entity (XXE) attacks, XML bombs, and XPath injection.
Participants attending this course will
- Understand basic concepts of security, IT security, and secure coding
- Understand the requirements of secure communication
- Learn about network attacks and defenses at different OSI layers
- Have a practical understanding of cryptography
- Understand essential security protocols
- Understand some recent attacks against cryptosystems
- Gain information about some recent related vulnerabilities
- Understand security concepts of web services
- Obtain sources and further readings on secure coding practices
Audience
Developers, Professionals
C/C++ Secure Coding
21 HoursThis three-day course introduces the fundamentals of securing C/C++ code against exploitation by malicious actors, focusing on vulnerabilities related to memory management and input handling. The curriculum emphasizes core principles for writing robust and secure software.
Advanced Java Security
21 HoursEven experienced Java developers do not always fully master the security services provided by Java, nor are they necessarily aware of the vulnerabilities relevant to web applications written in Java.
This course introduces the security components of Standard Java Edition, while also addressing security issues within Java Enterprise Edition (JEE) and web services. Before discussing specific services, we cover the foundations of cryptography and secure communication. Numerous exercises focus on declarative and programmatic security techniques in JEE, alongside discussions on both transport-layer and end-to-end security for web services. Through several practical exercises, participants get to experience these APIs and tools firsthand.
The course also examines and explains the most common and severe programming flaws in the Java language and platform, as well as web-related vulnerabilities. Beyond typical bugs made by Java developers, the security vulnerabilities covered include language-specific issues and problems arising from the runtime environment. All vulnerabilities and corresponding attacks are demonstrated through accessible exercises, followed by recommended coding guidelines and possible mitigation techniques.
Participants attending this course will
- Understand fundamental concepts of security, IT security, and secure coding
- Learn about web vulnerabilities beyond the OWASP Top Ten and how to avoid them
- Understand security concepts in web services
- Learn to utilize various security features of the Java development environment
- Gain a practical understanding of cryptography
- Understand the security solutions of Java EE
- Learn about typical coding mistakes and how to avoid them
- Receive information about some recent vulnerabilities in the Java framework
- Obtain practical knowledge in using security testing tools
- Access sources and further reading on secure coding practices
Audience
Developers
Standard Java Security: Secure Coding & Development Practices
14 HoursDescription
The Java language and the Runtime Environment (JRE) were designed to eliminate many of the common, problematic security vulnerabilities found in other languages, such as C/C++. However, software developers and architects must not only master the security features available in the Java environment (positive security) but also remain vigilant regarding the numerous vulnerabilities that still pose risks to Java development (negative security).
The introduction of security services begins with a concise overview of cryptographic foundations, establishing a shared baseline for understanding the purpose and operation of the relevant components. The practical application of these components is illustrated through several hands-on exercises, allowing participants to experiment with the discussed APIs firsthand.
The course also examines and explains the most frequent and severe programming flaws in the Java language and platform, addressing both typical bugs made by Java programmers and issues specific to the language and its environment. All vulnerabilities and associated attacks are demonstrated through easy-to-understand exercises, followed by recommended coding guidelines and mitigation techniques.
Participants attending this course will
- Understand the fundamental concepts of security, IT security, and secure coding
- Learn about web vulnerabilities beyond the OWASP Top Ten and how to avoid them
- Learn to utilize various security features within the Java development environment
- Gain a practical understanding of cryptography
- Learn about common coding mistakes and how to prevent them
- Gain insight into recent vulnerabilities in the Java framework
- Receive sources and further reading materials on secure coding practices
Audience
Developers
.NET, C# and ASP.NET Security Development
14 HoursToday, numerous programming languages allow developers to compile code for the .NET and ASP.NET frameworks. While this environment offers robust tools for security development, it is crucial for developers to understand how to apply architecture-level and coding-level programming techniques to implement effective security measures, prevent vulnerabilities, and limit their potential exploitation.
This course aims to equip developers with the skills to prevent untrusted code from executing privileged actions, safeguard resources through rigorous authentication and authorization, manage remote procedure calls, handle sessions, and explore various functional implementations through extensive hands-on exercises.
The course introduces various vulnerabilities by highlighting common programming errors associated with .NET. It further examines ASP.NET vulnerabilities, discussing how different environment settings impact security. Additionally, it addresses ASP.NET-specific vulnerabilities, covering general web application security challenges as well as specialized issues and attack methods, such as ViewState manipulation and string termination attacks.
Participants attending this course will
- Grasp fundamental concepts of security, IT security, and secure coding
- Identify web vulnerabilities beyond the OWASP Top Ten and learn strategies to mitigate them
- Master the use of various security features within the .NET development environment
- Acquire practical expertise in utilizing security testing tools
- Recognize common coding mistakes and understand how to avoid them
- Stay informed about recent vulnerabilities in .NET and ASP.NET
- Access resources and further reading materials on secure coding practices
Audience
Developers
Microsoft SDL Core
14 HoursThe Combined SDL Core training offers an in-depth look at secure software design, development, and testing through the Microsoft Secure Development Lifecycle (SDL). It provides a Level 100 overview of the fundamental building blocks of SDL, followed by design techniques to help detect and fix flaws in the early stages of the development process.
Focusing on the development phase, the course provides an overview of typical security-relevant programming bugs in both managed and native code. Attack methods are presented for the discussed vulnerabilities, along with associated mitigation techniques. These concepts are explored through a series of hands-on exercises that offer practical, real-world hacking scenarios for participants. An introduction to various security testing methods is followed by demonstrations of the effectiveness of different testing tools. Participants gain a deeper understanding of how these tools operate by applying them to previously discussed vulnerable code through practical exercises.
Participants attending this course will
Understand basic concepts of security, IT security, and secure coding
Become familiar with the essential steps of the Microsoft Secure Development Lifecycle
Learn secure design and development practices
Learn about secure implementation principles
Understand security testing methodology
- Obtain sources and further reading materials on secure coding practices
Audience
Developers, Managers
DevOps Security: Creating a DevOps Security Strategy
7 HoursIn this instructor-led live course held in Norway, participants will learn how to formulate an appropriate security strategy to address the security challenges inherent in DevOps practices.
EC-Council Certified DevSecOps Engineer (ECDE)
28 HoursThe EC-Council Certified DevSecOps Engineer (ECDE) programme is a practical course designed to empower professionals with the expertise needed to integrate security throughout the DevOps lifecycle, ensuring robust software development from initial planning to final deployment.
This instructor-led live training, available both online and onsite, targets intermediate-level software and DevOps professionals seeking to embed security practices within CI/CD pipelines, thereby guaranteeing the delivery of secure and compliant code.
Upon completion of this training, participants will be equipped to:
- Comprehend the core principles and practices of DevSecOps.
- Secure all stages of the CI/CD pipeline through the utilization of automated tools.
- Apply secure coding methodologies and conduct vulnerability scans.
- Prepare for the ECDE certification by engaging in practical labs and review sessions.
Course Format
- Interactive lectures and discussions.
- Hands-on experimentation with DevSecOps tools within simulated pipelines.
- Guided exercises centred on secure development and deployment processes.
Customization Options
- For tailored training aligned with your team’s specific workflows or toolchain, please reach out to us to make arrangements.
Laravel PHP Framework
14 HoursThis instructor-led, live training in Norway introduces the fundamentals of Laravel and guides participants through the creation of a Laravel-based web application.
Laravel Livewire
7 HoursThis instructor-led live training in Norway (online or onsite) targets developers who wish to learn and use Livewire to build modern and dynamic application interfaces.
By the end of this training, participants will be able to:
- Build and test Livewire components.
- Build applications using the Livewire library.
- Create dynamic components within PHP.
Laravel and Vue.js
14 HoursThis instructor-led, live training in Norway (online or onsite) is aimed at web developers who wish to use Laravel and Vue JS for fullstack web development.
By the end of this training, participants will be able to:
- Develop web applications with Laravel and Vue JS.
- Integrate the Laravel backend API into Vue JS.
- Deploy a Laravel application.
Laravel: Middleware Development
14 HoursThis instructor-led live training (available online or onsite) is targeted at web developers who wish to build middleware and web services in Laravel.
By the end of this training, participants will be able to:
- Use Laravel's PHP Artisan to generate code and components.
- Build RESTful APIs in Laravel that can browse, read, edit, add, and delete.
- Filter and sort results based on URL parameters using RESTful APIs.
How to Write Secure Code
35 HoursThis course aims to assist with the following:
- Help developers to master the techniques of writing secure code
- Help software testers to test the security of the application before publishing to the production environment
- Help software architects to understand the risks surrounding the applications
- Help team leaders to set the security baselines for the developers
- Help web masters to configure the servers to avoid misconfigurations
Secure Developer Java (Inc OWASP)
21 HoursThis course provides an in-depth exploration of secure coding principles for Java, utilizing the testing framework established by the Open Web Application Security Project (OWASP). The Open Web Application Security Project is a global online community dedicated to producing freely available resources, including articles, methodologies, documentation, tools, and technologies, aimed at enhancing web application security.