Strategies for Securing Web Content
Strategies for Securing Web Content
WWDC 2018
Secure Transport
Your ToDo list
- HTTPS and WSS
- Strict Transport Security ( HSTS )
- Auto-upgrades your domain - Upgrade Insecure Request ( UIR )
- Auto-upgrades cross-origin loads - Secure Cookies
- Are never sent in plaintext
data:image/s3,"s3://crabby-images/bd387/bd38793501e46b89832e4d2317092a335cf28210" alt=""
data:image/s3,"s3://crabby-images/1f060/1f06089dcda9a1d493ede84c1c422f6f4f22dbca" alt=""
Cross-Origin Loads
data:image/s3,"s3://crabby-images/1130d/1130d440d38a19bce3e29b50e694302ece527320" alt=""
Cross-Origin Lockdown
data:image/s3,"s3://crabby-images/0e5e0/0e5e06fbd465fe9ac4e692b331e74453202b8876" alt=""
Subresource integrity
Check the integrity before executing the code
data:image/s3,"s3://crabby-images/79a34/79a34584cb5866a2da5707d58d5800b12aa4091a" alt=""
data:image/s3,"s3://crabby-images/1f840/1f840ae0f9df1d6e73bab271f390e6f162e77222" alt=""
Content security policy
data:image/s3,"s3://crabby-images/ce18d/ce18d668694f308ca4799118d47df972fbc17560" alt=""
data:image/s3,"s3://crabby-images/b58e2/b58e2b1df67c9df4bef6a0055832a642508134b9" alt=""
HttpOnly cookies
- HTTP only means don’t expose the cookie in the
document.cookie
JavaScript API
data:image/s3,"s3://crabby-images/560bb/560bb56962272cb0ea1fb85a0ad2724a0232494f" alt=""
SameSite cookies
- Only send it when I’m the page owner,
when I’m the main page, not when I’m embedded. - If your web content is being embedded by someone you don’t trust,
the SameSite cookie will not be sent and your server can detect this.
data:image/s3,"s3://crabby-images/1f129/1f1291d34597f9fd5416eb71874240defe87c6a8" alt=""
data:image/s3,"s3://crabby-images/1031f/1031f587ee54d52817e75ebff143d8e445af8d74" alt=""
Cross-Origin-Resource-Policy
- Only my own site can load this
- Only when my domain name is the main page domain and I’m pulling in this image, then load the image into the web content process
- When someone tries to cross-origin load your image or your script and
you’re sending this response header, those things won’t be loaded
data:image/s3,"s3://crabby-images/9fea3/9fea3c9f2ac8f0215318e1e81bafb2f480dcd1f7" alt=""
Cross-Origin-Window-Policy
- The opener can even navigate your window outside of your control 😡
data:image/s3,"s3://crabby-images/523a2/523a2c379539246f14dac4e0484c656d5bc87a95" alt=""
Cross-origin attacks
Cross-Site Scripting ( exam )
- Trying to steal the cookies of that user ( by a message )😡
- Http Only cookies protect your cookies 😆
data:image/s3,"s3://crabby-images/69679/696790b4debc5f152ac9f819d563fd742059ef1b" alt=""
Cross-origin attacks
Compromised CDN ( exam )
- Redirecting that script request to evil.example, loading attack code 😡
- If it doesn’t match the check sum, you’re going to load is off of your own server instead. So, that attack is also foiled 😆
data:image/s3,"s3://crabby-images/25c52/25c527149297aafcce87c1219486527116120fed" alt=""
data:image/s3,"s3://crabby-images/8e264/8e26424cf9dd38df274ed7a35721466a75775076" alt=""
Cross-origin attacks
Cross-Site Request Forgeries ( exam )
- The attacker that of course has phished one of your users, meaning sent a link and lured that user onto the attacker’s site, evil.example 😡
- The victim user doesn’t realize is that there’s a hidden resource load with your web content sending a message on the victim user’s behalf 😡
- Use Same-Site Cookies. They will not be sent in the embedded case, which means that your server will detect I’m being embedded here.
data:image/s3,"s3://crabby-images/3c7aa/3c7aa005fef188d0c3dfb242453823d1001e5546" alt=""
Speculative Execution Attacks
- Speculative Execution and the Attack (Spectre)
- Defenses
- WKWebView
- Content Security Policy
- HttpOnly cookies
- SameSite cookies
- Cross-Origin-Resource-Policy
Speculative Execution Defined
- Make sure your web content doesn’t end up in the same process as a frame from evil.example
data:image/s3,"s3://crabby-images/f29d5/f29d56f0697ac83efd5b9a574fdb5833ffbe8a1e" alt=""
data:image/s3,"s3://crabby-images/f3444/f3444a2419ab7f7c1b32ec995defeab0e2a16091" alt=""
UIWebView
- Infectious 😡
data:image/s3,"s3://crabby-images/f9554/f95548fbd1249fbb4f0a8058e96cd7396bc662cb" alt=""
WKWebView
- Not infectious 😆
- Use WKWebView
data:image/s3,"s3://crabby-images/8c9b0/8c9b05671c0b7898e8b7e74909e3f4b19a236b7a" alt=""
Speculative Execution Attacks
Content security policy
- You might have an embedded social widget from social.example, but then you might have an injection attack,
maybe it’s the messaging thing again where someone can send markup in a message and
you accidentally render it and they pull in an iframe from evil.example 😡 - Specifying from where you allow frame.
Don’t allow evil.example 😆 frame-ancestors 'none'
— never iframe me
data:image/s3,"s3://crabby-images/a8516/a8516293302ad0b2d8a81da34b16b5fce2e49959" alt=""
Speculative Execution Attacks
HttpOnly cookies
- evil.example can reach into an iframe from your content and actually read the cookies 😡
- Use HttpOnly. We don’t need to expose in the
document.cookie
API 😆
data:image/s3,"s3://crabby-images/6913b/6913b2cece3f572f49734531e796071f4cdc60f4" alt=""
Speculative Execution Attacks
SameSite cookies
- evil.example has decide to try to pull off a speculative execution attack against your content. Loaded an iframe with your content. 😡
- SameSite cookie doesn’t get sent.
Server will know that 😆
data:image/s3,"s3://crabby-images/cd73b/cd73ba67a3fd9a52a77d6cc1e30794a152bbaeb9" alt=""
Speculative Execution Attacks
Cross-Origin-Resource-Policy, Cross-Origin Window Policy
- evil.example could wait until your user loses focus of that page of yours and then use the handle to navigate it to a fraud page that looks like your page and asks the user to please log in again. 😡
- Use Cross-Origin Window Policy.
There will be no handler for the attacker page to navigate your window with 😆
data:image/s3,"s3://crabby-images/90676/906766585415e5fc5a4a064ad4ec5724b329c78e" alt=""
Window Control Attacks
- Malicious window navigation
data:image/s3,"s3://crabby-images/b12df/b12df8ddd5ff77ff4a725c407e126b3e770a769d" alt=""
- Defense: Cross-Origin-Window-Policy header
data:image/s3,"s3://crabby-images/502d2/502d258b4c2d14b16e26548318d58e652fd2523b" alt=""
Take Action
Baseline
- Use transport security ( https, wss)
- Mark cookies HttpOnly and Secure
- Migrate from UIWebView to WKWebView
- https://webkit.org/blog/
data:image/s3,"s3://crabby-images/f3184/f318470e3b31073f9137740e2e40e432212b3027" alt=""