本帖最后由 20230713G001133 于 2024-7-13 15:32 编辑
现在有一个叫做(execute_command.php)的文件
[PHP] 纯文本查看 复制代码 <?php
header('Content-Type: text/html; charset=utf-8');
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$command = $_POST['command'];
$output = shell_exec($command);
$output = htmlspecialchars($output, ENT_QUOTES | ENT_SUBSTITUTE, 'UTF-8'); // 转义特殊字符并保持 UTF-8 编码
$output = nl2br($output); // 保持换行格式
echo $output;
} else {
echo "Error: Method not allowed";
}
?>
通过一个HTML发送Post请求(代码如下)
[HTML] 纯文本查看 复制代码 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>执行命令示例</title>
<style>
#output {
font-family: SimSun, '宋体', Arial, sans-serif; /* 设置字体为宋体,如果系统不支持宋体,则使用Arial或sans-serif作为备选字体 */
}
</style>
</head>
<body>
<button id="lsCommand">查看目录列表</button>
<button id="ipconfigCommand">查看IP配置</button>
<button id="hostnameCommand">查看主机名</button>
<button id="shutdown">关闭服务器</button>
<button id="restart">重启服务器</button>
<button id="tasklist">进程列表</button>
<div id="output"></div>
<style>
#output {
font-family: SimSun, '宋体', Arial, sans-serif; /* 设置字体为宋体,如果系统不支持宋体,则使用Arial或sans-serif作为备选字体 */
white-space: pre; /* 保留换行符和空格 */
overflow-x: auto; /* 显示水平滚动条 */
max-width: 100%; /* 限制最大宽度,防止内容过宽 */
padding: 10px; /* 添加一些内边距,使内容与边框有一定间距 */
border: 1px solid #ccc; /* 添加边框 */
}
</style>
<script>
// 点击按钮执行命令的函数
function executeCommand(command) {
var xhr = new XMLHttpRequest();
xhr.open('POST', 'execute_command.php', true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
xhr.onload = function() {
if (xhr.status === 200) {
document.getElementById('output').innerHTML = xhr.responseText;
} else {
document.getElementById('output').innerHTML = 'Error: ' + xhr.status;
}
};
xhr.send('command=' + encodeURIComponent(command));
}
// 给每个按钮添加点击事件处理
document.getElementById('lsCommand').addEventListener('click', function() {
executeCommand('dir'); // Windows下查看目录列表的命令是 dir
});
document.getElementById('ipconfigCommand').addEventListener('click', function() {
executeCommand('ipconfig'); // Windows下查看IP配置的命令是 ipconfig
});
document.getElementById('hostnameCommand').addEventListener('click', function() {
executeCommand('hostname'); // Windows下查看主机名的命令是 hostname
});
document.getElementById('shutdown').addEventListener('click', function() {
executeCommand('shutdown /s /t 0');
});
document.getElementById('restart').addEventListener('click', function() {
executeCommand('shutdown /r /t 0');
});
document.getElementById('tasklist').addEventListener('click', function() {
executeCommand('tasklist');
});
</script>
</body>
</html>
返回结果中文部分无法正常显示
这种情况可能是什么原因造成的
应该怎么解决
|