WASEC: Web Application Security for the everyday software engineer
WASEC: Web Application Security for the everyday software engineer
$6.99
Minimum price
$6.99
Suggested price
WASEC: Web Application Security for the everyday software engineer

This book is 100% complete

Completed on 2019-11-30

About the Book

As software engineers, we often think of security as an afterthought: build it, then fix it later.

Truth is, knowing a few simple browser features can save you countless of hours banging your head against a security vulnerability reported by a user. This book is a solid read that aims to save you days learning about security fundamentals for Web applications, and provide you a concise and condensed idea of everything you should be aware of when developing on the Web from a security standpoint.

Don't understand prepared statements very well? Can't think of a good way to make sure that if your CDN gets compromised your users aren't affected? Still adding CSRF tokens to every form around? Then this book will definitely help you get a better understanding of how to build strong, secure Web applications made to last.

Security is often an afterthought because we don't understand how simple measures can improve our application's defense by multiple orders of magnitude, so let's learn it together.

Table of contents

  1. Introduction
  2. Understanding the browser
  3. HTTP(S)
  4. Protection through HTTP headers
  5. HTTP cookies
  6. Situationals
  7. DDoS attacks
  8. Bug Bounty Programs
  9. Final words

Upcoming chapters

  • Docker security
  • Kubernetes security
  • Penetration tests
  • Secret management
  • Leveraging other services

About the Author

Alessandro Nadalin
Alessandro Nadalin

Alessandro Nadalin (who likes to go by "Alex"), is a seasoned technical leader who pays a lot of attention to enterprise patterns, methodologies, communities and (everyone’s) personal development: with 10 years of experience on his back, he heavily focused his attention towards agile practices, patterns of enterprise application architecture, leading mid-sized development teams and managing complexity in distributed systems.

A forward-thinker by nature, he still loves to get his hands dirty with code, or testing new platforms: he's am quite active on github and, from time to time, blogs in his own little place on the internet.

He's been involved in projects for governments, mainstream companies such as Samsung or Nissan and pioneered the technology scene of e-commerce platforms in the Middle East: when not working, you can find him speaking at some conference, blogging or grabbing a bite in the old side of Dubai.

Table of Contents

  • Introduction
    • Who this book is for
    • Formatting
    • Errata and additional content
  • Understanding the browser
    • What does a browser do?
    • Vendors
    • Vendor or standard bug?
    • A browser for developers
    • Into the HTTP protocol
  • HTTP
    • Overview
    • Mechanics: HTTP vs HTTPS vs H2
    • HTTPS
    • HTTPS everywhere
    • GET vs POST
    • In HTTP headers we trust
  • Protection through HTTP headers
    • HSTS
    • HPKP
    • Expect-CT
    • X-Frame-Options
    • Content-Security-Policy
    • X-XSS-Protection
    • Feature policy
    • X-Content-Type-Options
    • CORS
    • X-Permitted-Cross-Domain-Policies
    • Referrer-Policy
    • The reporting API
    • Testing your security posture
    • Stateful HTTP: managing sessions with cookies
  • HTTP cookies
    • What’s behind a cookie?
    • Session and persistent cookies
    • Host-only
    • Supercookies
    • Cookie flags that matter
    • Alternatives
    • What would LeBron do?
  • Situationals
    • Blacklisting versus whitelisting
    • Logging secrets
    • Never trust the client
    • Generating session IDs
    • Querying your database while avoiding SQL injections
    • Dependencies with known vulnerabilities
    • Have I been pwned?
    • Session invalidation in a stateless architecture
    • My CDN was compromised!
    • The slow death of EV certificates
    • Paranoid mode: on
    • Low-priority and delegated domains
    • OWASP
    • Hold the door
  • DDoS attacks
    • Anatomy of a DDoS
    • Why would anyone bomb me?
    • Notable DDoS attacks
    • Don’t panic: some services to the rescue!
    • Hackers welcome
  • Bug Bounty Programs
    • What’s in a program?
    • security.txt
    • HackerOne
    • Dealing with researchers
    • “Malicious” reporters
    • We’re about to wrap it up
  • This is the end
    • Forget safe. Make it safer.
    • In the works
    • A few thank yous

Authors have earned$8,253,833writing, publishing and selling on Leanpub,
earning 80% royalties while saving up to 25 million pounds of CO2 and up to 46,000 trees.

Learn more about writing on Leanpub

The Leanpub 45-day 100% Happiness Guarantee

Within 45 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.

See full terms

Free Updates. Free App. DRM Free.

If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).

Most Leanpub books are available in PDF (for computers), EPUB (for phones and tablets), MOBI (for Kindle) and in the free Leanpub App (for Mac, Windows, iOS and Android). The formats that a book includes are shown at the top right corner of this page.

Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.

Learn more about Leanpub's ebook formats and where to read them

Write and Publish on Leanpub

You can use Leanpub to easily write, publish and sell in-progress and completed ebooks and online courses! Leanpub is a powerful platform for serious authors, combining a simple, elegant writing and publishing workflow with a store focused on selling in-progress ebooks. Leanpub is a magical typewriter for authors: just write in plain text, and to publish your ebook, just click a button. It really is that easy.

Learn more about writing on Leanpub