密碼加密方式:
* md5(自設密碼+$ace) //$ace為cdn鏡像地址
使用方法:
* 1.確認 $pwd 變數值為 false, 上傳本檔案到PHP空間並訪問
* 2.第一次訪問提示設定密碼,設定密碼並牢記
* 3.使用第一次設定的密碼登入後,預設編輯的是本php檔案,
* 4.本檔案是編輯器核心檔案,請不要隨意修改
* 5.儲存編輯的檔案請用 Ctrl + S 按鍵組合,等待執行結果
* 6.儲存動作執行後請務必等待儲存成功資訊返回
* 7.重設操作會修改本程式的檔案名稱,以防他人猜測路徑
* 8.重新整理功能僅是重新整理本程式檔案,不能重新整理其他
建議在 chrome 瀏覽器中使用本編輯器
複製代碼 代碼如下:
<?php
session_start();
$curr_file = __FILE__; //預設編輯當前檔案
$curr_file_path = str_replace(dirname(__FILE__), '', __FILE__);
$pwd = "57574d98bc6ebe77b07e59d87065cd9e"; //密碼初始化預設值為 false
$ace = 'ace.js'; //編輯器核心js
$tip['core'] = 'alertify.core.min.css';
$tip['css'] = 'alertify.default.min.css';
$tip['js'] = 'alertify.min.js';
$jquery = 'jquery.min.js';
if ( false !== $pwd ) {
define('DEFAULT_PWD', $pwd);
}
//檔案尾碼名對應的文法解析器
$lng = array(
'as' => 'actionscript', 'js' => 'javascript',
'php' => 'php', 'css' => 'css', 'html' => 'html',
'htm' => 'html', 'ini' => 'ini', 'json' => 'json',
'jsp' => 'jsp', 'txt' => 'text', 'sql' => 'mysql',
'xml' => 'xml', 'yaml' => 'yaml', 'py' => 'python',
'md' => 'markdown', 'htaccess' => 'apache_conf',
'bat' => 'batchfile', 'go' => 'golang',
);
//判斷使用者是否登入
function is_logged() {
$flag = false;
if ( isset($_SESSION['pwd']) && defined('DEFAULT_PWD') ) {
if ( $_SESSION['pwd'] === DEFAULT_PWD ) {
$flag = true;
}
}
return $flag;
}
//重新載入到本頁面
function reload() {
$file = pathinfo(__FILE__, PATHINFO_BASENAME);
die(header("Location: {$file}"));
}
//判斷請求是否是ajax請求
function is_ajax() {
$flag = false;
if ( isset($_SERVER['HTTP_X_REQUESTED_WITH']) ) {
$flag = strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) === 'xmlhttprequest';
}
return $flag;
}
//銷毀SESSION和COOKIE
function exterminate() {
$_SESSION = array();
foreach ( $_COOKIE as $key ) {
setcookie($key, null);
}
session_destroy();
$_COOKIE = array();
return true;
}
//擷取一個目錄下的檔案清單
function list_dir($path, $type = 'array') {
$flag = false;
$lst = array('dir'=>array(), 'file'=>array());
$base = !is_dir($path) ? dirname($path) : $path;
$tmp = scandir($base);
foreach ( $tmp as $k=>$v ) {
//過濾掉上級目錄,本級目錄和程式自身檔案名稱
if ( !in_array($v, array('.', '..')) ) {
$file = $full_path = rtrim($base, '/').DIRECTORY_SEPARATOR.$v;
if ( $full_path == __FILE__ ) {
continue; //屏蔽自身檔案不在列表出現
}
$file = str_replace(dirname(__FILE__), '', $file);
$file = str_replace("\\", '/', $file); //過濾win下的路徑
$file = str_replace('//', '/', $file); //過濾雙斜杠
if ( is_dir($full_path) ) {
if ( 'html' === $type ) {
$v = '
'.$v.'';
}
array_push($lst['dir'], $v);
} else {
if ( 'html' === $type ) {
$v = '
'.$v.'';
}
array_push($lst['file'], $v);
}
}
}
$lst = array_merge($lst['dir'], $lst['file']);
$lst = array_filter($lst);
$flag = $lst;
if ( 'html' === $type ) {
$flag = '
';
}
return $flag;
}
//遞迴刪除一個非空目錄
function deldir($dir) {
$dh = opendir($dir);
while ( $file = readdir($dh) ) {
if ( $file != '.' && $file != '..' ) {
$fullpath = $dir.'/'.$file;
if ( !is_dir($fullpath) ) {
unlink($fullpath);
} else {
deldir($fullpath);
}
}
}
return rmdir($dir);
}
//退出登入
if ( isset($_GET['logout']) ) {
if ( exterminate() ) {
reload();
}
}
//ajax輸出檔案內容
if ( is_logged() && is_ajax() && isset($_POST['file']) ) {
$file = dirname(__FILE__).$_POST['file'];
$ext = pathinfo($file, PATHINFO_EXTENSION);
$mode = isset($lng[$ext]) ? $lng[$ext] : false;
die(json_encode(array(
'file' => $file, 'html' => file_get_contents($file),
'mode' => $mode,
)));
}
//ajax輸出目錄列表
if ( is_logged() && is_ajax() && isset($_POST['dir']) ) {
$dir = dirname(__FILE__).$_POST['dir'];
$list_dir = list_dir($dir, 'html');
die(json_encode(array(
'dir' => $dir, 'html' => $list_dir,
)));
}
//ajax儲存檔案
if ( is_logged() && is_ajax() && isset($_POST['action']) ) {
$arr = array('result'=>'error', 'msg'=>'檔案儲存失敗!');
$content = $_POST['content'];
if ( 'save_file' === $_POST['action'] ) {
if ( isset($_POST['file_path']) ) {
$file = dirname(__FILE__).$_POST['file_path'];
} else {
$file = __FILE__;
}
file_put_contents($file, $content);
$arr['result'] = 'success';
$arr['msg'] = '儲存成功!';
}
die(json_encode($arr));
}
//ajax刪除檔案或檔案夾
if ( is_logged() && is_ajax() && isset($_POST['del']) ) {
$path = dirname(__FILE__).$_POST['del'];
$arr = array('result'=>'error', 'msg'=>'刪除操作失敗!');
if ( $_POST['del'] && $path ) {
$flag = is_dir($path) ? deldir($path) : unlink($path);
if ( $flag ) {
$arr['msg'] = '刪除操作成功!';
$arr['result'] = 'success';
}
}
die(json_encode($arr));
}
//ajax建立檔案或檔案夾
if ( is_logged() && is_ajax() && isset($_POST['create']) ) {
$flag = false;
$arr = array('result'=>'error', 'msg'=>'操作失敗!');
if ( isset($_POST['target']) ) {
$target = dirname(__FILE__).$_POST['target'];
$target = is_dir($target) ? $target : dirname($target);
}
if ( $_POST['create'] && $target ) {
$base_name = pathinfo($_POST['create'], PATHINFO_BASENAME);
$exp = explode('.', $base_name);
$full_path = $target.'/'.$base_name;
$new_path = str_replace(dirname(__FILE__), '', $full_path);
if ( count($exp) > 1 && isset($lng[array_pop($exp)]) ) {
file_put_contents($full_path, '');
$arr['result'] = 'success';
$arr['msg'] = '建立檔案成功!';
$arr['type'] = 'file';
} else {
mkdir($full_path, 0777, true);
$arr['result'] = 'success';
$arr['msg'] = '建立目錄成功!';
$arr['type'] = 'dir';
}
if ( $base_name && $new_path ) {
$arr['new_name'] = $base_name;
$arr['new_path'] = $new_path;
}
}
die(json_encode($arr));
}
//ajax重新命名檔案或檔案夾
if ( is_logged() && is_ajax() && isset($_POST['rename']) ) {
$arr = array('result'=>'error', 'msg'=>'重新命名操作失敗!');
if ( isset($_POST['target']) ) {
$target = dirname(__FILE__).$_POST['target'];
}
if ( $_POST['rename'] ) {
$base_name = pathinfo($_POST['rename'], PATHINFO_BASENAME);
if ( $base_name ) {
$rename = dirname($target).'/'.$base_name;
$new_path = str_replace(dirname(__FILE__), '', $rename);
}
}
if ( $rename && $target && rename($target, $rename) ) {
$arr['new_name'] = $base_name;
$arr['new_path'] = $new_path;
$arr['msg'] = '重新命名操作成功!';
$arr['result'] = 'success';
}
if ( $target == __FILE__ ) {
$arr['redirect'] = $new_path;
}
die(json_encode($arr));
}
//擷取代碼檔案內容
$code = file_get_contents($curr_file);
$tree = '
- ROOT'.list_dir($curr_file, 'html').'
';
//登陸和設定密碼共用模版
$first = <<
【標題】
HTMLSTR;
//判斷是否第一次登入
if ( false === $pwd && empty($_POST) ) {
die(str_replace(
array('【標題】', '【動作】'),
array('第一次使用,請先設定密碼!', '設定'),
$first
));
}
//第一次設定登入密碼
if ( false === $pwd && !empty($_POST) ) {
if ( isset($_POST['pwd']) && strlen($_POST['pwd']) ) {
$pwd = $_SESSION['pwd'] = md5($_POST['pwd'].$ace);
$code = preg_replace('#\$pwd = false;#', '$pwd = "'.$pwd.'";', $code, 1);
file_put_contents($curr_file, $code);
} else {
reload();
}
}
//使用者登入驗證
if ( false !== $pwd && !empty($_POST) ) {
$tmp = md5($_POST['pwd'].$ace);
if ( $tmp && $pwd && $tmp === $pwd ) {
$_SESSION['pwd'] = $pwd;
reload();
}
}
//處理一下html實體
$code = htmlspecialchars($code);
$dir_icon = str_replace(array("\r\n", "\r", "\n"), '',
'data:image/jpg;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAANCAYAAACgu+4kAAAAGXRFWHRTb2Z0d2
FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQVJREFUeNqkkk1uwjAQhd84bsNP1FUXLCtu0H3XPSoX4Qrd9wR
sCjQEcIY3DiiJUYiqRhp5Mra/92YSUVVgLSW49B7H+NApRh75XkHfFoCG+02tyflUeQTw2y9UYYP8cCStc9SM
PeVA/Sy6Dw555q3au1z+EhBYk1cgO7OSNdaFNT0x5sCkYDha0WPiHZgVqPzLO+8seai6E2jed42bCL06tNyEH
AX9kv3jh3HqH7BctFWLMOmAbcg05mHK5+sQpd1HYijN47zcDUCShGEHtzxtwQS9WTcAQmJROrJDLXQB9s1Tu6
MtRED4bwsHLnUzxEeKac3+GeP6eo8yevhjC3F1qC4CDAAl3HwuyNAIdwAAAABJRU5ErkJggg==');
$file_icon = str_replace(array("\r\n", "\r", "\n"), '',
'data:image/jpg;base64,iVBORw0KGgoAAAANSUhEUgAAAA8AAAAQCAYAAADJViUEAAAAGXRFWHRTb2Z0d2
FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAS1JREFUeNqMU01KxkAMTaez7aYbNwreQdBzeopS6EXEW+jug7Z
C6X+/iUloSr6xioFHJkPee5mUJgBwT7gjpPB3XAgfiBjs5dOyLF/btl0pkEFngdbzPGNRFK/U+0hwJAAMjmcm
DsOA4zge6Pseu67DpmlEqK5rLMvyRkDJor6uq2SGktu2FfdpmpANqqoSASYnO/kthABJkoCOxCASkCBkWSYuQ
qCeNE1fqHz3fMkXzjnJ2sRinL33QBNIzWJ5nh/L8npQohVTJwYTyfFm/d6Oo2HGE8ffwseuZ1PEjhrOutmsRF
0iC8QmPibEtT4hftrhHI95JqJT/HC2JOt0to+zN6MVsZ/oZKqwmyCTA33DkbN1sws0i+Pega6v0kd42H9JB/8
LJl5I6PNbgAEAa9MP7QWoNLoAAAAASUVORK5CYII=');
$loading = str_replace(array("\r\n", "\r", "\n"), '',
'data:image/gif;base64,R0lGODlhFAAUALMIAPh2AP+TMsZiALlcAKNOAOp4ANVqAP+PFv///wAAAAAAAA
AAAAAAAAAAAAAAAAAAACH/C05FVFNDQVBFMi4wAwEAAAAh+QQFCgAIACwAAAAAFAAUAAAEUxDJSau9iBDMteb
TMEjehgTBJYqkiaLWOlZvGs8WDO6UIPCHw8TnAwWDEuKPcxQml0Ynj2cwYACAS7VqwWItWyuiUJB4s2AxmWxG
g9bl6YQtl0cAACH5BAUKAAgALAEAAQASABIAAAROEMkpx6A4W5upENUmEQT2feFIltMJYivbvhnZ3Z1h4FMQI
Dodz+cL7nDEn5CH8DGZhcLtcMBEoxkqlXKVIgAAibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAAQASABIAAA
ROEMkphaA4W5upMdUmDQP2feFIltMJYivbvhnZ3V1R4BNBIDodz+cL7nDEn5CH8DGZAMAtEMBEoxkqlXKVIg4
HibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAAQASABIAAAROEMkpjaE4W5tpKdUmCQL2feFIltMJYivbvhnZ
3R0A4NMwIDodz+cL7nDEn5CH8DGZh8ONQMBEoxkqlXKVIgIBibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAA
QASABIAAAROEMkpS6E4W5spANUmGQb2feFIltMJYivbvhnZ3d1x4JMgIDodz+cL7nDEn5CH8DGZgcBtMMBEox
kqlXKVIggEibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAAQASABIAAAROEMkpAaA4W5vpOdUmFQX2feFIltM
JYivbvhnZ3V0Q4JNhIDodz+cL7nDEn5CH8DGZBMJNIMBEoxkqlXKVIgYDibbK9YLBYvLtHH5K0J0IACH5BAUK
AAgALAEAAQASABIAAAROEMkpz6E4W5tpCNUmAQD2feFIltMJYivbvhnZ3R1B4FNRIDodz+cL7nDEn5CH8DGZg
8HNYMBEoxkqlXKVIgQCibbK9YLBYvLtHH5K0J0IACH5BAkKAAgALAEAAQASABIAAAROEMkpQ6A4W5spIdUmHQ
f2feFIltMJYivbvhnZ3d0w4BMAIDodz+cL7nDEn5CH8DGZAsGtUMBEoxkqlXKVIgwGibbK9YLBYvLtHH5K0J0
IADs=');
//編輯器模版
$html = <<
ACE代碼編輯器
儲存
重新整理
重設
退出
{$tree}
{$code}
HTMLSTR;
//判斷是否已經登入
if ( !is_logged() ) {
die(str_replace(
array('【標題】', '【動作】'),
array('請輸入您第一次設定的密碼!', '登入'),
$first
));
} else {
echo $html;
}
以上就是本文所述的全部內容了,希望大家能夠喜歡。