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.
@LiveOverflow5 жыл бұрын
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 ;)
@Thect5 жыл бұрын
blame Tom Scott
@nilsirl5 жыл бұрын
Can you give us a little bit of context? What did Tom Scott do?
@whydoineedausername13865 жыл бұрын
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_styles67205 жыл бұрын
It was the self-retweeting tweet video, wasn't it?
@DustDaAnt5 жыл бұрын
Google: HEY HEY! STOP! Me: What? Google: 1
@karlkastor5 жыл бұрын
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.
@abc321meins5 жыл бұрын
@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...
@abc321meins5 жыл бұрын
@M. de k. Hmm, yeah you're right I guess.
@abc321meins5 жыл бұрын
@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.
@miguelricardosobong49275 жыл бұрын
@@abc321meins then you'd be persecuted and no money...
@trieulieuf95 жыл бұрын
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?
@NicholasFagan5 жыл бұрын
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.
@mirradric5 жыл бұрын
Sadly xhtml died a sad death
@WoolieOG5 жыл бұрын
or just give option to websites to opt-out from corrections, and make browser render html 1:1.
@omri93255 жыл бұрын
That's kind of a feedback loop, browser vendors do not want their browsers to stop working on a lot of site unexpectedly.
@rogercruz15475 жыл бұрын
@@omri9325 Maybe we can write some extensions/plugins for major browsers that parse everything as xhtml...
@nobody75575 жыл бұрын
I got goosebumps when the alert(1) opened.
@termviewerthelost755 жыл бұрын
Cedric Brandt
@YitocukKilic5 жыл бұрын
1
@Pinkkprincess15 жыл бұрын
Alert: (1) [OK]
@Generatrix5 жыл бұрын
@@pseudoforceyt AaaaaAAAAAAAA
@muhdsafie8054 жыл бұрын
@@termviewerthelost75 nmn n m n m n m
@_DeProgrammer5 жыл бұрын
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.
@domaincontroller4 жыл бұрын
00:52 basics XSS 05:10 mutation XSS 05:35 Client-side sanitization, DOMPurifiy 07:47 masato, noscript element 10:38 DOM XSS
@mobile_ingou5 жыл бұрын
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!!!
@mtssvnsn5 жыл бұрын
So, in conclusion: 1.) Sanitizing should be done on the client, because its hard to do on the the server. 2.) Woops!
@renakunisaki5 жыл бұрын
3) The noscript tag is parsed differently depending on context.
@JochemKuijpers5 жыл бұрын
4) replacing all with their appropriate html entities before DOM insertion would have fixed this.
@otesunki5 жыл бұрын
5) ok lets filter & and " but not < or > .
@unarei5 жыл бұрын
@@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.
@NetheriteMiner5 жыл бұрын
wouldn't filtering < do everything? I'm new at XSS please help
@문동선-j7d5 жыл бұрын
When you literally hacked Google and everyone else thinks it's just an April fool's joke. Achievement unlocked: Hacking Google.
@alandosman50025 жыл бұрын
문동선 you can’t hack websites with XSS
@문동선-j7d5 жыл бұрын
@@alandosman5002 yet you know you're hacking it when you find an exploit like that
@cyborggoat24675 жыл бұрын
@@문동선-j7d its an exploit, more of a bug or easter egg of sorts, not hacking
@MrGrazyD965 жыл бұрын
@@cyborggoat2467 what do you think is hacking then?
@cyborggoat24675 жыл бұрын
@@MrGrazyD96 literally getting into their servers, being able to see what they see, break it if you so chose
@oldbootz5 жыл бұрын
This is brilliant, and the vid goes so deep and thorough on the topic. You really are the best security channel on YT.
@devttyUSB05 жыл бұрын
I always use regular expressions to parse HTML! :P
@twistedsim5 жыл бұрын
😂🤣
@karlkastor5 жыл бұрын
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.
@tvili9995 жыл бұрын
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.
@alphatier49195 жыл бұрын
"Regex" and "parse" in 1 sentence... My hearth stopped beating.....
@WolfrostWasTaken5 жыл бұрын
Evil RegEx input is coming at you muahahahaahah
@dominiksulzer13385 жыл бұрын
Thankfully there is a javascript framework for everything :D
@DarkOverFlowOverflow5 жыл бұрын
Keep making websecurity videos keep up the good work
@Zooiest5 жыл бұрын
He’s not the copypaste machine, he’s the one who makes the exploits Reference to your older video 🙃
@LiveOverflow5 жыл бұрын
Masato is a browser bug machine!!!
@Zooiest5 жыл бұрын
LiveOverflow thanks for the heart and reply :3
@Dakta965 жыл бұрын
Copypasting is also boring just create something to do it for you if you really want to
@poincareless1053 жыл бұрын
Every time i watch your videos i keep another mind as a spare, to replace the blown mind. thank you
@kartoffelwaffel5 жыл бұрын
holy f that debugger tip at 10:26 blew my mind! thanks!
@thatLukeKneller5 жыл бұрын
I've worked in javascript for too many years and not known that... god damn
@bensaputra15675 жыл бұрын
Same here :D lol
@skysunset8779 ай бұрын
I Love It! Your explanation is intuitive and easy. It is very helpful for studying!
@codechapter69605 жыл бұрын
WOW i had to pause the video to actually understand something for the first time. VIDEO IS SO GOOOOOOOOOOD!!!
@PurplProto5 жыл бұрын
LiveOverflow: "Google search is arguably the front page of the internet" Reddit: *sad noises*
@madghostek30265 жыл бұрын
Now this is scary how many sites use the template parser, which appears to be vulnerable
@10F2C2 жыл бұрын
attacker's dream
@blackAngel88it5 жыл бұрын
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.
@MaxRoaldEckardt4 жыл бұрын
You race to the top of my favorite youtubers with videos like these...
@Nick_Tag5 жыл бұрын
This video blows my mind in how it archives what happened - as it was happening!
@developermaroc99885 жыл бұрын
What I like the most is that all videos are free to download offline on KZbin, thank you
@strayedaway194 жыл бұрын
I did not understand a thing but I went along as watching you debug and hack is beautiful and enlightening.
@machinexa14 жыл бұрын
Did you guys notice at 0:05, when @LiveOverflow puts quote it says "I put ' it gives bug" (a video by Liveoverflow, easter egg)
@adityyyaaa4 жыл бұрын
Actually 🤔
@threeMetreJim5 жыл бұрын
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.
@Ikxi5 жыл бұрын
I don't understand anything but it's still sooooo interesting xD Gutes Video
@shantanurauthan93185 жыл бұрын
masato did a great job..and you too by explaining the stuff behind the attack.
@gydo19425 жыл бұрын
wow. that's crazy! Thanks for explaining man and keep up the good work!
@cr9pr35 жыл бұрын
having paused the video at 2:50 What the browser _should_ do, is saying: "Malformed document. Aborting execution." :P
@karlkastor5 жыл бұрын
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.
@Madinko125 жыл бұрын
@@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%.
@cr9pr35 жыл бұрын
@@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
@Asdayasman5 жыл бұрын
Karl Kastor Haha, nah. Fuck them.
@-morrow5 жыл бұрын
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.38175 жыл бұрын
i was looking at memes how i am here?
@Jcraft1535 жыл бұрын
Stay a while, this dude does some cool stuff.
@NoName-gs9mb5 жыл бұрын
@@Jcraft153 Is he German, because he sounds so.
@useodyseeorbitchute94505 жыл бұрын
He must be using some unknown exploit in youtube recommend algorithm. ;)
@hblaub5 жыл бұрын
Thanks for keeping the Internet safe and us informed and entertained.
@TheSweMaster5 жыл бұрын
Anyone else who had their Google assistant Google JavaScript for you at 12:23 ?!
@Mark_1991_15 жыл бұрын
Amazing. I said it because i don't know no more words =)
@IOwnThisHandle5 жыл бұрын
You clearly don't know English either. No -> know
@prashanthchandrasekar10262 жыл бұрын
I thought this was impossible in google search. But this is amazing!!!
@theohallenius88825 жыл бұрын
HTML has reached a critical mass of bloat that there will always be a XSS vulnerability discovered every year.
@renakunisaki5 жыл бұрын
Yeah, it's a real fustercluck. I think there are other tags that parse differently, such as xmp.
@omri93255 жыл бұрын
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.
@ExEBoss5 жыл бұрын
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.21425 жыл бұрын
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).
@theohallenius88825 жыл бұрын
@@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-ws9og5 жыл бұрын
Is there any benefit of fixing invalid html code? I cannot find any. I think that pages should be blocked by browser.
@luizzeroxis5 жыл бұрын
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.
@TheLolilol3215 жыл бұрын
We need a "use strict" for html
@semanticsyntax5 жыл бұрын
@@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_5 жыл бұрын
Backwards compatibility. However there should definitely be a mechanism to disable this behaviour, just like we have CORS headers.
@phasm425 жыл бұрын
@@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.
@gabiold5 жыл бұрын
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.
@LuLeBe2 жыл бұрын
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.
@RoterFruchtZwerg5 жыл бұрын
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 </> within innerHTML and returning a valid HTML.
@LuLeBe2 жыл бұрын
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
@RoterFruchtZwerg2 жыл бұрын
@@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); //
@xBZZZZyt2 жыл бұрын
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:
@bahai024 жыл бұрын
Oh my god! This was really amazing
@roskelpletnick96605 жыл бұрын
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 "
@LiEnby5 жыл бұрын
Was thinking the same Google search doesn't let you do custom styling anywhere lol
@IOwnThisHandle5 жыл бұрын
Just ...
@xBZZZZyt3 жыл бұрын
agree
@xBZZZZyt3 жыл бұрын
just why??????
@PAhmad995 жыл бұрын
Idk how I got here... Idk what's going on. I feel incredibly stupid.
@jayant91515 жыл бұрын
Programmers
@realcartoongirl5 жыл бұрын
no
@PAhmad995 жыл бұрын
@@realcartoongirl thx, that explains everything
@hassankumail10535 жыл бұрын
same bro same
@MaheshSingh-de1ix4 жыл бұрын
That is one historical mutated XSS example that will live on....
@avileox63045 жыл бұрын
Thank for such a great explanation. Keep Posting
@IOwnThisHandle5 жыл бұрын
He would regardless of your comment.
@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.
@JochemKuijpers5 жыл бұрын
Recent change? IE hasn't been updated for years. That bug fix was pretty old too.
@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.
@concernedcitizen32545 жыл бұрын
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.
@KINGSABRI5 жыл бұрын
wonderful explanation and great catch
@soneomeelse5 жыл бұрын
@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.
@scaslx5 жыл бұрын
Your video blows my mind
@4.0.45 жыл бұрын
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.
@atharvparlikar87654 жыл бұрын
just test
@brod5155 жыл бұрын
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"
@MarineFocus5 жыл бұрын
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.
@vladomaimun5 жыл бұрын
Browsers should only parse strict and correct HTML.
@LiEnby5 жыл бұрын
That would break the internet
@UltraNyan5 жыл бұрын
@@LiEnby where are the days of XHTML, those sitty hipster kids with their shitty HTML5 and fancy CSS3
@IOwnThisHandle5 жыл бұрын
In a perfect world.
@LiEnby5 жыл бұрын
@@UltraNyan what we would like and what we can acturally do are completely different things..
@kidbomb5 жыл бұрын
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.
@fusseldieb5 жыл бұрын
One day I'll open a LiveOverflow video and suddenly a alert will pop up. One day some random user will make it.
@probably90855 жыл бұрын
I will remember your words
@boahneelassmal5 жыл бұрын
search encrypt as an interesting approach to sanitizing their search requests.... it just takes out any < and > :D
@dnns18965 жыл бұрын
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.
@dnns18965 жыл бұрын
@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.
@yusufislek36695 жыл бұрын
0:05 *flackback* i try put ' it gives bug
@danielchin12595 жыл бұрын
This blows my mind
@WoolieOG5 жыл бұрын
Browsers should add support to new optional header, which would fully disable any DOM corrections - for companies like google it only produces problems.
@Napert5 жыл бұрын
Why not use xhtml so if something breaks you don't get anything at all?
@Revelation-X10 күн бұрын
Is it possible to bypass sanitation where EVERY special character is encoded like > is > 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
@ignitor99415 жыл бұрын
this is sick man !
@MrSnakeHome5 жыл бұрын
ist Security Flag GmbH deine eigene Firma? aber cooles Video :D und habe ein Abo da gelassen!
@MrSnakeHome5 жыл бұрын
interessantes Video! wenn deine Gedanken wo anders sind! XD
@winstonlopez61173 жыл бұрын
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 .
@klyplays5 жыл бұрын
How come the biggest tech companies still get these kind of errors?
@JohnRunyon5 жыл бұрын
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?!
@Squire35555 жыл бұрын
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.
@fracasopina21215 жыл бұрын
Lol, you're on the money.
@biabianca61905 жыл бұрын
Xss
@RoterFruchtZwerg5 жыл бұрын
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?
@renakunisaki5 жыл бұрын
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...
@mohamedhassanqeyru8524 жыл бұрын
Qeyruu maxamad xasan cabdi@com
@mohamedhassanqeyru8524 жыл бұрын
@@renakunisaki yutob+com00252615196122
@mohamedhassanqeyru8524 жыл бұрын
@@renakunisaki qeyruu maxamad xasan cabdi@com
@kesuskim60725 жыл бұрын
dude... seriously... this is sick lol fabulous insight
@xBZZZZyt4 жыл бұрын
Why did Google do sanitizing for search field that just wants plain text (not any html tags)?
@thebosscrystal5 жыл бұрын
Can this be used for malicious stuff?
@petermarshall16345 жыл бұрын
Just escape the quotes and "greater than"/"less than" tags. Google doesn't need to parse HTML anyways.
@xBZZZZyt3 жыл бұрын
agree
@lucaspelegrino13 жыл бұрын
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.
@lordtylus92625 жыл бұрын
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?
@zanidd5 жыл бұрын
interesting exploit, it shows that even big companies can suffer from these things
@renakunisaki5 жыл бұрын
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 ...]
@Dragiux5 жыл бұрын
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?
@kenji27872 жыл бұрын
So the DOMPurify would be used after processing the request on the backend and upon loading the response back to the client right?
@kenji27872 жыл бұрын
Also, do you think it’s enough to forgo sanitizing in the backend?
@Junhexeocara5 жыл бұрын
i always use markdown to style text inputed by user
@brend8c4 жыл бұрын
@LiveOverflow what is the best way to protect the message form from xss?
@nikhilkamble42105 жыл бұрын
Very helpful 👍
@jonmayer5 жыл бұрын
Was the commit part of some attempt to hack the Nintendo switch and needed to add some small vulnerability to pull it off?
@mpeppelman5 жыл бұрын
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.
@fatlineoppp20025 жыл бұрын
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?
@davyrogersuk5 жыл бұрын
This is great!
@rianhasiando5 жыл бұрын
But, can i just do htmlspecialchars() to prevent it ??
@shihabsoft5 жыл бұрын
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.
@Rossilaz584 жыл бұрын
"Google search is arguably the front page of the Internet" *reddit ceo is angry*
@TEXASF1ERCE5 жыл бұрын
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 :/
@stefouy5 жыл бұрын
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. Жыл бұрын
There is an extension for VS Code to do this. (I forgot the name)
@XYNOMS5 жыл бұрын
@LiveOverflow, Very convincing ;)
@M1stersupersonic85 жыл бұрын
"Google is arguably the front page of the internet" Reddit would to have a word with you.
@tormenmashi_5 жыл бұрын
PFFT
@berthold645 жыл бұрын
epic upbboated xD edit: thanks for the gold sir
@alevfalse79635 жыл бұрын
r/ihavereddit
@martint17755 жыл бұрын
Isn't there like a big bounty on exploiting Google? Did he get any money?
@shobhitchittora22675 жыл бұрын
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 ?
@LiveOverflow5 жыл бұрын
Correct. But CSP turns out to be almost impossible to implement for huge applications like google.
@shobhitchittora22675 жыл бұрын
@@LiveOverflow Can you give an example ? I guess if you whitelist the domains you want and disable everything else, it should work fine.
@laurinneff43045 жыл бұрын
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
@asianpuppy20805 жыл бұрын
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
@MattZelda5 жыл бұрын
Can confirm that this also works on Firefox version: 66.0.2 (64-bit)
@powershellaxp644 жыл бұрын
0:05 I put ' it gives bug
@JohnRunyon5 жыл бұрын
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.
@AbdelrahmanRashed5 жыл бұрын
why do we still have XSS Vulnerabilities in 2019 ?
@fmattia995 жыл бұрын
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
@renakunisaki5 жыл бұрын
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.
@Drqonic5 жыл бұрын
Curious to know why they aren't using htmlspecialchars or entities :|