这篇文章主要介绍了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']) === '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 = <<

【标题】

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;

}

【动作】

var editor = false;

$(function(){

$('form').prepend('

'+ document.title +'

');

$('form').css({

left: ($(window).width()-$('form').width())/2,

top: ($(window).height()-$('form').height())/2

});

$('form').show();

});

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 = <<

ACE代码编辑器

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; }

保存

刷新

重置

退出

{$tree}

{$code}

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 = $('

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 = $('新建浏览重命名删除');

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($(''), '{$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');

});

}

});

HTMLSTR;

//判断是否已经登录

if ( !is_logged() ) {

die(str_replace(

array('【标题】', '【动作】'),

array('请输入您第一次设置的密码!', '登录'),

$first

));

} else {

echo $html;

}

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。

相关推荐:

127.0.0.1 zxt.php_php单文件版在线代码编辑器使用方法相关推荐

  1. 在线编写php文件,php单文件版在线代码编辑器_php实例

    密码加密方式: * md5(自设密码+$ace) //$ace为cdn镜像地址 使用方法: * 1.确认 $pwd 变量值为 false, 上传本文件到PHP空间并访问 * 2.第一次访问提示设置密码 ...

  2. WinHex v20.0 绿色单文件版

    本文链接:https://www.xy586.top/38117.html 转载请注明文章来源:行云博客 » WinHex v20.0 绿色单文件版 软件介绍 X-Ways WinHex,全球知名的计 ...

  3. 入口文件到控制器 php,tp5.0框架隐藏index.php入口文件及模块和控制器的方法分析...

    本文实例讲述了tp5.0框架隐藏index.php入口文件及模块和控制器的方法.分享给大家供大家参考,具体如下: 1. 隐藏入口文件: [ IIS ] 在IIS的高版本下面可以配置web.Config ...

  4. CodeMirror 5.26.0 发布,在线代码编辑器

    CodeMirror 5.26.0 已发布,CodeMirror 是一款"Online Source Editor",基于 Javascript,短小精悍,实时在线代码高亮显示,它 ...

  5. 最新TeamViewer绿色便携单文件版之新手使用说明

    TeamViewerPortable单文件版的新手使用说明 TeamViewer这款神器用的人越来越多了,她是否经常在如下场景中有出现: 1.在自己学校的公共电脑上使用TeamViewer通过inte ...

  6. 会说话的狗狗本电脑版_「电脑知识」硬件狗狗专业电脑硬件检测跑分工具免安装单文件版|电脑硬件|电脑|显卡|狗狗|操作系统...

    最新很多小伙伴要求找一款适合大家的硬件检测跑分工具,今天给大家分享一款,简单的希望大家能够喜欢. 硬件狗狗专业的电脑硬件检测工具免安装单文件版,硬件狗狗是一款媲美鲁大师电脑硬件检测工具,由快科技(驱动 ...

  7. wps单文件版_局域网共享精灵,轻松实现文件共享amp;打印机共享

    点击上面的 xiaoqiangclub 关注我! XiaoqiangClub 人生就像一个动物园,当你以为你在看别人耍猴的时候,却不知自己也是猴子中的一员! 与您分享 更多推荐[空间回收]一键回收U盘 ...

  8. 使用WinRAR制作属于自己的单文件版软件

    前言:单文件版软件可以无须安装直接运行,而且体积也比安装版的要小,可以拷贝放到u盘或者移动硬盘里面,随时可以双击使用,对我们来说真的是非常的方便!像这类软件网上也有不少,但是很多时候都不是自己想要的, ...

  9. UltraISO软碟通软件(绿色单文件版)

    UltraISO 是一款功能强大而又方便实用的光盘映像文件制作/编辑/格式转换工具,它可以直接编辑光盘映像和从映像中直接提取文件,也可以从CD-ROM制作光盘映像或者将硬盘上的文件制作成ISO文件.同 ...

最新文章

  1. 读书:个人成长 -- 即兴演讲
  2. IOS开发CALayer隐式动画
  3. SpringBoot非官方教程 | 第八篇:SpringBoot整合mongodb
  4. 自己动手修改龙邱信标灯固件FM频率
  5. php二维数组排序 按照指定的key 对数组进行排序
  6. linux arch 包管理,Archlinux使用包管理方式安装MyEclipse
  7. python自动爬取更新电影网站_python爬取电影网站信息
  8. 算法63----丑数【动态规划】
  9. SpringBoot集成Spring Security(1)——入门程序
  10. 线程池——JAVA并发编程指南
  11. Android端测试工具有哪些,android移动app测试几款移动端测试工具分享
  12. 网易云自动签到云函数【详细版】-2022.5.4
  13. 【微信H5开发】the permission value is offline verifying
  14. html中background标签作用,CSS Background 属性详解
  15. SHIO世硕科技马新云携全体员工:2021,在此感谢所有的一切!
  16. Hark的数据结构与算法练习之插入排序
  17. 离开平凡的生活,你们都是诗人。
  18. Project0:小游戏
  19. ImageViewEx控件介绍
  20. python换脸教程_教你如何用200行Python代码“换脸”教程

热门文章

  1. 计算机无法正常更新,无法完成更新正在撤销更改请不要关闭你的计算机的解决方法...
  2. 自学c语言困难吗,你觉得这4块是C语言最难学的部分吗?
  3. #304 – 为没有文本标题的控件定义Access 键(Defining an Access Key That Gives Focus to a Different Control)
  4. java区分无线网卡,无线网卡种类有什么区别
  5. linux命令日志抓取,linux抓取某条日志记录的命令
  6. treeset可以重复吗_买了好几份意外险,可以重复理赔吗?
  7. <第2.5个月>新店日记,shopee要投入多少钱?利润怎么样能赚钱吗好做吗?shopee孵化期考核
  8. elasticsearch学习笔记——二.querystring查询document方式与dsl查询document方式
  9. 免费送纸质书, 感谢亲们的陪伴~
  10. mts如何转换为mp4