XSS on Google Search - Sanitizing HTML in The Client?

  Рет қаралды 694,122

LiveOverflow

LiveOverflow

Күн бұрын

Пікірлер: 588
@alexc8992
@alexc8992 5 жыл бұрын
I blame Tom Scott for this since he said that Google was fine in a video about XSS. He probably inspired people to try it.
@LiveOverflow
@LiveOverflow 5 жыл бұрын
Google is constantly changing, so errors can always pop-up. But that's also why Google invests a lot of money into bug-bounty, so researchers like Masato get paid for it ;)
@Thect
@Thect 5 жыл бұрын
blame Tom Scott
@nilsirl
@nilsirl 5 жыл бұрын
Can you give us a little bit of context? What did Tom Scott do?
@whydoineedausername1386
@whydoineedausername1386 5 жыл бұрын
He made a video explaining XSS (using an XSS bug in a twitter client as an example because it was recent at the time) and in it claimed that google is trustworthy as a company that is safe and wouldn't allow XSS. That inspired people to try and get XSS working on google
@fluent_styles6720
@fluent_styles6720 5 жыл бұрын
It was the self-retweeting tweet video, wasn't it?
@DustDaAnt
@DustDaAnt 5 жыл бұрын
Google: HEY HEY! STOP! Me: What? Google: 1
@karlkastor
@karlkastor 5 жыл бұрын
Unbelievable that Google had an XSS like that. Really interesting attack and great explanation, was really easy to understand. I hope Masato got a big bug bounty.
@abc321meins
@abc321meins 5 жыл бұрын
@M. de k. Don't you think thats way to little? He could have overtaken the internet and make Billions with this XSS in less than a day...
@abc321meins
@abc321meins 5 жыл бұрын
@M. de k. Hmm, yeah you're right I guess.
@abc321meins
@abc321meins 5 жыл бұрын
@M. de k. But to be honest, for 3000$ I'd have kept it a secret and used it to rickroll as manny people as possible. The faces of my coworkers would have been priceless.
@miguelricardosobong4927
@miguelricardosobong4927 5 жыл бұрын
@@abc321meins then you'd be persecuted and no money...
@trieulieuf9
@trieulieuf9 5 жыл бұрын
M. de k. Hi, i am curious, who does he get the bounty? Google see his tweet and verify it is a bug then give him money? Or he needs to report it to google?
@NicholasFagan
@NicholasFagan 5 жыл бұрын
Amazing vulnerability! Loosely parsing html always seems silly to me. If browsers started being strict about displaying html, people would start being strict when writing it.
@mirradric
@mirradric 5 жыл бұрын
Sadly xhtml died a sad death
@WoolieOG
@WoolieOG 5 жыл бұрын
or just give option to websites to opt-out from corrections, and make browser render html 1:1.
@omri9325
@omri9325 5 жыл бұрын
That's kind of a feedback loop, browser vendors do not want their browsers to stop working on a lot of site unexpectedly.
@rogercruz1547
@rogercruz1547 5 жыл бұрын
@@omri9325 Maybe we can write some extensions/plugins for major browsers that parse everything as xhtml...
@nobody7557
@nobody7557 5 жыл бұрын
I got goosebumps when the alert(1) opened.
@termviewerthelost75
@termviewerthelost75 5 жыл бұрын
Cedric Brandt
@YitocukKilic
@YitocukKilic 5 жыл бұрын
1
@Pinkkprincess1
@Pinkkprincess1 5 жыл бұрын
Alert: (1) [OK]
@Generatrix
@Generatrix 5 жыл бұрын
@@pseudoforceyt AaaaaAAAAAAAA
@muhdsafie805
@muhdsafie805 4 жыл бұрын
@@termviewerthelost75 nmn n m n m n m
@_DeProgrammer
@_DeProgrammer 5 жыл бұрын
I think this is honestly, one of the best channels on KZbin. The time you put in to explain and share what you learn with us is GOLDEN! thanks dude. I'll support.
@domaincontroller
@domaincontroller 4 жыл бұрын
00:52 basics XSS 05:10 mutation XSS 05:35 Client-side sanitization, DOMPurifiy 07:47 masato, noscript element 10:38 DOM XSS
@mobile_ingou
@mobile_ingou 5 жыл бұрын
With the second example with the invalid code, the browser was correct. tags are CDATA, meaning that the contents will never be interpreted as HTML. It also means they cannot be self closing. It is not because of parsers. With both examples, the browser is not being "weird". It is following the W3C spec, which states that scripts are CDATA, and that browsers must auto-close tags. BTW, great video!!!
@mtssvnsn
@mtssvnsn 5 жыл бұрын
So, in conclusion: 1.) Sanitizing should be done on the client, because its hard to do on the the server. 2.) Woops!
@renakunisaki
@renakunisaki 5 жыл бұрын
3) The noscript tag is parsed differently depending on context.
@JochemKuijpers
@JochemKuijpers 5 жыл бұрын
4) replacing all with their appropriate html entities before DOM insertion would have fixed this.
@otesunki
@otesunki 5 жыл бұрын
5) ok lets filter & and " but not < or > .
@unarei
@unarei 5 жыл бұрын
@@JochemKuijpers or adding textnodes instead of using innerhtml in the first place. there was probably some reason they needed a limited set of tags though.
@NetheriteMiner
@NetheriteMiner 5 жыл бұрын
wouldn't filtering < do everything? I'm new at XSS please help
@문동선-j7d
@문동선-j7d 5 жыл бұрын
When you literally hacked Google and everyone else thinks it's just an April fool's joke. Achievement unlocked: Hacking Google.
@alandosman5002
@alandosman5002 5 жыл бұрын
문동선 you can’t hack websites with XSS
@문동선-j7d
@문동선-j7d 5 жыл бұрын
@@alandosman5002 yet you know you're hacking it when you find an exploit like that
@cyborggoat2467
@cyborggoat2467 5 жыл бұрын
@@문동선-j7d its an exploit, more of a bug or easter egg of sorts, not hacking
@MrGrazyD96
@MrGrazyD96 5 жыл бұрын
@@cyborggoat2467 what do you think is hacking then?
@cyborggoat2467
@cyborggoat2467 5 жыл бұрын
@@MrGrazyD96 literally getting into their servers, being able to see what they see, break it if you so chose
@oldbootz
@oldbootz 5 жыл бұрын
This is brilliant, and the vid goes so deep and thorough on the topic. You really are the best security channel on YT.
@devttyUSB0
@devttyUSB0 5 жыл бұрын
I always use regular expressions to parse HTML! :P
@twistedsim
@twistedsim 5 жыл бұрын
😂🤣
@karlkastor
@karlkastor 5 жыл бұрын
I actually do that a lot for webscrapers. It is faster than an actual XML/HTML parser and it doesn't make much of a difference when it doesn't have to be hundred percent accurate. Although, if one of my download tool gets outside input, I should abstain from these methods, because someone could inject something. Although the worst case scenario in that case is that wrong data gets downloaded.
@tvili999
@tvili999 5 жыл бұрын
I think they are using it too. Most language parsers somehow use regex. 😁 BTW I think regex is one of the perfect examples on how amazing things were created in the old days, when they had no clue how important it will be, and they cared to do these algorithms the best possible way.
@alphatier4919
@alphatier4919 5 жыл бұрын
"Regex" and "parse" in 1 sentence... My hearth stopped beating.....
@WolfrostWasTaken
@WolfrostWasTaken 5 жыл бұрын
Evil RegEx input is coming at you muahahahaahah
@dominiksulzer1338
@dominiksulzer1338 5 жыл бұрын
Thankfully there is a javascript framework for everything :D
@DarkOverFlowOverflow
@DarkOverFlowOverflow 5 жыл бұрын
Keep making websecurity videos keep up the good work
@Zooiest
@Zooiest 5 жыл бұрын
He’s not the copypaste machine, he’s the one who makes the exploits Reference to your older video 🙃
@LiveOverflow
@LiveOverflow 5 жыл бұрын
Masato is a browser bug machine!!!
@Zooiest
@Zooiest 5 жыл бұрын
LiveOverflow thanks for the heart and reply :3
@Dakta96
@Dakta96 5 жыл бұрын
Copypasting is also boring just create something to do it for you if you really want to
@poincareless105
@poincareless105 3 жыл бұрын
Every time i watch your videos i keep another mind as a spare, to replace the blown mind. thank you
@kartoffelwaffel
@kartoffelwaffel 5 жыл бұрын
holy f that debugger tip at 10:26 blew my mind! thanks!
@thatLukeKneller
@thatLukeKneller 5 жыл бұрын
I've worked in javascript for too many years and not known that... god damn
@bensaputra1567
@bensaputra1567 5 жыл бұрын
Same here :D lol
@skysunset877
@skysunset877 9 ай бұрын
I Love It! Your explanation is intuitive and easy. It is very helpful for studying!
@codechapter6960
@codechapter6960 5 жыл бұрын
WOW i had to pause the video to actually understand something for the first time. VIDEO IS SO GOOOOOOOOOOD!!!
@PurplProto
@PurplProto 5 жыл бұрын
LiveOverflow: "Google search is arguably the front page of the internet" Reddit: *sad noises*
@madghostek3026
@madghostek3026 5 жыл бұрын
Now this is scary how many sites use the template parser, which appears to be vulnerable
@10F2C
@10F2C 2 жыл бұрын
attacker's dream
@blackAngel88it
@blackAngel88it 5 жыл бұрын
2:53 neither html, head or body are required elements for valid html. in a minimalistic webpage, only the title element is required. Also, we're kinda talking here about code embedded into an already existing site, so the validity only comes down to "broken" tags and non escaped characters () inside an attribute.
@MaxRoaldEckardt
@MaxRoaldEckardt 4 жыл бұрын
You race to the top of my favorite youtubers with videos like these...
@Nick_Tag
@Nick_Tag 5 жыл бұрын
This video blows my mind in how it archives what happened - as it was happening!
@developermaroc9988
@developermaroc9988 5 жыл бұрын
What I like the most is that all videos are free to download offline on KZbin, thank you
@strayedaway19
@strayedaway19 4 жыл бұрын
I did not understand a thing but I went along as watching you debug and hack is beautiful and enlightening.
@machinexa1
@machinexa1 4 жыл бұрын
Did you guys notice at 0:05, when @LiveOverflow puts quote it says "I put ' it gives bug" (a video by Liveoverflow, easter egg)
@adityyyaaa
@adityyyaaa 4 жыл бұрын
Actually 🤔
@threeMetreJim
@threeMetreJim 5 жыл бұрын
New Facebook games may be an opportunity to hunt down bugs similar to this, they are quite often hurried through, especially the ones by smaller teams of programmers. I got one before, managed to insert html to play a KZbin video offscreen (for the sound effects). It actually got a laugh out of the programmers of the game before they fixed the issue - there were a ton of other bugs too, that I helped get removed before the game was attacked by someone else. No reward money though, but earned some kudos, none-the-less.
@Ikxi
@Ikxi 5 жыл бұрын
I don't understand anything but it's still sooooo interesting xD Gutes Video
@shantanurauthan9318
@shantanurauthan9318 5 жыл бұрын
masato did a great job..and you too by explaining the stuff behind the attack.
@gydo1942
@gydo1942 5 жыл бұрын
wow. that's crazy! Thanks for explaining man and keep up the good work!
@cr9pr3
@cr9pr3 5 жыл бұрын
having paused the video at 2:50 What the browser _should_ do, is saying: "Malformed document. Aborting execution." :P
@karlkastor
@karlkastor 5 жыл бұрын
If they do that a lot of websites won't work. Just run any HTML validator on almost any website and you will get dozens of errors. One of the pains of these web architectures is that they should be backwards compatible and cross-browser.
@Madinko12
@Madinko12 5 жыл бұрын
@@karlkastor yeah, that's why versioning was invented at some point. Just put some "strict" flag, tell non-strict is deprecated and support will be dropped by browsers starting from 2030, don't add new features in permissive mode, and you just improved the web by 999%.
@cr9pr3
@cr9pr3 5 жыл бұрын
​@@karlkastor Yes I know. That's why I made the half-ironic :P at the end. I know browser vendors won't do it, because ultimately their product will be the one "that does not work", but in my opinion the idea of accepting a word that isn't in the formal language you are parsing is absolutely insane. I mean we _say_ we use this particular language (html) but in practice every vendor implements a client for a MUCH broader language that isn't even close to the original one. And this behavior isn't even a bug but absolutely intentional. I just don't like it :D
@Asdayasman
@Asdayasman 5 жыл бұрын
Karl Kastor Haha, nah. Fuck them.
@-morrow
@-morrow 5 жыл бұрын
It depends on the what makes the html invalid. e.g. ignoring some mandatory attributes (img alt) may be fine, but guessing/closing tags is just plain evil imho.
@youtubekackejr.3817
@youtubekackejr.3817 5 жыл бұрын
i was looking at memes how i am here?
@Jcraft153
@Jcraft153 5 жыл бұрын
Stay a while, this dude does some cool stuff.
@NoName-gs9mb
@NoName-gs9mb 5 жыл бұрын
@@Jcraft153 Is he German, because he sounds so.
@useodyseeorbitchute9450
@useodyseeorbitchute9450 5 жыл бұрын
He must be using some unknown exploit in youtube recommend algorithm. ;)
@hblaub
@hblaub 5 жыл бұрын
Thanks for keeping the Internet safe and us informed and entertained.
@TheSweMaster
@TheSweMaster 5 жыл бұрын
Anyone else who had their Google assistant Google JavaScript for you at 12:23 ?!
@Mark_1991_1
@Mark_1991_1 5 жыл бұрын
Amazing. I said it because i don't know no more words =)
@IOwnThisHandle
@IOwnThisHandle 5 жыл бұрын
You clearly don't know English either. No -> know
@prashanthchandrasekar1026
@prashanthchandrasekar1026 2 жыл бұрын
I thought this was impossible in google search. But this is amazing!!!
@theohallenius8882
@theohallenius8882 5 жыл бұрын
HTML has reached a critical mass of bloat that there will always be a XSS vulnerability discovered every year.
@renakunisaki
@renakunisaki 5 жыл бұрын
Yeah, it's a real fustercluck. I think there are other tags that parse differently, such as xmp.
@omri9325
@omri9325 5 жыл бұрын
Feature toggles are there to fix it in the future, you will be able to remove the old browser features that you don't use to prevent potential vulnerabilities.
@ExEBoss
@ExEBoss 5 жыл бұрын
At this point, I wish that XML5 would be worked on: github.com/whatwg/html/issues/4436 That would solve a lot of these problems.
@mattf.2142
@mattf.2142 5 жыл бұрын
I think it's been on the OWASP top 10 for years. All of the bugs I've found through hackerone, or what have you have been XSS vulnerbilities. Some found within 30 minutes. More like there will be a few XSS vulns discovered every day. (perhaps not on Google, though).
@theohallenius8882
@theohallenius8882 5 жыл бұрын
@@tf2excession I know, some Intel cpus even have a "god mode" instruction that can execute any instruction, and it wasn't even in the manual, it was probably there for debug purposes and they forgot to remove it.
@krzysztof-ws9og
@krzysztof-ws9og 5 жыл бұрын
Is there any benefit of fixing invalid html code? I cannot find any. I think that pages should be blocked by browser.
@luizzeroxis
@luizzeroxis 5 жыл бұрын
It's less annoying when you just wanna make a quick and dirty page. I don't even use the html, head, and body tags, they don't really have a purpose.
@TheLolilol321
@TheLolilol321 5 жыл бұрын
We need a "use strict" for html
@semanticsyntax
@semanticsyntax 5 жыл бұрын
@@luizzeroxis Yeah but quick and dirty pages mean the browser has to guess what you actually meant, and introduces these security issues. Why should your convenience come at the cost of others security? Obviously this isn't just targeted at you, half the web probable contains invalid HTML etc., but if people actually took the time to check their code was well formed then browsers wouldn't have to 'guess', removing an entire class of security exploit.
@amunak_
@amunak_ 5 жыл бұрын
Backwards compatibility. However there should definitely be a mechanism to disable this behaviour, just like we have CORS headers.
@phasm42
@phasm42 5 жыл бұрын
@@amunak_ The saying used to be, "Be conservative in what you send, be liberal in what you accept". But experience has shown that this leniency in what you accept results in bad data getting incorporated into future versions and standards. It sets up an incentive to make an effort to parse bad data so you're not the program that can't display site X. Over time, it gets rolled into standards.
@gabiold
@gabiold 5 жыл бұрын
Browsers should phase-out HTML correction. If a website requires inserting HTML tags, it should inform the user with some yellow bars at the top like the "prevented to open a window" message. There should be a config option to this like "notify", "ask", "reject", making the notify the default now, then after a year or two, making the "ask" the default, which should be as hard to click through as an invalid TLS cert. window. Really, pages without matching open/close tags and with syntactically bad javascripts are a major thing, errors should really be show up to the users, which will motivate companies to fix their annoying websites, then after a time it should not be allowed to work like nothing happened. No need to be as strict as certain required attribute missing or something semantically wrong trigger it, but if the structural syntax is broken, missing closing tag, closing braket, closing quote or so happens, it should not be rendered to the user at all.
@LuLeBe
@LuLeBe 2 жыл бұрын
Nah it will just make users angry at the browser. They don't understand this and they don't have to. Opening up some old forums page from 2005 (which is way more likely to have these issues than sites that are actually still maintained well enough to fix it) is no hazard (unless you download stuff) and yet you wanna show the users all kinds of warnings? Worst idea I've ever heard. On the web, "breaking" stuff is a bad idea. Even just making https the default with warnings for http sites was a major discussion, and that's much less obtrusive than what you propose.
@RoterFruchtZwerg
@RoterFruchtZwerg 5 жыл бұрын
I think there is also a problem with the browser reassembling the innerHTML property at 8:35 ... In the DOM view, the is clearly interpreted as attribute-text. However, when reassembled to innerHTML, the attribute-text is not encoded properly. While the DOM contains valid HTML, the reassembled innerHTML does not. I really think the browser should have encoded the attribute-text based on its interpretation of it as text, thus replacing with &lt;/&gt; within innerHTML and returning a valid HTML.
@LuLeBe
@LuLeBe 2 жыл бұрын
The browser never automatically escapes HTML entities. If it would, that could break all kinds of sites. Changing behaviour in Browsers is hard, sometimes they have to change the spec instead of fixing a bug xD
@RoterFruchtZwerg
@RoterFruchtZwerg 2 жыл бұрын
@@LuLeBe That's not true. If you set innerText or an attribute (setAttribute) of a DOM element and then somehow ask the browser to the HTML code of this element, the values you've set MUST be properly encoded. I'm pretty surprised however that only quotes get encoded: var tag = document.createElement('b'); tag.setAttribute('attr',''); console.log(tag.outerHTML); //
@xBZZZZyt
@xBZZZZyt 2 жыл бұрын
05:30 just parse html with parser library and escape attribute contents and texts and add closing tags and remove comments (do the fixing server-side) like:
@bahai02
@bahai02 4 жыл бұрын
Oh my god! This was really amazing
@roskelpletnick9660
@roskelpletnick9660 5 жыл бұрын
Wait... I can get the point of needing styles in HTML emails, there one would need to have some HTML tags. But why did they not just escape any and all unsafe characters in the search bar - you know, replace "
@LiEnby
@LiEnby 5 жыл бұрын
Was thinking the same Google search doesn't let you do custom styling anywhere lol
@IOwnThisHandle
@IOwnThisHandle 5 жыл бұрын
Just ...
@xBZZZZyt
@xBZZZZyt 3 жыл бұрын
agree
@xBZZZZyt
@xBZZZZyt 3 жыл бұрын
just why??????
@PAhmad99
@PAhmad99 5 жыл бұрын
Idk how I got here... Idk what's going on. I feel incredibly stupid.
@jayant9151
@jayant9151 5 жыл бұрын
Programmers
@realcartoongirl
@realcartoongirl 5 жыл бұрын
no
@PAhmad99
@PAhmad99 5 жыл бұрын
@@realcartoongirl thx, that explains everything
@hassankumail1053
@hassankumail1053 5 жыл бұрын
same bro same
@MaheshSingh-de1ix
@MaheshSingh-de1ix 4 жыл бұрын
That is one historical mutated XSS example that will live on....
@avileox6304
@avileox6304 5 жыл бұрын
Thank for such a great explanation. Keep Posting
@IOwnThisHandle
@IOwnThisHandle 5 жыл бұрын
He would regardless of your comment.
@LegacyVision.
@LegacyVision. 5 жыл бұрын
This is a newly exploitable bug due to fixes for IE that were coded incorrectly, so it was never always possible, just a recent change that has been reverted.
@JochemKuijpers
@JochemKuijpers 5 жыл бұрын
Recent change? IE hasn't been updated for years. That bug fix was pretty old too.
@LegacyVision.
@LegacyVision. 5 жыл бұрын
@@JochemKuijpers incorrect, it was badly coded compatibility fixes made to address rendering for Nintendo switch. It was about 5months in prod before rollback. Edit: my bad english on first comment, I meant Googles js had fixes to address IE compatibility 5/6months ago.
@concernedcitizen3254
@concernedcitizen3254 5 жыл бұрын
Am I right in saying search engines are in an unusual position in that they are meant to allow for users to search for code online, therefore must accept the characters. Many sites could just block these inputs.
@KINGSABRI
@KINGSABRI 5 жыл бұрын
wonderful explanation and great catch
@soneomeelse
@soneomeelse 5 жыл бұрын
@7:16 It can't be a good sanitizer when there is image object in its template, no matter how good it's on attributes filtering. Strings are to be treated as strings.
@scaslx
@scaslx 5 жыл бұрын
Your video blows my mind
@4.0.4
@4.0.4 5 жыл бұрын
On the one hand, I like that bugs like this exist, it warms my heart to see the extent of human ingenuity. On the other, I wonder how much could be fixed by something like , where anything semi-valid is proactively rejected.
@atharvparlikar8765
@atharvparlikar8765 4 жыл бұрын
just test
@brod515
@brod515 5 жыл бұрын
3:36 I don't know much of anything about html or web But why is the browser trying to fix invalid HTML. If I put an incorrect account number to my bank, my bank doesn't try to fix it and say "did you mean this"
@MarineFocus
@MarineFocus 5 жыл бұрын
Not a very good developer myself, but it works on a "better than nothing" principle. Tons of tags in a HTML document so it's pretty easy to trip up and make mistakes. Imagine missing a single tag somewhere in a big company's website and having the browser display nothing (or garbage) because of the error? Thus browsers try to compensate for human mistakes, which happens all the time.
@vladomaimun
@vladomaimun 5 жыл бұрын
Browsers should only parse strict and correct HTML.
@LiEnby
@LiEnby 5 жыл бұрын
That would break the internet
@UltraNyan
@UltraNyan 5 жыл бұрын
@@LiEnby where are the days of XHTML, those sitty hipster kids with their shitty HTML5 and fancy CSS3
@IOwnThisHandle
@IOwnThisHandle 5 жыл бұрын
In a perfect world.
@LiEnby
@LiEnby 5 жыл бұрын
@@UltraNyan what we would like and what we can acturally do are completely different things..
@kidbomb
@kidbomb 5 жыл бұрын
We should at least have the option of only parsing correct HTML. I wouldn't mind having an experimental flag in my browser for it which I could turn on whenever I see fit.
@fusseldieb
@fusseldieb 5 жыл бұрын
One day I'll open a LiveOverflow video and suddenly a alert will pop up. One day some random user will make it.
@probably9085
@probably9085 5 жыл бұрын
I will remember your words
@boahneelassmal
@boahneelassmal 5 жыл бұрын
search encrypt as an interesting approach to sanitizing their search requests.... it just takes out any < and > :D
@dnns1896
@dnns1896 5 жыл бұрын
So maybe I missunderstood something, but why is it possible to enter HTML inside the Google Search bar that gets interpreted somehow? Is there any valid reason? From a Search Engine I expect, that everything that is entered in the search field gets "interpreted" as Text I am searching for. And the example with Webmailers shows me, that we definitely need a different Standard for those types of Input, that is not HTML. Something like Markdown or so. But not HTML that can cause Problems in Browsers.
@dnns1896
@dnns1896 5 жыл бұрын
@Michael Murphy But why the heck is google still trying to do so? That doesn't make any sense to me. Because from how I understood that, by default the text inside a input field is not interpreted anyway.
@yusufislek3669
@yusufislek3669 5 жыл бұрын
0:05 *flackback* i try put ' it gives bug
@danielchin1259
@danielchin1259 5 жыл бұрын
This blows my mind
@WoolieOG
@WoolieOG 5 жыл бұрын
Browsers should add support to new optional header, which would fully disable any DOM corrections - for companies like google it only produces problems.
@Napert
@Napert 5 жыл бұрын
Why not use xhtml so if something breaks you don't get anything at all?
@Revelation-X
@Revelation-X 10 күн бұрын
Is it possible to bypass sanitation where EVERY special character is encoded like > is &gt; I have a Django website I created for the purpose of practicing xss, and every quote or greater than or equal to sign gets converted into encoded url making it hard to put any successful xss
@ignitor9941
@ignitor9941 5 жыл бұрын
this is sick man !
@MrSnakeHome
@MrSnakeHome 5 жыл бұрын
ist Security Flag GmbH deine eigene Firma? aber cooles Video :D und habe ein Abo da gelassen!
@MrSnakeHome
@MrSnakeHome 5 жыл бұрын
interessantes Video! wenn deine Gedanken wo anders sind! XD
@winstonlopez6117
@winstonlopez6117 3 жыл бұрын
Im pretty new to all this but from what can follow. The writes the script in a way that the paser fixs rewrites the script. Now the wbsite thinks its okay put it just help script to work and take over .
@klyplays
@klyplays 5 жыл бұрын
How come the biggest tech companies still get these kind of errors?
@JohnRunyon
@JohnRunyon 5 жыл бұрын
The parsing of the div inside the script is bizarre to me. The closing script tag is inside a string literal, but it's still seen as a closing script tag?!
@Squire3555
@Squire3555 5 жыл бұрын
What blows my mind is the bounty he'll probably get on this. XSS in Google's home page is a no-no. Browsers are kind of those weird machines. So much going on.
@fracasopina2121
@fracasopina2121 5 жыл бұрын
Lol, you're on the money.
@biabianca6190
@biabianca6190 5 жыл бұрын
Xss
@RoterFruchtZwerg
@RoterFruchtZwerg 5 жыл бұрын
That's indeed mindblowing, thank you for sharing this with us :) But what I don't get is, why is google using this sanitizer at all in this case? I'm not aware that the search input requires partial parsing, it should be shown as plain text everywhere and this should be simple to escape... Where is this needed?
@renakunisaki
@renakunisaki 5 жыл бұрын
That's what it's trying to do, display user input as plain text. Unfortunately it wants to then add styles to that text, which complicates things...
@mohamedhassanqeyru852
@mohamedhassanqeyru852 4 жыл бұрын
Qeyruu maxamad xasan cabdi@com
@mohamedhassanqeyru852
@mohamedhassanqeyru852 4 жыл бұрын
@@renakunisaki yutob+com00252615196122
@mohamedhassanqeyru852
@mohamedhassanqeyru852 4 жыл бұрын
@@renakunisaki qeyruu maxamad xasan cabdi@com
@kesuskim6072
@kesuskim6072 5 жыл бұрын
dude... seriously... this is sick lol fabulous insight
@xBZZZZyt
@xBZZZZyt 4 жыл бұрын
Why did Google do sanitizing for search field that just wants plain text (not any html tags)?
@thebosscrystal
@thebosscrystal 5 жыл бұрын
Can this be used for malicious stuff?
@petermarshall1634
@petermarshall1634 5 жыл бұрын
Just escape the quotes and "greater than"/"less than" tags. Google doesn't need to parse HTML anyways.
@xBZZZZyt
@xBZZZZyt 3 жыл бұрын
agree
@lucaspelegrino1
@lucaspelegrino1 3 жыл бұрын
Yeah, it really doesnt make sense to even handle html at that point. But the vulnerability was only possible on the querystring tho, if I understood correctly, there must be a reason for accepting html there.
@lordtylus9262
@lordtylus9262 5 жыл бұрын
Hello, thank you for the very informative video, it was well explained, but I havent quite grasp the point about the XSS problem in that case. I see that you basically alter the HTML of the server to get some JavaScript executed. But as long as you dont get googles servers to execute that it should be relatively harmless right? You could even use like ctrl+shift+i in google Chrome to get your browers debugging and can change any HTML attribute add Scripts and what not which would get to the same result. As you have shown in the video. I am aware that if you happen to be able get your scripts embedded into the youtube comment section by just posting it there it will be executed by the clients of every user that watches the comments. So this indeed is a huge problem. But what exactly do you gain by executing java script on your client in your googles search bar? Because there is only you who would see it. Sending someone a link similar to what you got at the start of the video is of course an option, but so would any other link of a site you have control over. with a similar looking URL also its not quite seamless as you had to click into the search bar to get it executed. could you or someone else please explain it to me?
@zanidd
@zanidd 5 жыл бұрын
interesting exploit, it shows that even big companies can suffer from these things
@renakunisaki
@renakunisaki 5 жыл бұрын
A few years ago KZbin had an issue where if you just put two script tags in a row (I think?) one could slip through. Lots of sites also just do a single pass stripping bad tags, which fails when given [scr[script butts]ipt ...]
@Dragiux
@Dragiux 5 жыл бұрын
A lot of these issues come from browsers not being strict in parsing HTML, at some points even modifying it to make it "work". "use strict" for html, when?
@kenji2787
@kenji2787 2 жыл бұрын
So the DOMPurify would be used after processing the request on the backend and upon loading the response back to the client right?
@kenji2787
@kenji2787 2 жыл бұрын
Also, do you think it’s enough to forgo sanitizing in the backend?
@Junhexeocara
@Junhexeocara 5 жыл бұрын
i always use markdown to style text inputed by user
@brend8c
@brend8c 4 жыл бұрын
@LiveOverflow what is the best way to protect the message form from xss?
@nikhilkamble4210
@nikhilkamble4210 5 жыл бұрын
Very helpful 👍
@jonmayer
@jonmayer 5 жыл бұрын
Was the commit part of some attempt to hack the Nintendo switch and needed to add some small vulnerability to pull it off?
@mpeppelman
@mpeppelman 5 жыл бұрын
I think that's unlikely. Unless a high level part of the switch such as the main menu functions like a browser and runs javascript, there is no reason to do it that way. Using this attack on lower level should just leave it sandboxed off, and things that aren't sand boxed off usually restrict user input, so the chance you could actualy input the code for the XSS is basically 0. And that is all assuming that Nintendo uses the google javascript library in the first place.
@fatlineoppp2002
@fatlineoppp2002 5 жыл бұрын
I have a question, if u find xss using that way right, how can u make a POC about that, can u make that so it will show up in the url?
@davyrogersuk
@davyrogersuk 5 жыл бұрын
This is great!
@rianhasiando
@rianhasiando 5 жыл бұрын
But, can i just do htmlspecialchars() to prevent it ??
@shihabsoft
@shihabsoft 5 жыл бұрын
Man oh man. I've been trying to hunt bugs for so many days on Google. Found some but never a massive ones such as this, RCE or sqli. Well I've been through the injections in search bar but couldn't successfully inject any malicious payload. I gotta say, it's not just how talented you're in this field. But luck plays a major role in finding vulnerabilities too.
@Rossilaz58
@Rossilaz58 4 жыл бұрын
"Google search is arguably the front page of the Internet" *reddit ceo is angry*
@TEXASF1ERCE
@TEXASF1ERCE 5 жыл бұрын
How long did it take him to find this? I'm asking because I'm new to web app hacking and I don't know when to stop probing a certain parameter and end up burning myself out :/
@stefouy
@stefouy 5 жыл бұрын
Surely a noob question but how can you edit html files and see the result imediatly through your browser dev tools ? I know it's possible to edit html but doing it with dev tools does not look like that. Or this is a simple editor but what do you use so that the page reload imediatly ?
@ees4.
@ees4. Жыл бұрын
There is an extension for VS Code to do this. (I forgot the name)
@XYNOMS
@XYNOMS 5 жыл бұрын
@LiveOverflow, Very convincing ;)
@M1stersupersonic8
@M1stersupersonic8 5 жыл бұрын
"Google is arguably the front page of the internet" Reddit would to have a word with you.
@tormenmashi_
@tormenmashi_ 5 жыл бұрын
PFFT
@berthold64
@berthold64 5 жыл бұрын
epic upbboated xD edit: thanks for the gold sir
@alevfalse7963
@alevfalse7963 5 жыл бұрын
r/ihavereddit
@martint1775
@martint1775 5 жыл бұрын
Isn't there like a big bounty on exploiting Google? Did he get any money?
@shobhitchittora2267
@shobhitchittora2267 5 жыл бұрын
This can easily be prevented by sending appropriate values in the Content-Security-Policy Header in your responses. Don't know why google is not setting the header. Any idea why ?
@LiveOverflow
@LiveOverflow 5 жыл бұрын
Correct. But CSP turns out to be almost impossible to implement for huge applications like google.
@shobhitchittora2267
@shobhitchittora2267 5 жыл бұрын
@@LiveOverflow Can you give an example ? I guess if you whitelist the domains you want and disable everything else, it should work fine.
@laurinneff4304
@laurinneff4304 5 жыл бұрын
I‘ve just found a XSS bug in my dad‘s website: He‘s a photographer and has an image archive on his website. This archive has a search feature where you just need to enter something like alert(1) to run JS
@asianpuppy2080
@asianpuppy2080 5 жыл бұрын
if it is a small website its not a big issue considering its only a reflected xss, try finding a stored xss on his site
@MattZelda
@MattZelda 5 жыл бұрын
Can confirm that this also works on Firefox version: 66.0.2 (64-bit)
@powershellaxp64
@powershellaxp64 4 жыл бұрын
0:05 I put ' it gives bug
@JohnRunyon
@JohnRunyon 5 жыл бұрын
So, in other words, the bug is in the browser (or spec), not Google. Why the hell is the noscript block sometimes parsed as text and sometimes as DOM? Oh, and we need a way to tell the browser that a given chunk of text/DOM is user-supplied and untrusted and reduce to a "safe" set of elements and attributes.
@AbdelrahmanRashed
@AbdelrahmanRashed 5 жыл бұрын
why do we still have XSS Vulnerabilities in 2019 ?
@fmattia99
@fmattia99 5 жыл бұрын
Because HTML is bloated, XSS is one of the vulnerabilities that still happens because of a reason, SQL Injections for example are easy to avoid, and they happen only when programmers knows nothing about security, but until we will replace HTML with something less bloated and maybe a little bit more strict, we will have XSS
@renakunisaki
@renakunisaki 5 жыл бұрын
Because the web is a huge pile of spaghetti and legacy cruft that's become so bloated and complex that it's impossible to do correctly.
@Drqonic
@Drqonic 5 жыл бұрын
Curious to know why they aren't using htmlspecialchars or entities :|
How did Masato find the Google Search XSS?
10:04
LiveOverflow
Рет қаралды 162 М.
Generic HTML Sanitizer Bypass Investigation
14:05
LiveOverflow
Рет қаралды 142 М.
Cheerleader Transformation That Left Everyone Speechless! #shorts
00:27
Fabiosa Best Lifehacks
Рет қаралды 16 МЛН
Что-что Мурсдей говорит? 💭 #симбочка #симба #мурсдей
00:19
You don't need a frontend framework
15:45
Andrew Schmelyun
Рет қаралды 138 М.
Cracking Websites with Cross Site Scripting - Computerphile
8:34
Computerphile
Рет қаралды 1,5 МЛН
Script Gadgets! Google Docs XSS Vulnerability Walkthrough
18:57
LiveOverflow
Рет қаралды 143 М.
Fuzzing Browsers for weird XSS Vectors
9:16
LiveOverflow
Рет қаралды 69 М.
I legally defaced this website.
25:48
thehackerish
Рет қаралды 532 М.
DO NOT USE alert(1) for XSS
12:16
LiveOverflow
Рет қаралды 166 М.
The Perfect Dependency - SQLite Case Study
19:32
Tom Delalande
Рет қаралды 86 М.
Fast Inverse Square Root - A Quake III Algorithm
20:08
Nemean
Рет қаралды 5 МЛН
Good vs. Bad Security Tweets
17:43
LiveOverflow
Рет қаралды 175 М.
If __name__ == "__main__" for Python Developers
8:47
Python Simplified
Рет қаралды 420 М.