php單文件版在線代碼編輯器_PHP教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦:php實現ip白名單黑名單功能
      本文給大家分享了2個php用于實現黑白名單的實用函數,分別是安全IP檢測函數和獲取客戶端IP函數,注釋里解釋的非常清楚,這里我就不多廢話了。 這個是一個檢測ip是否非法的php函數,適應于白名單,黑名單功能開發,主要場景應用于:api來源限制,訪問限制等. 代碼如下:

       這篇文章主要介紹了php單文件版在線代碼編輯器,個人感覺相當不錯,分享給大家,需要的朋友可以參考下

         

      密碼加密方式:
      * 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']) === 'xmlhtt }
      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 = '<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"), '',
      '
      FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQVJREFUeNqkkk1uwjAQhd84bsNP1FUXLCtu0H3XPSoX4Qrd9wR
      sCjQEcIY3DiiJUYiqRhp5Mra/92YSUVVgLSW49B7H+NApRh75XkHfFoCG+02tyflUeQTw2y9UYYP8cCStc9SM
      PeVA/Sy6Dw555q3au1z+EhBYk1cgO7OSNdaFNT0x5sCkYDha0WPiHZgVqPzLO+8seai6E2jed42bCL06tNyEH
      AX9kv3jh3HqH7BctFWLMOmAbcg05mHK5+sQpd1HYijN47zcDUCShGEHtzxtwQS9WTcAQmJROrJDLXQB9s1Tu6
      MtRED4bwsHLnUzxEeKac3+GeP6eo8yevhjC3F1qC4CDAAl3HwuyNAIdwAAAABJRU5ErkJggg==');
      $file_icon = str_replace(array("\r\n", "\r", "\n"), '',
      '
      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"), '',
      '
      AAAAAAAAAAAAAAAAAAACH/C05FVFNDQVBFMi4wAwEAAAAh+QQFCgAIACwAAAAAFAAUAAAEUxDJSau9iBDMteb
      TMEjehgTBJYqkiaLWOlZvGs8WDO6UIPCHw8TnAwWDEuKPcxQml0Ynj2cwYACAS7VqwWItWyuiUJB4s2AxmWxG
      g9bl6YQtl0cAACH5BAUKAAgALAEAAQASABIAAAROEMkpx6A4W5upENUmEQT2feFIltMJYivbvhnZ3Z1h4FMQI
      Dodz+cL7nDEn5CH8DGZhcLtcMBEoxkqlXKVIgAAibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAAQASABIAAA
      ROEMkphaA4W5upMdUmDQP2feFIltMJYivbvhnZ3V1R4BNBIDodz+cL7nDEn5CH8DGZAMAtEMBEoxkqlXKVIg4
      HibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAAQASABIAAAROEMkpjaE4W5tpKdUmCQL2feFIltMJYivbvhnZ
      3R0A4NMwIDodz+cL7nDEn5CH8DGZh8ONQMBEoxkqlXKVIgIBibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAA
      QASABIAAAROEMkpS6E4W5spANUmGQb2feFIltMJYivbvhnZ3d1x4JMgIDodz+cL7nDEn5CH8DGZgcBtMMBEox
      kqlXKVIggEibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAAQASABIAAAROEMkpAaA4W5vpOdUmFQX2feFIltM
      JYivbvhnZ3V0Q4JNhIDodz+cL7nDEn5CH8DGZBMJNIMBEoxkqlXKVIgYDibbK9YLBYvLtHH5K0J0IACH5BAUK
      AAgALAEAAQASABIAAAROEMkpz6E4W5tpCNUmAQD2feFIltMJYivbvhnZ3R1B4FNRIDodz+cL7nDEn5CH8DGZg
      8HNYMBEoxkqlXKVIgQCibbK9YLBYvLtHH5K0J0IACH5BAkKAAgALAEAAQASABIAAAROEMkpQ6A4W5spIdUmHQ
      f2feFIltMJYivbvhnZ3d0w4BMAIDodz+cL7nDEn5CH8DGZAsGtUMBEoxkqlXKVIgwGibbK9YLBYvLtHH5K0J0
      IADs=');
      //編輯器模版
      $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>
      <div id="logout">
      <a href="javascript:void(0);">保存</a>
      <a href="javascript:void(0);">刷新</a>
      <a href="javascript:void(0);">重置</a>
      <a href="?logout">退出</a>
      </div>
      <div id="sider">{$tree}</div><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 = $('<div id="contextmenu"></div>');
      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操作(刪除,提取,增加)zip文件方法詳解
      本文給大家分享的是php操作zip文件的方法示例,包括了從zip壓縮文件中提取文件、從一個zip壓縮文件中刪除文件、添加一個文件到zip壓縮文件中,推薦給大家,有需要的小伙伴參考下。 php讀取zip文件(刪除文件,提取文件,增加文件)實例 從zip壓縮文件中提取文件 代碼如下:

      來源:模板無憂//所屬分類:PHP教程/更新時間:2015-03-13
      相關PHP教程