您好,欢迎访问一九零五行业门户网

php单文件版在线代码编辑器使用方法

这篇文章主要介绍了php单文件版在线代码编辑器,个人感觉相当不错,分享给大家,需要的朋友可以参考下
密码加密方式:
 * md5(自设密码+$ace) //$ace为cdn镜像地址
使用方法:
 * 1.确认 $pwd 变量值为 false, 上传本文件到php空间并访问
 * 2.第一次访问提示设置密码,设置密码并牢记
 * 3.使用第一次设置的密码登录后,默认编辑的是本php文件,
 * 4.本文件是编辑器核心文件,请不要随意修改
 * 5.保存编辑的文件请用 ctrl + s 按键组合,等待执行结果
 * 6.保存动作执行后请务必等待保存成功信息返回
 * 7.重置操作会修改本程序的文件名,以防他人猜测路径
 * 8.刷新功能仅是刷新本程序文件,不能刷新其他
建议在 chrome 浏览器中使用本编辑器
代码如下:
<?phpsession_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}</pre><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 load = false;var curr_file = false;window.location.hash = '';alertify.set({delay: 1000}); //n秒后自动消失alertify.set({labels: {ok:'确定',cancel:'取消'}});var editor = false;$(function(){ //实例化代码编辑器 editor = ace.edit("editor"); //设置编辑器的语法和高亮 editor.settheme("ace/theme/monokai"); editor.getsession().setmode("ace/mode/php"); //设置编辑器自动换行 editor.getsession().setwraplimitrange(null, null); editor.getsession().setusewrapmode(true); //不显示垂直衬线 editor.renderer.setshowprintmargin(false); //editor.setreadonly(true); //设置编辑器为只读 //editor.gotoline(325); //跳转到指定行 //使编辑器获得输入焦点 editor.focus(); //绑定组合按键 var commands = editor.commands; commands.addcommand({ name: "save", bindkey: {win: "ctrl-s", mac: "command-s"}, exec: save_file }); //保存动作 function save_file() { if ( false == editor ) { return false; } var obj = { content: editor.getvalue(), action: 'save_file' }; if ( false !== curr_file ) { obj.file_path = curr_file; } alertify.log('正在保存...'); $.post(window.location.href, obj, function(data){ if ( data.msg && 'success' == data.result ) { alertify.success(data.msg); } else { alertify.error(data.msg); } }, 'json'); } //加载目录列表或文件 load = function(ele) { var curr = $(event.srcelement); if ( ele ) { curr = ele; } if ( curr.is('span') ) { curr = curr.parent('li'); } $('#dir_tree #on').removeattr('id'); curr.attr('id', 'on'); var type = curr.attr('class'); var path = curr.attr('path'); window.location.hash = path; if ( 'file' === type ) { alertify.log('正在加载...'); curr.addclass('loading'); $.post(window.location.href, {file:path}, function(data){ curr.removeclass('loading'); if ( data.mode ) { editor.getsession().setmode("ace/mode/"+data.mode); } //注意,空文件应当允许编辑 if ( true || data.html ) { curr.attr('disabled', 'disabled'); curr_file = path; //当前编辑的文件路径 //动态赋值编辑器中的内容 editor.session.doc.setvalue(data.html); editor.renderer.scrolltorow(0); //滚动到第一行 editor.focus(); //编辑器获得焦点 settimeout(function(){ editor.gotoline(0); }, 800); } }, 'json'); event.stoppropagation(); event.preventdefault(); return false; } if ( 'dir' === type ) { if ( curr.attr('loaded') ) { curr.children('ul').toggle(); event.stoppropagation(); event.preventdefault(); return false; } else { curr.attr('loaded', 'yes'); } alertify.log('正在加载...'); curr.addclass('loading'); $.post(window.location.href, {dir:path}, function(data){ curr.find('ul').remove(); curr.removeclass('loading'); if ( data.html ) { curr.append(data.html); } }, 'json'); } return false; } //绑定右键菜单 $('#sider').bind('contextmenu', function(e){ var path = false; var target = $(event.srcelement); if ( target.is('span') ) { target = target.parent('li'); } if ( target.attr('path') ) { path = target.attr('path'); } else { return false; } target.addclass('hover'); var right_menu = $('#contextmenu'); if ( !right_menu.get(0) ) { var timer = false; right_menu = $('<p id="contextmenu"></p>'); right_menu.hover(function(){ if ( timer ) { cleartimeout(timer); } }, function(){ timer = settimeout(function(){ hide_menu(right_menu); }, 500); }); $('body').append(right_menu); } if ( path ) { right_menu.html(''); var menu = $('<span>新建</span><span>浏览</span><span>重命名</span><span>删除</span>'); right_menu.append(menu); menu_area(right_menu, {left: e.pagex, top: e.pagey}); right_menu.find('span').click(function(){ switch ( $(this).text() ) { case '新建' : create_new(target, path); break; case '浏览' : preview(target, path); break; case '重命名' : re_name(target, path); break; case '删除' : del_file(target, path); break; } hide_menu(right_menu); }); } path ? right_menu.show() : hide_menu(right_menu); return false; }); //隐藏右键菜单 function hide_menu(menu) { $('#sider li.hover').removeclass('hover'); if ( menu ) { menu.hide(); } } //右键菜单区域 function menu_area(menu, cfg) { if ( menu && cfg ) { var w = $('#sider').width() - menu.width(); var h = $('#sider').height() - menu.height(); if ( cfg.left > w ) { cfg.left = w; } if ( cfg.top > h ) { cfg.top = h; } menu.css(cfg); } } //保存按钮 $('#logout>a:contains("保存")').click(function(){ save_file(); return false; }); //刷新按钮 $('#logout>a:contains("刷新")').click(function(){ window.location.href = window.location.pathname; return false; }); //重置按钮 $('#logout>a:contains("重置")').click(function(){ alertify.confirm('是否修改 {$curr_file_path} 程序文件名?', function (e) { if ( !e ) { return 'cancel'; } re_name($('<a>'), '{$curr_file_path}'); }); return false; }); //新建操作 function create_new(obj, path) { if ( !obj || !path ) { return false; } alertify.prompt('请输入新建文件或文件夹名:', function (e, str) { if ( !e || !str ) { return false; } alertify.log('正在操作中...'); $('#dir_tree #on').removeattr('loaded').removeattr('id'); $.post(window.location.href, {create:str,target:path}, function(data){ if ( data.msg && 'success' == data.result ) { alertify.success(data.msg); if ( obj.attr('class') == 'dir' ) { load(obj); //重新加载子节点 } else { load(obj.parent().parent()); } } else { alertify.error(data.msg); } }, 'json'); }); } //浏览操作 function preview(obj, path) { if ( !obj || !path ) { return false; } window.open(path, '_blank'); } //重命名 function re_name(obj, path) { if ( !obj || !path ) { return false; } alertify.prompt('重命名 '+path+' 为:', function (e, str) { if ( !e || !str ) { return false; } alertify.log('正在操作中...'); $.post(window.location.href, {rename:str,target:path}, function(data){ if ( data.msg && 'success' == data.result ) { alertify.success(data.msg); if ( data.redirect ) { window.location.href = data.redirect; } if ( data.new_name ) { obj.children('span').first().text(data.new_name); obj.attr('path', data.new_path); } } else { alertify.error(data.msg); } }, 'json'); }); } //删除文件动作 function del_file(obj, path) { if ( !obj || !path ) { return false; } alertify.confirm('您确定要删除:'+path+' 吗?', function (e) { if ( !e ) { return 'cancel'; } alertify.log('正在删除中...'); $.post(window.location.href, {del:path}, function(data){ if ( data.msg && 'success' == data.result ) { alertify.success(data.msg); obj.remove(); } else { alertify.error(data.msg); } }, 'json'); }); }});</script></body></html>htmlstr;//判断是否已经登录if ( !is_logged() ) { die(str_replace( array('【标题】', '【动作】'), array('请输入您第一次设置的密码!', '登录'), $first )); } else { echo $html;}
总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。
相关推荐:
php单例模式的概念及特点
php通过ajax调用连接百度效果实现检测网站是否联网的功能
php中static关键字的定义、迟绑定以及与self关键字的区别
以上就是php单文件版在线代码编辑器使用方法的详细内容。
其它类似信息

推荐信息