Safe vs Unsafe jQuery Methods
We all know XSS is bad and we all use jQuery, unfortunately its API doc doesn't do a very good job explaining what jQuery methods are safe to use for unescaped input, and which are not.
Safe
.text()
-
.attr()
// still needs to be careful when used in anhref
.prop()
.val()
Unsafe
$("html code")
.html()
.append*()
.insert*()
.prepend*()
.wrap*()
.before()
.after()
Written by Jimmy Yuen Ho Wong
Related protips
4 Responses
data:image/s3,"s3://crabby-images/d49fb/d49fb5530eddcbd811468f41e71170e8eb664daf" alt=""
I wouldn't consider .attr as a safe method. Example: .attr('href', 'javascript:alert()')
over 1 year ago
·
data:image/s3,"s3://crabby-images/79564/795646d91c68c1c0f9f06b2b58cf203d22f38e55" alt=""
Good call!
over 1 year ago
·
data:image/s3,"s3://crabby-images/1cee2/1cee25161ccfacd4d1ef6d57b0272e5c52c86362" alt=""
Superb post, thank you for this!
over 1 year ago
·
data:image/s3,"s3://crabby-images/1cee2/1cee25161ccfacd4d1ef6d57b0272e5c52c86362" alt=""
Can you please show an example of the XSS safe DOM insertion. Would it be:
jQuery('<div/>', {
id: 'foo',
href: 'http://google.com',
title: 'Become a Googler',
rel: 'external',
text: 'Go to Google!'
}).appendTo('#mySelector');
?
Thank you
over 1 year ago
·
Have a fresh tip? Share with Coderwall community!
Post
Post a tip
Best
#Jquery
Authors
Sponsored by #native_company# — Learn More
#native_title#
#native_desc#