0

0

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

墨辰丷

墨辰丷

发布时间:2018-06-12 16:58:24

|

4185人浏览过

|

来源于php中文网

原创

这篇文章主要介绍了php单文件版在线代码编辑器,个人感觉相当不错,分享给大家,需要的朋友可以参考下

密码加密方式:
 * md5(自设密码+$ace) //$ace为cdn镜像地址

使用方法:

 * 1.确认 $pwd 变量值为 false, 上传本文件到PHP空间并访问
 * 2.第一次访问提示设置密码,设置密码并牢记
 * 3.使用第一次设置的密码登录后,默认编辑的是本php文件,
 * 4.本文件是编辑器核心文件,请不要随意修改
 * 5.保存编辑的文件请用 Ctrl + S 按键组合,等待执行结果
 * 6.保存动作执行后请务必等待保存成功信息返回
 * 7.重置操作会修改本程序的文件名,以防他人猜测路径
 * 8.刷新功能仅是刷新本程序文件,不能刷新其他

新秀B2C商城系统
新秀B2C商城系统

新秀B2C商城系统是一款简洁易用PHP商城系统。可免费下载使用,可用于商业用途,没有时效限制,除版权标识外,所有代码都允许修改。后台功能简介:1、商城设置:基本信息,配送方式,配送范围,支付方式,财务管理;2、商品管理:商品列表,添加商品,商品分类,商品品牌,商品属性;3、订单管理:订单列表,缺货登记;4、用户互动:用户管理,留言管理,评论管理,网站公告,在线客服,用户协议;5、文章管理:文章列表

下载

建议在 chrome 浏览器中使用本编辑器

立即学习PHP免费学习笔记(深入)”;

代码如下:

 '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 = '
      '. implode('', $lst) .'
    '; } 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}

    相关文章

    PHP速学教程(入门到精通)
    PHP速学教程(入门到精通)

    PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

    下载

    相关标签:

    php

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    相关专题

    更多
    vlookup函数使用大全
    vlookup函数使用大全

    本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

    26

    2025.12.30

    金山文档相关教程
    金山文档相关教程

    本专题整合了金山文档相关教程,阅读专题下面的文章了解更多详细操作。

    28

    2025.12.30

    PS反选快捷键
    PS反选快捷键

    本专题整合了ps反选快捷键介绍,阅读下面的文章找到答案。

    25

    2025.12.30

    表格中一行两行的方法
    表格中一行两行的方法

    本专题整合了表格中一行两行的相关教程,阅读专题下面的文章了解更多详细内容。

    3

    2025.12.30

    cpu温度过高解决方法大全
    cpu温度过高解决方法大全

    本专题整合了cpu温度过高相关教程,阅读专题下面的文章了解更多详细内容。

    5

    2025.12.30

    ASCII码介绍
    ASCII码介绍

    本专题整合了ASCII码相关内容,阅读专题下面的文章了解更多详细内容。

    31

    2025.12.30

    GPS是什么
    GPS是什么

    本专题整合了GPS相关内容,阅读专题下面的文章了解更多详细内容。

    3

    2025.12.30

    wifi拒绝接入
    wifi拒绝接入

    本专题整合了wifi拒绝接入相关教程,阅读下面的文章了解更多详细方法。

    9

    2025.12.30

    丰网速运介绍
    丰网速运介绍

    本专题整合了丰网速运查询入口以及相关内容,阅读专题下面的文章了解更多内容。

    3

    2025.12.30

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    PHP课程
    PHP课程

    共137课时 | 8.1万人学习

    JavaScript ES5基础线上课程教学
    JavaScript ES5基础线上课程教学

    共6课时 | 6.9万人学习

    PHP新手语法线上课程教学
    PHP新手语法线上课程教学

    共13课时 | 0.8万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号