c# - 如何将 Javascript Unicode 解码为 C# 字符串

标签 c# javascript jquery security encoding

例如,我们在谷歌自动搜索中获得的 JSON 回调:

window.google.td && window.google.td('tljp1322487273527014', 4,{e:"HY7TTtmRFZPe8QPCvf30Dw",c:1,u:"http://www.google.co.uk/s?hl\x3den\x26cp\x3d5\x26gs_id\x3d17\x26xhr\x3dt\x26q\x3dowasp\x26pf\x3dp\x26sclient\x3dpsy-ab\x26source\x3dhp\x26pbx\x3d1\x26oq\x3d\x26aq\x3d\x26aqi\x3d\x26aql\x3d\x26gs_sm\x3d\x26gs_upl\x3d\x26bav\x3don.2,or.r_gc.r_pw.,cf.osb\x26fp\x3dbd20912ccdf288ab\x26biw\x3d387\x26bih\x3d362\x26tch\x3d4\x26ech\x3d15\x26psi\x3d5o3TTqCqCsnD0QXA7sUI.1322487273527.1\x26wrapid\x3dtljp1322487273527014",d:"[\x22owasp\x22,[[\x22owasp\x22,0,\x220\x22],[\x22owasp\\u003Cb\\u003E top 10\\u003C\\/b\\u003E\x22,0,\x221\x22],[\x22owasp\\u003Cb\\u003E top 10 2011\\u003C\\/b\\u003E\x22,0,\x222\x22],[\x22owasp\\u003Cb\\u003E zap\\u003C\\/b\\u003E\x22,0,\x223\x22]],{\x22j\x22:\x2217\x22}]"});window.google.td && window.google.td('tljp1322487273527014', 4,{e:"HY7TTtmRFZPe8QPCvf30Dw",c:0,u:"http://www.google.co.uk/s?hl\x3den\x26cp\x3d5\x26gs_id\x3d17\x26xhr\x3dt\x26q\x3dowasp\x26pf\x3dp\x26sclient\x3dpsy-ab\x26source\x3dhp\x26pbx\x3d1\x26oq\x3d\x26aq\x3d\x26aqi\x3d\x26aql\x3d\x26gs_sm\x3d\x26gs_upl\x3d\x26bav\x3don.2,or.r_gc.r_pw.,cf.osb\x26fp\x3dbd20912ccdf288ab\x26biw\x3d387\x26bih\x3d362\x26tch\x3d4\x26ech\x3d15\x26psi\x3d5o3TTqCqCsnD0QXA7sUI.1322487273527.1\x26wrapid\x3dtljp1322487273527014",d:""});

更具体地说,如何从:

"\x22te\\u003Cb\\u003Esco\\u003C\\/b\\u003E\x22,0,\x220\x22"

"te\u003Cb\u003Esco\u003C\/b\u003E",0,"0"

"te<b>sco</b>"

请注意,System.Web UrlDecode 和 HtmlDecode 无法处理此问题。

有趣的是,AntiXss 几乎相反,因为它可以从:

"te<b>sco</b>"

te\00003Cb\00003Esco\00003C\00002Fb\00003E

安全 Angular

这些解码具有许多安全隐患,因为它们将由浏览器呈现。例如,如果在 Javascript/jQuery 中我们有一个带有有效载荷的变量

var xss = "te\u003Cscript\u003Ealert\u002812\u0029\u003C\u002Fscript\u003E"

如果分配给 div 的 html 将被触发

$("#header").html(xss)

最佳答案

\x....

WTF?\u - 没关系。 根据之前的回答:

string str = @"P\u003e\u003cp\u003e Notes \u003cstrong\u003e Разработчик: \u003c/STRONG\u003e \u003cbr /\u003eЕсли игра Безразлично";
Regex regex = new Regex(@"\\u([0-9a-z]{4})",RegexOptions.IgnoreCase);
str = regex.Replace(str, match => char.ConvertFromUtf32(Int32.Parse(match.Groups[1].Value , System.Globalization.NumberStyles.HexNumber)));

关于c# - 如何将 Javascript Unicode 解码为 C# 字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8296916/

相关文章:

c# - 如何将 EmailMessage 备用 View 转换为 SendGrid Html 和文本

与 HTML 相关的 Javascript/JQuery 脚本放置

javascript - 修复了一个可以根据平台引导您访问不同网站的图标

Jquery 验证不能正确验证数字?

C# 单例日志记录类

c# - 调用在docker中运行的不安全的GRPC服务

c# - "Items collection cannot be modified when the DataSource property is set."

javascript - jqgrid userData 在刷新时发布 null

javascript - 修改后无法搜索多选

javascript - 如何为js变量设置最小和最大边界?