8296  Reviews star_rate star_rate star_rate star_rate star_half

Desktop Application Security in Python

This Desktop Application Security in Python course teaches developers basic and advanced skills for building secure desktop applications using Python. Participants learn how to identify and mitigate...

Read More
Duration 3 days
Course Code CYD-APPSECPYTH
Available Formats Classroom

Overview

This Desktop Application Security in Python course teaches developers basic and advanced skills for building secure desktop applications using Python. Participants learn how to identify and mitigate threats, implement secure coding practices, and leverage cryptography to safeguard sensitive data. By the end of the course, learners can create robust and secure desktop applications that protect against cyberattacks.

Skills Gained

  • Understand fundamental cyber security concepts and threats
  • Apply input validation techniques to mitigate injection attacks
  • Identify and prevent integer handling vulnerabilities
  • Securely handle files and streams to avoid path traversal attacks
  • Implement robust authentication and password management strategies
  • Utilize cryptography to protect data confidentiality and integrity
  • Recognize and address common software security weaknesses related to time, state, and errors

Prerequisites

All Python Security training students must have general Python development experience.

Course Details

Introduction to Cyber Security

  • What is security?
  • Threat and risk
  • Cyber security threat types – the CIA triad
  • Cyber security threat types – the STRIDE model
  • Consequences of insecure software

Input Validation

  • Input validation principles
  • Denylists and allowlists
  • What to validate – the attack surface
  • Where to validate – defense in depth
  • When to validate – validation vs transformations
  • Validation with regex
  • Regular expression denial of service (ReDoS)
  • Dealing with ReDoS

Injection

  • Injection principles
  • Injection attacks
  • SQL injection
  • Code injection

Integer Handling Problems

  • Representing signed numbers
  • Integer visualization
  • Integers in Python
  • Integer overflow
  • Integer overflows in ctypes and numpy

Files and Streams

  • Path traversal
  • Additional challenges in Windows
  • Path traversal best practices

Security Features

  • Authentication
  • Password management
  • Information exposure

Platform Security

  • Python platform security

Using Vulnerable Components

  • Assessing the environment
  • Hardening
  • Malicious packages in Python
  • Vulnerability management

Cryptography for Developers

  • Cryptography basics
  • Cryptography in Python
  • Elementary algorithms
  • Confidentiality protection
  • Integrity protection
  • Public Key Infrastructure (PKI)

Time and State

  • Race conditions

Errors

  • Error and exception handling principles
  • Exception handling

Wrap Up

  • Secure coding principles
  • And now what?

Conclusion

Schedule

FAQ

Does the course schedule include a Lunchbreak?

Classes typically include a 1-hour lunch break around midday. However, the exact break times and duration can vary depending on the specific class. Your instructor will provide detailed information at the start of the course.

What languages are used to deliver training?

Most courses are conducted in English, unless otherwise specified. Some courses will have the word "FRENCH" marked in red beside the scheduled date(s) indicating the language of instruction.

What does GTR stand for?

GTR stands for Guaranteed to Run; if you see a course with this status, it means this event is confirmed to run. View our GTR page to see our full list of Guaranteed to Run courses.

Does Ascendient Learning deliver group training?

Yes, we provide training for groups, individuals and private on sites. View our group training page for more information.

What does vendor-authorized training mean?

As a vendor-authorized training partner, we offer a curriculum that our partners have vetted. We use the same course materials and facilitate the same labs as our vendor-delivered training. These courses are considered the gold standard and, as such, are priced accordingly.

Is the training too basic, or will you go deep into technology?

It depends on your requirements, your role in your company, and your depth of knowledge. The good news about many of our learning paths, you can start from the fundamentals to highly specialized training.

How up-to-date are your courses and support materials?

We continuously work with our vendors to evaluate and refresh course material to reflect the latest training courses and best practices.

Are your instructors seasoned trainers who have deep knowledge of the training topic?

Ascendient Learning instructors have an average of 27 years of practical IT experience and have also served as consultants for an average of 15 years. To stay current, instructors spend at least 25 percent of their time learning new, emerging technologies and courses.

Do you provide hands-on training and exercises in an actual lab environment?

Lab access is dependent on the vendor and the type of training you sign up for. However, many of our top vendors will provide lab access to students to test and practice. The course description will specify lab access.

Will you customize the training for our company’s specific needs and goals?

We will work with you to identify training needs and areas of growth.  We offer a variety of training methods, such as private group training, on-site of your choice, and virtually. We provide courses and certifications that are aligned with your business goals.

How do I get started with certification?

Getting started on a certification pathway depends on your goals and the vendor you choose to get certified in. Many vendors offer entry-level IT certification to advanced IT certification that can boost your career. To get access to certification vouchers and discounts, please contact info@ascendientlearning.com.

Will I get access to content after I complete a course?

You will get access to the PDF of course books and guides, but access to the recording and slides will depend on the vendor and type of training you receive.

How do I request a W9 for Ascendient Learning?

View our filing status and how to request a W9.

Reviews

Great instructor, clear and concise course. Labs were easy to follow and worked perfectly.

Instructor, Training material & span of the training is neatly planned.

They are very good and made sure we had all the appropriate materials for class.

vary good online learning. instructor is vary good the way he explained every thing.

Great company -- easy to sign up and very organized. Loved my teacher and class overall.