1. [代码][PHP]代码
<?php/** * 单文件版在线代码编辑器 editor.php 版本: v1.21 * * 密码加密方式: * md5(自设密码+$ace) //$ace为cdn镜像地址 * * 使用方法: * 1.确认 $pwd 变量值为 false, 上传本文件到PHP空间并访问 * 2.第一次访问提示设置密码,设置密码并牢记 * 3.使用第一次设置的密码登录后,默认编辑的是本php文件, * 4.本文件是编辑器核心文件,请不要随意修改 * 5.保存编辑的文件请用 Ctrl + S 按键组合,等待执行结果 * 6.保存动作执行后请务必等待保存成功信息返回 * 7.重置操作会修改本程序的文件名,以防他人猜测路径 * 8.刷新功能仅是刷新本程序文件,不能刷新其他 * * 建议在 chrome 浏览器中使用本编辑器 * * * */ 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和COOKIEfunction 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 = '<li class="dir" path="'.$file.'" onclick="load();"><span>'.$v.'</span></li>';}array_push($lst['dir'], $v);} else {if ( 'html' === $type ) {$v = '<li class="file" path="'.$file.'" onclick="load()"><span>'.$v.'</span></li>';}array_push($lst['file'], $v);}}}$lst = array_merge($lst['dir'], $lst['file']);$lst = array_filter($lst);$flag = $lst;if ( 'html' === $type ) {$flag = '<ul>'. implode('', $lst) .'</ul>';}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 = '<ul id="dir_tree"><li class="dir" path="/" onclick="load()">ROOT'.list_dir($curr_file, 'html').'</li></ul>';//登陆和设置密码共用模版$first = <<<HTMLSTR<!DOCTYPE html><html><head><meta charset="UTF-8"><title>【标题】</title><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><style type="text/css" media="screen">body {overflow: hidden; background-color: #2D2D2D; color: #CCCCCC; font-size: 12px; margin: 0;font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', 'Consolas', 'source-code-pro', monospace;}form { display: none; position: absolute; }form h5 { font-size: 14px; font-weight: normal; margin: 0; line-height: 2em; }form input { color: #fff; border: 1px solid #369; border-radius: 3px; background: #333; height: 22px; line-height: 1.6em; width: 125px; margin-right: 5px; vertical-align: middle;}form button { line-height: 1.6em; border: 1px solid #369; border-radius: 3px; background: #369; color: #fff; vertical-align: middle;}</style><link rel="stylesheet" href="{$tip['core']}" /><link rel="stylesheet" href="{$tip['css']}" /></head><body><form method="post"><input name="pwd" type="password" /><button type="submit">【动作】</button></form><script src="{$jquery}" type="text/javascript" charset="utf-8"></script><script src="{$ace}" type="text/javascript" charset="utf-8"></script><script src="{$tip['js']}" type="text/javascript"></script><script type="text/javascript">var editor = false;$(function(){$('form').prepend('<h5>'+ document.title +'</h5>');$('form').css({left: ($(window).width()-$('form').width())/2,top: ($(window).height()-$('form').height())/2});$('form').show();});</script></body></html>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"), '','');$file_icon = str_replace(array("\r\n", "\r", "\n"), '','');$loading = str_replace(array("\r\n", "\r", "\n"), '','');//编辑器模版$html = <<<HTMLSTR<!DOCTYPE html><html><head><meta charset="UTF-8"><title>ACE代码编辑器</title><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><style type="text/css" media="screen">a { text-decoration: none; }body {overflow: hidden; background-color: #2D2D2D; font-size: 12px;font-family: 'Consolas', 'Monaco', 'Menlo', 'Ubuntu Mono', monospace; scrollbar-arrow-color: #ccc; scrollbar-base-color: #333; scrollbar-dark-shadow-color: #00ffff; scrollbar-track-color: #272822; scrollbar-highlight-color: #272822; scrollbar-3d-light-color: #272822; scrollbar-face-color: #2D2D2D; scrollbar-shadow-color: #333;}::-webkit-scrollbar { width:5px; height:6px; background-color:#444; }::-webkit-scrollbar:hover { background-color:#444; }::-webkit-scrollbar-thumb:hover { min-height:5px; min-width:5px; background-color: #AAA; }::-webkit-scrollbar-thumb:active { -webkit-border-radius:20px; background-color: #AAA; }::-webkit-scrollbar-thumb { min-height:5px; min-width:5px; -webkit-border-radius:20px; ::-webkit-border-radius:1px; background-color: #AAA;}body > pre { color: #666; }#sider { margin: 0; position: absolute; top: 25px; bottom: 0; left: 0; right: 85%; }#editor { margin: 0; position: absolute; top: 0; bottom: 0; left: 15%; right: 0; }#dir_tree { margin:0; padding: 0; height: 100%; overflow: auto; position: relative; left: 5px; } #dir_tree, #dir_tree ul, #dir_tree li { margin: 0; padding: 0; list-style: none inside; }#dir_tree ul { padding-left: 20px; position: relative; }#dir_tree li { text-indent: 2em; line-height: 1.6em; cursor: default; color: #ccc; }#dir_tree li.hover > span, #dir_tree li:hover > span { color: #66D9EF; }#dir_tree li#on > span { color: red; }#dir_tree li.dir { background: url({$dir_icon}) no-repeat 3px 3px; }#dir_tree li.file { background: url({$file_icon}) no-repeat 3px 0; }#dir_tree li.loading { background: url({$loading}) no-repeat 3px 0; }#logout { position: absolute; top: 0; left: 0; }#logout a { display: inline-block; color: #aaa; line-height: 25px; padding: 0 4px; }#logout a:hover { background: #000; color: #ddd; }#contextmenu { position: absolute; top: 0; left: 0; background: #fff; color: #333; border: 1px solid #000; padding: 1px; }#contextmenu span { display: block; line-height: 24px; text-indent: 20px; width: 80px; cursor: default; }#contextmenu span:hover { background-color: #369; color: #fff; }#alertify .alertify-message, #alertify .alertify-message { text-align: left !important; text-indent: 0; font-weight: bold; font-size: 16px;}#alertify .alertify-dialog, #alertify .alertify-dialog { font-family: 'Consolas'; padding: 10px !important; color: #333 !important;}#alertify .alertify-button { border-radius: 3px !important; font-weight: normal !important; font-size: 14px !important; padding: 3px 15px !important;}.alertify-buttons { text-align: right !important; }</style><link rel="stylesheet" href="{$tip['core']}" /><link rel="stylesheet" href="{$tip['css']}" /></head><body><p id="logout"> <a href="javascript:void(0);">保存</a><a href="javascript:void(0);">刷新</a><a href="javascript:void(0);">重置</a> <a href="?logout">退出</a></p><p id="sider">{$tree}</p><pre id="editor">{$code}