前端安全防护指南(三)反射型XSS

什么是反射型XSS

  • 恶意脚本通过URL参数等方式传递给服务器,服务器将其嵌入响应页面并返回给用户,脚本在用户浏览器中执行。
  • 通常通过诱骗用户点击恶意链接实现。

反射型XSS示例

  • 场景:一个搜索功能将用户输入的内容直接显示在页面上。
  • 攻击原理:攻击者构造一个包含恶意脚本的URL,诱骗用户点击。
  • 示例
javascript 复制代码
 假设网页代码如下:
 
 <p>搜索结果:<?php echo $_GET['query']; ?></p>
 攻击者构造以下URL:
 http://example.com/search?query=<script>alert('XSS')</script>
 当用户点击该链接时,服务器返回的页面会直接执行脚本:
 <p>搜索结果:<script>alert('XSS')</script></p>
 用户的浏览器会弹出一个警告框,表明脚本已执行。
  • 代码示例
python 复制代码
from flask import Flask, request
from html import escape

app = Flask(__name__)

# ======================
# 漏洞示例(反射型XSS)
# ======================
@app.route('/vulnerable')
def vulnerable_search():
    # 直接获取用户输入(未做任何过滤)
    user_input = request.args.get('query', '')
    
    # 将用户输入直接拼接到HTML中(存在XSS漏洞)
    return f'''
    <!DOCTYPE html>
    <html>
    <head>
        <title>搜索功能演示</title>
    </head>
    <body>
        <h1>搜索功能(存在漏洞)</h1>
        <form method="GET">
            <input type="text" name="query" placeholder="输入搜索内容">
            <button type="submit">搜索</button>
        </form>
        <p>搜索结果:{user_input}</p>
    </body>
    </html>
    '''

# ======================
# 防御示例(输入转义)
# ======================
@app.route('/safe')
def safe_search():
    # 获取用户输入并进行HTML转义
    user_input = request.args.get('query', '')
    safe_input = escape(user_input)  # 关键防御步骤
    
    return f'''
    <!DOCTYPE html>
    <html>
    <head>
        <title>安全搜索功能</title>
    </head>
    <body>
        <h1>搜索功能(已修复)</h1>
        <form method="GET">
            <input type="text" name="query" placeholder="输入搜索内容">
            <button type="submit">搜索</button>
        </form>
        <p>搜索结果:{safe_input}</p>
    </body>
    </html>
    '''

if __name__ == '__main__':
    app.run(debug=True)
  • 代码运行示例说明
html 复制代码
反射型XSS示例

运行程序:python app.py

访问:http://localhost:5000/vulnerable?query=<script>alert('XSS')</script>
或使用更可靠的payload:http://localhost:5000/vulnerable?query=<img+src=x+onerror=alert('XSS')>

特别注意:python版本:3.13.2
特别声明:上述仅是反射型XSS的简单示例,禁止任何人利用示例用来违反法律。

相关推荐
xkxnq17 小时前
第一阶段:Vue 基础入门(第 15天)
前端·javascript·vue.js
anyup18 小时前
2026第一站:分享我在高德大赛现场学到的技术、产品与心得
前端·架构·harmonyos
BBBBBAAAAAi18 小时前
Claude Code安装记录
开发语言·前端·javascript
xiaolyuh12318 小时前
【XXL-JOB】 GLUE模式 底层实现原理
java·开发语言·前端·python·xxl-job
源码获取_wx:Fegn089518 小时前
基于 vue智慧养老院系统
开发语言·前端·javascript·vue.js·spring boot·后端·课程设计
毕设十刻18 小时前
基于Vue的人事管理系统67zzz(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
anyup18 小时前
从赛场到产品:分享我在高德大赛现场学到的技术、产品与心得
前端·harmonyos·产品
前端工作日常19 小时前
我学习到的A2UI的功能:纯粹的UI生成
前端
Jing_Rainbow19 小时前
【 前端三剑客-37 /Lesson61(2025-12-09)】JavaScript 内存机制与执行原理详解🧠
前端·javascript·程序员
dalerkd19 小时前
忙里偷闲叙-谈谈最近两年
网络·安全·web安全