来自dotnet安全矩阵星球一位师傅的个人笔记分享
.\NetWrapper.exe --keypath MachineKeys.txt --encrypteddata /wEPDwULLTE3NDQyMTk3OTUP
ZBYCZg9kFgICBQ8PFgIeBFRleHQFKeaJgOWhq+WGmeeahOmqjOivgeeggeS4juaJgOe7meeahOS4jeespiA
hZGQYAQUeX19Db250cm9sc1JlcXVpcmVQb3N0QmFja0tleV9fFgEFCGJ0bkxvZ2luRPqLQJ5A3TNa2Gdwy4
fC8ADPABjAUPZYA47oIldiSAI= --decrypt --purpose=viewstate --modifier=6811C9FF --macd
ecode --TargetPagePath "/Login.aspx" -f out.txt --IISDirPath="/"
--encrypteddata : __VIEWSTATE parameter value of the target application
--modifier : __VIWESTATEGENERATOR parameter value
.\NetWrapper.exe --keypath MachineKeys.txt --encrypteddata /wEPDwULLTE3NDQyMTk3OTUP
ZBYCZg9kFgICBQ8PFgIeBFRleHQFKeaJgOWhq+WGmeeahOmqjOivgeeggeS4juaJgOe7meeahOS4jeespiA
hZGQYAQUeX19Db250cm9sc1JlcXVpcmVQb3N0QmFja0tleV9fFgEFCGJ0bkxvZ2luRPqLQJ5A3TNa2Gdwy4
fC8ADPABjAUPZYA47oIldiSAI= --decrypt --purpose=viewstate -IISDirPath "/" --TargetPa
gePath "/Login.aspx"
--encrypteddata = {__VIEWSTATE parameter value}
--IISDirPath = {Directory path of website in IIS}
--TargetPagePath = {Target page path in application}
.\NetWrapper.exe --keypath MachineKeys.txt --encrypteddata /wEWBgKPrdzZBgLB2tiHDgLK
w6LdBQLChPzDDQKC3IeGDAKgt7D9Cmf6HV/8G+WwyoHfYHa9F9tclYAi+mZrwiLkcG1v2rxR --purpose=
viewstate --modifier=C2EE9ABB --macdecode
.\NetWrapper.exe --keypath MachineKeys.txt --encrypteddata /wEPDwULLTE3NDQyMTk3OTUP
ZBYCZg9kFgICBQ8PFgIeBFRleHQFKeaJgOWhq+WGmeeahOmqjOivgeeggeS4juaJgOe7meeahOS4jeespiA
hZGQYAQUeX19Db250cm9sc1JlcXVpcmVQb3N0QmFja0tleV9fFgEFCGJ0bkxvZ2luRPqLQJ5A3TNa2Gdwy4
fC8ADPABjAUPZYA47oIldiSAI= --decrypt --purpose=viewstate --IISDirPath "/" --Target
PagePath "/Login.aspx"
.\NetWrapper.exe --keypath MachineKeys.txt --encrypteddata /wEPDwUJLTI1MjczMDMxD2QW
AmYPZBYCAgcPZBYCAgEPZBYCAgsPZBYCZg9kFgYCBQ8PFgIeBFRleHQFD+mHjeWei+aRqeaJmOi7imRkAgk
PDxYCHwAFBk1BMDEyM2RkAhcPEA8WBB4NRGF0YVRleHRGaWVsZAULdHlwZU5hbWVDSFQeC18hRGF0YUJvdW
5kZ2QQFQIe5r6z6ZaA54m55Yil6KGM5pS/5Y2A6Lqr5Lu96K2JBuWFtuS7lhUCATEBMxQrAwJnZ2RkZCpnq
O+9hCcyBZ+7Sr7vFOvX8PRG --decrypt --purpose=viewstate --IISDirPath "/" --modifier=
C2EE9ABB --TargetPagePath "/Login.aspx"
ViewState机制是asp.net中对同一个Page的多次请求中 维持Page及控件状态的一种机制 ASP.NET 的ViewState是使用Base64的字符串保存在一个隐藏域中的在WebForm中每次请求完,Page对象都会被释放,这里就有一个问题就是我客户端请求一个 page但是多次请求,怎么维护我和page对象之间的状态以及一些信息?-----viewstate机制
ViewState的设计目的就是为了将必要的信息持-久化在页面中,这样通过ViewState在页面回传 的过程中保存状态值。
Cookie是存在于http请求中的,而ViewState仅仅存在于.net 。Cookie不存在后端解析(只需要取值即可)
而.net中的ViewState存在于后端解析(序列 化和反序列化的操作) Cookie是为了http无状态而产生的,ViewState是为了保存WebForm中服务端控件状态进 行持久化而产生的。
ViewState = serialize(我们控制传输的数据)+0xff+0x01+0x32+... client_id = hash(当前请求路径)+hash(当前请求文件名) MacKeyModifier = client_id + ViewStateUserKey(默认为空) signed_data = new HMACSHA256(web.config里面的密钥).encode(ViewState+MacKeyModifie r); __VIEWSTATE = ViewState + signed_data
为了更好地应对基于.NET技术栈的风险识别和未知威胁,dotNet安全矩阵星球从创建以来一直聚焦于.NET领域的安全攻防技术,定位于高质量安全攻防星球社区,也得到了许多师傅们的支持和信任,通过星球深度连接入圈的师傅们,一起推动.NET安全高质量的向前发展。经过运营团队成员商议一致同意给到师傅们最大优惠力度,只需199元就可以加入我们。
星球汇聚了各行业安全攻防技术大咖,并且每日分享.NET安全技术干货以及交流解答各类技术等问题,社区中发布很多高质量的.NET安全资源,可以说市面上很少见,都是干货。其中主题包括.NET Tricks、漏洞分析、内存马、代码审计、预编译、反序列化、webshell免杀、命令执行、C#工具库等等,后续还会倾力打造专刊、视频等配套学习资源,循序渐进的方式引导加深安全攻防技术提高以及岗位内推等等服务。