Simple Linux Panel
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
mdserver-web/plugins/tamper_proof_py/index.html

1163 lines
47 KiB

<style>
/*防篡改*/
.anti-switch {
margin-left: 20px;
margin-top: 4px;
}
.anti_lib_tit {
margin-bottom: 15px;
padding-bottom: 15px;
border-bottom: #ddd 1px solid;
}
.anti_lib_con {
background-color: #FBFBFB;
border: #F0F0F0 1px solid;
padding: 15px 10px;
}
.anti_rule_add {
margin-bottom: 10px;
}
.anti_rule_add input {
width: 360px;
}
.data-count-all {
background-color: #FAFAFA;
border: #ddd 1px solid;
width: 100%;
float: left;
}
.data-count-all .data-count-box {
height: 100%;
text-align: center;
width: 20%;
float: left;
margin-bottom: 15px;
}
.data-count-box .dname {
color: #78797D;
margin-top: 12px;
margin-bottom: 10px;
}
.data-count-box .dval {
color: #333;
}
.data-count-box .dval span {
font-family: arial;
color: #121313;
font-size: 20px;
}
.anti_rule_list_type {
float: left;
width: 45%;
}
.anti_rule_list {
width: 100%;
float: left;
margin-bottom: 20px;
}
.search-day {
height: 32px;
margin-left: 1px;
}
.search-day span {
float: left;
height: 32px;
line-height: 30px;
border: #ddd 1px solid;
padding: 0 20px;
margin-left: -1px;
cursor: pointer;
position: relative;
}
.search-day span.cur {
background-color: #20a53a;
color: #fff;
}
.search-day span.cur input,
.search-day span.cur em {
color: #666;
}
.search-day span:last-child {
padding: 0;
}
.search-day span input {
border: 0 none;
height: 30px;
padding: 0 10px;
width: 105px;
background-image: url("");
background-repeat: no-repeat;
background-position: 86px center;
}
.search-day span input:active {
border: 0 none;
}
.search-day span.cur input {
color: #fff;
background-color: #20a53a;
background-image: url("");
}
.total-all{
overflow: hidden;
}
.anti-open {
position: absolute;
top: 16px;
left: 300px;
line-height: 32px;
}
.bt-w-main {
height: 610px;
}
.nowrap_block {
display: inline-block;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
[name="status"] option{
padding: 5px;
}
/* 模拟攻击 */
.mtl0 {
margin-top: 0;
margin-left: 15px;
}
/* end */
</style>
<div class="bt-form">
<div class="bt-w-main">
<div class="pd15">
<div class="anti-tamper-con"></div>
</div>
</div>
</div>
<script type="text/javascript">
var siteList = [];
$('.layui-layer-page').css({'width': '800px','height':'500px'});
$(".bt-w-menu p").click(function () {
$(this).addClass('bgw').siblings().removeClass('bgw');
});
$('.bt-w-main').on('click', '.simulated_attacks_btn', function () {
var isEdit = false;
layer.open({
type: 1,
title: '模拟攻击',
area: '600px',
closeBtn: 2,
content: '<div id="bt_waf_test_table" class="pd20 bt_table" style="padding-bottom:30px;">\
<div class="divtable" style="max-height:308px; border: 1px solid #ddd;">\
<table class="table table-hover" style="border: none;">\
<thead>\
<tr>\
<th width="300px"><span data-index="1"><span>模拟攻击网站列表</span></span></th>\
<th width="80px" style="text-align:right"><span data-index="2"><span>操作</span></span></th>\
</tr>\
</thead>\
<tbody id="waf_test_table_body"></tbody>\
</table>\
</div>\
</div>\
<ul class="mtl0 c7" style="font-size: 13px;position:relative;bottom:20px;padding-right: 40px;">\
<li style="list-style:inside disc;margin-top:5px" style="">此模拟攻击为:黑客进行SQL注入获取数据库权限.不会影响业务的正常运行</li>\
<li style="list-style:inside disc;margin-top:5px">如果你的IP在IP白名单中测试则无效果</li>\
<li style="list-style:inside disc;margin-top:5px">如需测试其他的网站可使用【http://网站域名/?id=/etc/passwd】进行攻击</li>\
<li style="list-style:inside disc;margin-top:5px">返回拦截信息则表示拦截成功,如发现未拦截,建议更新至最新版</li>\
<li style="list-style:inside disc;margin-top:5px">如有疑问请联系宝塔运维</li>\
</ul>',
success: function (index, layers) {
// bt.fixed_table('bt_waf_test_table table');
for (var i = 0; i < siteList.length; i++) {
var item = siteList[i];
$('#waf_test_table_body').append($('<tr>\
<td>' + item.siteName + '</td>\
<td class="text-right"><a class="btlink defense" href="javascript:;">查看防护效果</a></td>\
</tr>').data({ data: item, index: i }));
}
$('#waf_test_table_body').on('click', '.defense', function () {
var data = $(this).parents('tr').data('data');
anti_tamper.sim_test({path: data.path}, function (res) {
isEdit = true;
layer.msg(res.msg,{icon:1});
});
});
},
cancel: function (index, layero) {
isEdit && anti_tamper.get_day();
}
});
});
//表格头固定
function tableFixed(name) {
var tableName = document.querySelector('#' + name);
tableName.addEventListener('scroll', scrollHandle);
}
function scrollHandle(e) {
var scrollTop = this.scrollTop;
$(this).find("thead").css({"transform": "translateY(" + scrollTop + "px)","position": "relative","z-index": "1"});
}
function appPost(method,args,callback, msg = ''){
var _args = null;
if (typeof(args) == 'string'){
_args = JSON.stringify(toArrayObject(args));
} else {
_args = JSON.stringify(args);
}
if (msg == ''){
msg = '正在获取...';
}
var loadT = layer.msg(msg, { icon: 16, time: 0, shade: 0.3 });
$.post('/plugins/run', {name:'tamper_proof_py', func:method, args:_args}, function(data) {
layer.close(loadT);
if (!data.status){
layer.msg(data.msg,{icon:0,time:2000,shade: [0.3, '#000']});
return;
}
if(typeof(callback) == 'function'){
callback(data);
}
},'json');
}
var anti_tamper = {
speed_index: null,
//查看面板运行日志
get_run_logs: function () {
appPost('get_run_logs',{},function (rdata) {
var rdata = $.parseJSON(rdata.data);
if (!rdata.status) {
layer.msg(rdata.msg, { icon: 2 });
return;
};
layer.open({
type: 1,
title: '防篡改服务运行日志',
area: ['700px', '490px'],
shadeClose: false,
closeBtn: 2,
content: '<div class="setchmod bt-form pb70">'
+ '<pre class="run-log" style="overflow: auto; border: 0px none; line-height:23px;padding: 15px; margin: 0px; white-space: pre-wrap; height: 405px; background-color: rgb(51,51,51);color:#f1f1f1;border-radius:0px;font-family: \"微软雅黑\"">'
+ (rdata.msg == '' ? '当前日志为空' : rdata.msg)
+ '</pre>'
+ '</div>'
});
setTimeout(function () {
$("#run-log").text(rdata.msg);
var div = document.getElementsByClassName('run-log')[0]
div.scrollTop = div.scrollHeight;
}, 200);
});
},
get_speed: function(){
// $.get('/plugin?action=a&s=get_speed&name=tamper_proof',function(result){
// if(!result['speed'] || result['speed'] == '>>>>>>>>>>END<<<<<<<<<<'){
// if(anti_tamper.speed_index){
// layer.close(anti_tamper.speed_index);
// anti_tamper.speed_index = null;
// }
// return
// }
// if(!anti_tamper.speed_index){
// anti_tamper.speed_index = layer.open({
// title: false,
// type: 1,
// closeBtn: 0,
// shade: 0.3,
// area: "500px",
// offset: "30%",
// content: "<pre style='margin-bottom: 0px;height:250px;text-align: left;background-color: #000;color: #fff;white-space: pre-wrap;' id='tamper_speed'></pre>"
// });
// }
// $("#tamper_speed").text(result['log']);
// setTimeout(function(){
// anti_tamper.get_speed();
// },1000)
// });
},
get_day: function () {
var con = '<div class="search-day">\
<span class="cur" onclick="anti_tamper.index(\'' + anti_tamper.getBeforeDate(0) + '\')">今日</span>\
<span onclick="anti_tamper.index(\'' + anti_tamper.getBeforeDate(1) +'\')">昨日</span>\
<span class="last-span">\
<input id="webdate-select" type="text" value="">\
</span>\
<div class="pull-right">\
<button class="btn btn-default btn-sm" onclick="anti_tamper.get_run_logs()">运行日志</button>\
<button style="margin-left: 5px;" class="btn btn-success btn-sm va0 simulated_attacks_btn">模拟攻击</button>\
</div>\
</div>\
<div class="total-all"></div>\
<div class="webDataStats-day"></div>';
$(".anti-tamper-con").html(con);
anti_tamper.index();
$(".search-day span").not(".last-span").click(function () {
$(this).addClass("cur").siblings().removeClass("cur");
})
laydate.render({
elem: '#webdate-select',
value: new Date(),
max: 0,
done: function (value, date, endDate) {
anti_tamper.index(value);
$("#date-select").val(value);
$(".last-span").addClass("cur").siblings().removeClass("cur");
}
});
},
index: function (day) {
var _this = this;
$(".webDataStats-day").html("<div class='cloading' style='margin-top:120px'>加载中,请稍侯</div>");
appPost('get_index', {day:day}, function(rdata){
var rdata = $.parseJSON(rdata.data);
var rdata = rdata.data;
if (rdata === false) {
layer.closeAll();
layer.msg('当前插件未购买,请刷新列表后重试', {icon: 2});
return;
}
siteList = rdata.sites;
var serviceOpen = rdata.open ? 'checked' : '';
var siteBody = '';
var _day_total = 0;
var _day_create = 0;
var _day_delete = 0;
var _day_modify = 0;
var _day_move = 0;
for (var i = 0; i < rdata.sites.length; i++) {
var day_arr = rdata.sites[i].total;
var total = day_arr.site.total;
var dayTotal = day_arr.day.total;
var _sitename = rdata.sites[i].siteName;
$.each(day_arr.day, function (key, val) {
switch (key) {
case 'total': _day_total += val;break;
case 'create':_day_create += val;break;
case 'delete':_day_delete += val;break;
case 'modify':_day_modify += val;break;
case 'move':_day_move += val;break;
}
});
siteBody += '<tr>\
<td><label><input type="checkbox" class="cust—checkbox-input" data-checkbox="'+ i +'"></label></td>\
<td><span class="nowrap_block" style="width:90px;" title="' + _sitename +'">' + _sitename + '</span></td>\
<td><span class="nowrap_block" style="width:200px;" title="' + _sitename +'">' + rdata.sites[i].path + '</span></td>\
<td><span title="创建:' + day_arr.site.create + '\n删除:' + day_arr.site.delete + '\n修改:' + day_arr.site.modify + '\n移动:' + day_arr.site.move + '">' + total + '</span></td>\
<td><span title="创建:' + day_arr.day.create + '\n删除:' + day_arr.day.delete +'\n修改:' + day_arr.day.modify + '\n移动:' + day_arr.day.move + '">' + dayTotal + '</span></td>\
<td>\
<div class="pull-left">\
<input class="btswitch btswitch-ios" id="close_anti_site_' + i +'" type="checkbox" ' + (rdata.sites[i].open ? 'checked' : '') + ' />\
<label class="btswitch-btn" for="close_anti_site_' + i +'" onclick=\'anti_tamper.set_site_status("' + _sitename + '",' + (rdata.sites[i].open ? 1 : 0) +',' + i + ')\' style="width:2.0em;height:1.2em;margin-bottom:0"></label>\
</div>\
</td>\
<td>\
<a onclick="anti_tamper.show_site_log(\'' + _sitename + '\')" class="btlink">日志</a> | \
<a onclick="anti_tamper.site_exclude_path(\'' + _sitename + '\',\''+rdata.sites[i].path+'\')" class="btlink">排除</a> | \
<a onclick="anti_tamper.site_tmaper_ext(\'' + _sitename + '\',\''+rdata.sites[i].path+'\')" class="btlink">保护</a>\
</td >\
</tr>';
}
var con = '<div class="anti-open">\
<span class="pull-left">防篡改开关</span>\
<div class="anti-switch pull-left">\
<input class="btswitch btswitch-ios" id="close_anti" type="checkbox" ' + serviceOpen + '>\
<label class="btswitch-btn" for="close_anti" onclick="anti_tamper.service_status()"></label>\
</div>\
</div>';
var con1 = '<div class="anti_rule_list anti_home_box">\
<div class="divtable bt_table">\
<div id="site_list_box" style="max-height:425px;overflow:auto;border:#ddd 1px solid">\
<table class="table table-hover" style="border:none">\
<thead>\
<tr>\
<th width="34px">\
<span>\
<label>\
<input type="checkbox" class="cust—checkbox-input" data-checkbox="all"/>\
</label>\
</span>\
</th>\
<th>站点</th>\
<th>监听目录</th>\
<th>总次数</th>\
<th>当日次数</th>\
<th>状态</th>\
<th width="120">操作</th>\
</tr>\
</thead>\
<tbody>' + siteBody + '</tbody>\
</table>\
</div>\
<div class="bt_batch mt10">\
<label><input type="checkbox" class="cust—checkbox" data-checkbox="all"/></label>\
<select class="bt-input-text mr5" name="status" disabled="disabled" style="height:28px;color: #666;" placeholder="请选择批量操作">\
<option style="color: #b6b6b6;display:none;" disabled selected>请选择批量操作</option>\
<option value="1">开启防篡改</option>\
<option value="0">关闭防篡改</option>\
</select>\
<button class="btn btn-success btn-sm setBatchStatus" disabled="disabled">批量操作</button>\
</div>\
</div></div>\
<ul class="help-info-text c7">\
<li>您可以通过【排除】按钮来编辑不受保护的目录名称,通过【保护】按钮来编辑受保护的文件类型</li>\
<li>如果开启防篡改后您的网站出现异常,请尝试排除网站日志、缓存、临时文件、上传等目录后重试,或直接关闭异常网站防篡改功能</li>\
</ul>';
$(".total-all").html(con);
$('.webDataStats-day').html(con1);
tableFixed("site_list_box");
$('.anti_home_box .bt_table .cust—checkbox,.anti_home_box .bt_table .cust—checkbox-input').click(function(){
var checkbox = $(this).data('checkbox'),
length = $('#site_list_box tbody tr').length,
active = $(this).prop('checked');
if(checkbox == 'all'){
if(active){
$('.anti_home_box .cust—checkbox-input').prop('checked',true);
$('.anti_home_box .cust—checkbox-input').addClass('active');
$('.anti_home_box .setBatchStatus').removeAttr('disabled');
$('.anti_home_box select[name="status"]').removeAttr('disabled');
} else {
$('.anti_home_box .cust—checkbox-input').prop('checked',false);
$('.anti_home_box .cust—checkbox-input').removeClass('active');
$('.anti_home_box .setBatchStatus').attr('disabled','disabled');
$('.anti_home_box select[name="status"]').attr('disabled','disabled');
}
} else {
if(active){
$(this).addClass('active');
$('.anti_home_box .setBatchStatus,.anti_home_box [name="status"]').removeAttr('disabled');
} else {
$(this).removeClass('active');
}
}
active_length = $('#site_list_box tbody tr .cust—checkbox-input.active').length;
if(active_length === length){
$('.anti_home_box [data-checkbox="all"]').addClass('active');
} else if(active_length === 0) {
$('.anti_home_box .setBatchStatus,.anti_home_box [name="status"]').attr('disabled','disabled');
} else {
$('.anti_home_box [data-checkbox="all"]').removeClass('active');
}
});
$('.anti_home_box .setBatchStatus').click(function(){
var siteState = parseInt($('.anti_home_box [name="status"]').val());
var siteNames = [];
console.log(rdata['sites']);
$('#site_list_box tbody tr .cust—checkbox-input.active').each(function(){
var i = $(this).data('checkbox');
siteNames.push(rdata.sites[i].siteName);
});
if(isNaN(siteState)){
layer.msg({status:false,msg:'请选择批量操作类型'});
return false;
}
layer.confirm('批量'+ (siteState?'开启':'关闭') +'防篡改状态,该操作可能会存在风险,是否继续?',{
title: "批量设置防篡改状态",
icon: 3,
closeBtn: 2,
cancel: function () {
if (status) {
$("#close_anti").prop("checked", true);
} else {
$("#close_anti").prop("checked", false);
}
}
}, function () {
_this.set_site_bath_status({siteState:siteState,siteNames:siteNames},function(res){
layer.msg(res.msg, {icon: 1,time: 2000,shade: 0.3});
anti_tamper.get_day();
});
});
});
});
},
set_site_bath_status:function(config,fun){
var siteNames = [];
appPost('set_site_status_all', {siteNames:JSON.stringify(config.siteNames),siteState:config.siteState}, function(res){
var res = $.parseJSON(res.data);
setTimeout(function(){
anti_tamper.get_speed();
},1000);
if(!res.status && typeof(res.msg)=== "string"){
layer.msg(res.msg, {icon: 1,time: 2000,shade: 0.3});
return false;
}
if(fun) {
fun(res);
}
},'正在设置站点防篡改状态,请稍侯...');
},
//控制服务状态,若服务状态(open)为关闭,则所有站点失去防篡改保护
// start 启动
// stop 停止
// restart 重启
service_status: function () {
var txt = "是否开启防篡改";
var status = $("#close_anti").prop("checked");
var _status = 'start';
if (status) {
txt = "是否关闭防篡改";
_status = "stop";
}
layer.confirm(txt, {title: "防篡改开关",icon: 3,closeBtn: 2, cancel: function () {
if (status) {
$("#close_anti").prop("checked", true);
} else {
$("#close_anti").prop("checked", false);
}
}
}, function () {
appPost('service_admin', {serviceStatus: _status}, function(rdata){
var rdata = $.parseJSON(rdata.data);
if (!rdata.status){
layer.msg(rdata.msg, {icon: 2,time: 2000,shade: 0.3});
$("#close_anti").prop("checked", false);
return;
}
layer.msg(rdata.msg, {icon: rdata.status ? 1 : 2});
},'正在设置防篡改总开关状态,请稍侯...');
},function(){
if (status) {
$("#close_anti").prop("checked", true);
} else {
$("#close_anti").prop("checked", false);
}
});
},
//站点状态控制
//用于控制指定站点是否被保护,当open为False时,请求此接口将open改为True,反之为False
set_site_status: function (siteName, _lock, index) {
// var txt = "是否开启站点备份模式,该模式将会消耗与站点同等大小的磁盘空间!";
var status = $("#close_anti_site_" + index).prop("checked");
var txt_status = {true:'关闭',false:'开启'};
var txt = "是否"+txt_status[status]+"站点["+ siteName +"],防篡改";
layer.confirm(txt,{title: "防篡改开关",icon: 3,closeBtn: 2,cancel: function () {
$("#close_anti_site_" + index).prop('checked', _lock === 1 ? true : false);
}
}, function () {
appPost('set_site_status', {siteName: siteName}, function(rdata){
var rdata = $.parseJSON(rdata.data);
anti_tamper.get_day();
layer.msg(rdata.msg, {icon: rdata.status ? 1 : 2});
// anti_tamper.get_speed();
},'正在设置站点防篡改状态,请稍侯...');
}, function () {
$("#close_anti_site_" + index).prop('checked', _lock === 1 ? true : false);
});
},
//显示站点防御日志
show_site_log: function (siteName, day) {
var _this = this;
if (day != undefined) {
pdata['day'] = day;
}
appPost('get_safe_logs', {siteName: siteName,day: day}, function(rdata){
var rdata = $.parseJSON(rdata.data);
var rdata = rdata.data;
var selectLogDay = "";
var day = rdata[0];
for (var i = 0; i < rdata.days.length; i++) {
selectLogDay += '<option value="' + rdata.days[i] + '">' + rdata.days[i] + '</option>';
}
if (rdata.logs == "") {
layer.msg("暂无日志记录", {icon: 6,shade: 0.3,time: 1000});
return;
}
var con = '';
var logs_len = rdata.logs.length;
for (var i = 0; i < logs_len; i++) {
var txt = '';
switch (rdata.logs[i][1]) {
case 'create':txt = '创建';break;
case 'delete':txt = '删除';break;
case 'modify':txt = '修改';break;
case 'move':txt = '移动';break;
}
con += '<tr>\
<td>' + anti_tamper.timestampToTime(rdata.logs[i][0]) + '</td>\
<td>' + txt + '</td>\
<td>' + rdata.logs[i][2] + '</td>\
<td>防护成功</td>\
</tr>'
}
layer.open({
type: 1,
title: "日志【" + siteName + "】",
area: ['860px', '550px'],
closeBtn: 2,
shadeClose: false,
content: '<div class="lib-box pd15 lib-box-log">\
<div class="lib-con-title" style="height:40px">\
<select id="selectLogDay" class="bt-input-text" onchange="anti_tamper.show_site_log_con(\'' + siteName +'\',this.options[this.options.selectedIndex].value)">' + selectLogDay + '</select>\
<button class="btn btn-success btn-sm va0 mb15 remove_logs mr5">清理日志</button>\
</div>\
<div class="lib-con">\
<div class="divtable">\
<div id="site_anti_log" style="max-height:400px;overflow:auto;border:#ddd 1px solid">\
<table class="table table-hover" style="border:none;">\
<thead><tr><th width="150">时间</th><th width="70">类型</th><th>文件</th><th>溯源日志</th><th width="80">状态</th></tr></thead>\
<tbody id="LogDayCon"></tbody>\
</table>\
</div>\
<p class="mtb10 c9" style="border: #ddd 1px solid;padding: 5px 8px;float: right;"><span id="logs_len">' + logs_len + '</span>条记录</p>\
</div>\
</div>\
</div>',
success: function () {
$('.remove_logs').click(function () {
var select = $('#selectLogDay').val();
var confirm = layer.confirm('是否清理&nbsp;[' + select + ']&nbsp;的日志?', {title: '提示',btn: ['确定', '取消'],icon: 0,closeBtn: 2}, function () {
var loadT = layer.msg('正在清理日志,请稍候..', {
icon: 16,
time: 0
});
$.post('/plugin?action=a&s=ClearDayLog&name=tamper_proof', {
siteName: siteName,
day: select
}, function (rdata) {
layer.close(loadT);
layer.msg(rdata.msg, {icon: rdata.status ? 1 : 2});
if (rdata.status) {
$('#LogDayCon').html('');
$('#logs_len').html('0')
}
});
});
});
$('#LogDayCon').on('click','.get_traceability_log', function(){
var index = $(this).parents('tr').index()
_this.get_traceability_log(siteName,_this.site_log_data[index])
});
}
});
anti_tamper.show_site_log_con(siteName, day);
tableFixed("site_anti_log");
});
},
// 站点日志列表
site_log_data:[],
show_site_log_con: function (siteName, day) {
var _this = this;
$("#site_waf_log").scrollTop(0);
appPost('get_safe_logs', {siteName: siteName,day: day}, function(rdata){
var rdata = $.parseJSON(rdata.data);
if (rdata.logs == "") {
layer.msg("暂无日志记录", {icon: 6,shade: 0.3,time: 1000});
return;
}
_this.site_log_data = rdata.logs;
var con = '';
var logs_len = rdata.logs.length;
for (var i = 0; i < logs_len; i++) {
var txt = '';
switch (rdata.logs[i][1]) {
case 'create':txt = '创建';break;
case 'delete':txt = '删除';break;
case 'modify':txt = '修改';break;
case 'move':txt = '移动';break;
}
con += '<tr>\
<td>' + anti_tamper.timestampToTime(rdata.logs[i][0]) + '</td>\
<td>' + txt + '</td>\
<td>' + rdata.logs[i][2] + '</td>\
<td>' + '<a class="btlink get_traceability_log">溯源日志</a>' + '</td>\
<td >防护成功</td>\
</tr>';
}
$("#LogDayCon").html(con);
$("#logs_len").text(logs_len);
});
},
//获取排除的目录
site_exclude_path: function (siteName,path) {
var con ='<div class="pd15"><div class="anti_rule_add">\
<input style="display:none;" id="select-exclude" value="'+path+'" />\
<textarea id="input-exclude" class="bt-input-text mr5" type="rule" placeholder="排除目录或文件,每行一条" spellcheck="false" style="margin: 0px 5px -10px 0px; width: 449px; height: 68px; line-height: 18px;"></textarea>\
<span style="margin-right: 10px;position: fixed;top: 58px;" class="glyphicon glyphicon-folder-open cursor" onclick="changePath(\'input-exclude\')" title="点击选择文件或目录"></span>\
<button class="btn btn-default btn-sm va0" onclick=\'anti_tamper.add_exclude_path("' + siteName + '","'+path+'",this)\'>添加排除</button>\
</div>\
<div class="anti_rule_list rule_out_box">\
<div class="divtable bt_table">\
<div id="site_exclude_path" style="max-height:320px;overflow:auto;border:#ddd 1px solid">\
<table class="table table-hover" style="border:none">\
<thead>\
<tr>\
<th width="34px">\
<span><label><input type="checkbox" class="cust—checkbox-input" data-checkbox="all"/></label></span>\
</th>\
<th>名称或路径</th>\
<th class="text-right">操作</th>\
</tr>\
</thead>\
<tbody id="site_exclude_path_con"></tbody>\
</table>\
</div>\
<div class="bt_batch mt10">\
<label>\
<input type="checkbox" class="cust—checkbox-input" data-checkbox="all" />\
</label>\
<select class="bt-input-text mr5" name="status" disabled="disabled" style="height:28px;color: #666;" placeholder="请选择批量操作">\
<option style="color: #b6b6b6;display:none;" disabled selected>请选择批量操作</option>\
<option value="1">删除选中</option>\
</select>\
<button class="btn btn-success btn-sm setBatchStatus" disabled="disabled">批量操作</button>\
</div>\
</div>\
</div>\
<ul class="help-info-text c7">\
<li>在此列表中的目录或文件名将不受保护</li>\
<li>可以是目录或文件名称,也可以是完整绝对路径,如: cache或/tmp</li>\
<li>目录或文件名称在完全匹配的情况下生效,绝对路径则使用从左到右匹配成功时生效</li>\
</ul>\
</div>';
layer.open({
type: 1,
title: "排除文件或目录【" + siteName + "】",
area: ['600px', '605px'],
closeBtn: 2,
shadeClose: false,
content: con,
success:function(index,lay){
$("#select-exclude").change(function(){
var exclude = $("#input-exclude").val()
var select_exclude = $(this).val();
$(this).val(path);
if(exclude){
exclude += select_exclude + "\n";
} else {
exclude = select_exclude + "\n";
}
$("#input-exclude").val(exclude);
}
)}
});
anti_tamper.site_exclude_path_post(siteName);
tableFixed("site_exclude_path");
},
site_exclude_path_post: function (siteName, callback) {
var that = this;
var pdata = {siteName: siteName};
appPost('get_site_find',pdata,function (rdata) {
var rdata = $.parseJSON(rdata.data);
var rdata = rdata.data;
var excludeBody = ''
for (var i = 0; i < rdata.excludePath.length; i++) {
excludeBody += '<tr>\
<td><label><input type="checkbox" class="cust—checkbox-input" data-checkbox="'+ i +'"></label></td>\
<td>' + rdata.excludePath[i] +'</td>\
<td class="text-right"><a href=\'javascript:anti_tamper.remove_exclude_path("' + siteName +'","' + rdata.excludePath[i] + '")\' class="btlink">删除</a></td>\
</tr>';
}
$("#site_exclude_path_con").html(excludeBody);
$('.rule_out_box .bt_table .cust—checkbox,.rule_out_box .bt_table .cust—checkbox-input').click(function(){
var checkbox = $(this).data('checkbox'),
length = $('#site_exclude_path tbody tr').length,
active = $(this).prop('checked');
if(checkbox == 'all'){
if(active){
$('.rule_out_box .cust—checkbox-input').addClass('active').prop('checked',true);
$('.rule_out_box .setBatchStatus,.rule_out_box select[name="status"]').removeAttr('disabled');
}else{
$('.rule_out_box .cust—checkbox-input').removeClass('active').prop('checked',false);
$('.rule_out_box .setBatchStatus,.rule_out_box select[name="status"]').attr('disabled','disabled');
}
}else{
if(active){
$(this).addClass('active').prop('checked',true);
$('.rule_out_box .setBatchStatus,.rule_out_box select[name="status"]').removeAttr('disabled');
}else{
$(this).removeClass('active').prop('checked',false);
}
}
var active_length = $('#site_exclude_path tbody tr .cust—checkbox-input.active').length;
if(active_length === length){
$('.rule_out_box [data-checkbox="all"]').addClass('active');
} else if(active_length === 0){
$('.rule_out_box .setBatchStatus,.rule_out_box [name="status"]').attr('disabled','disabled');
} else {
$('.rule_out_box [data-checkbox="all"]').removeClass('active');
}
});
$('.rule_out_box .setBatchStatus').click(function(){
var siteState = parseInt($('.rule_out_box [name="status"]').val());
var rules = [];
$('#site_exclude_path tbody tr .cust—checkbox-input.active').each(function(){
var i = $(this).data('checkbox');
rules.push(rdata.excludePath[i]);
});
if(isNaN(siteState)){
layer.msg({status:false,msg:'请选择批量操作类型'});
return false;
}
layer.confirm('批量删除选中的名称或路径,该操作可能会存在风险,是否继续?',{title: "批量删除",icon: 3,closeBtn: 2}, function () {
that.batch_del_rule_out({siteName:siteName,rule:rules.join(',')});
});
});
if (callback){
callback(rdata);
}
},'正在获取排除列表,请稍候..');
},
//显示受保护的文件类型
site_tmaper_ext: function (siteName,path) {
var con ='<div class="pd15">\
<div class="anti_rule_add">\
<input style="display:none;" id="select-safe" value="'+path+'" />\
<textarea id="input-safe" class="bt-input-text mr5" type="rule" placeholder="受保护的文件或扩展名,每行一条" spellcheck="false" style="margin: 0px 5px -10px 0px; width: 449px; height: 68px; line-height: 18px;"></textarea>\
<span style="margin-right: 10px;position: fixed;top: 58px;" class="glyphicon glyphicon-folder-open cursor" onclick="changePath(\'input-safe\')" title="点击选择文件"></span>\
<button class="btn btn-default btn-sm va0" onclick=\'anti_tamper.add_protect_ext("' + siteName + '","' + path + '",this)\'>添加保护</button>\
</div>\
<div class="anti_rule_list rule_protect_box">\
<div class="divtable bt_table">\
<div id="site_exclude_path" style="max-height:320px;overflow:auto;border:#ddd 1px solid">\
<table class="table table-hover" style="border:none">\
<thead>\
<tr>\
<th width="34px"><span><label>\<input type="checkbox" class="cust—checkbox-input" data-checkbox="all"/></label></span></th>\
<th>扩展名/文件名</th>\
<th class="text-right">操作</th>\
</tr>\
</thead>\
<tbody id="site_exclude_path_con"></tbody>\
</table>\
</div>\
<div class="bt_batch mt10">\
<label>\
<input type="checkbox" class="cust—checkbox-input" data-checkbox="all" />\
</label>\
<select class="bt-input-text mr5" name="status" disabled="disabled" style="height:28px;color: #666;" placeholder="请选择批量操作">\
<option style="color: #b6b6b6;display:none;" disabled selected>请选择批量操作</option>\
<option value="1">删除选中</option>\
</select>\
<button class="btn btn-success btn-sm setBatchStatus" disabled="disabled">批量操作</button>\
</div>\
</div>\
</div>\
<ul class="help-info-text c7">\
<li>可以是文件扩展名(如:php等),也可以是文件名或文件全路径(如: /tmp/1.txt)</li>\
<li>一般添加常见容易被篡改的扩展名即可,如html,php,js等</li>\
</ul>\
</div>';
layer.open({
type: 1,
title: "保护配置【" + siteName + "】",
area: ['600px', '580px'],
closeBtn: 2,
shadeClose: false,
content: con,
success:function(index,lay){
$("#select-safe").change(function(){
var safe = $("#input-safe").val()
var select_safe = $(this).val();
$(this).val(path);
if(safe){
safe += select_safe + "\n";
} else {
safe = select_safe + "\n";
}
$("#input-safe").val(safe);
});
}
});
anti_tamper.site_tmaper_ext_post(siteName);
tableFixed("site_exclude_path");
},
site_tmaper_ext_post: function (siteName, callback) {
var that = this;
var pdata = {siteName: siteName};
appPost('get_site_find',pdata,function (rdata) {
var rdata = $.parseJSON(rdata.data);
var rdata = rdata.data;
var protectBody = ''
for (var i = 0; i < rdata.protectExt.length; i++) {
protectBody += '<tr><td><label><input type="checkbox" class="cust—checkbox-input" data-checkbox="'+ i +'"></label></td><td>' + rdata.protectExt[i] +
'</td><td class="text-right"><a href=\'javascript:anti_tamper.remove_protect_ext("' + siteName +
'","' + rdata.protectExt[i] + '")\' class="btlink">删除</a></td></tr>';
}
$("#site_exclude_path_con").html(protectBody);
$('.rule_protect_box .bt_table .cust—checkbox,.rule_protect_box .bt_table .cust—checkbox-input').click(function(){
var checkbox = $(this).data('checkbox'),
length = $('#site_exclude_path tbody tr').length,
active = $(this).prop('checked'),
active_length;
if(checkbox == 'all'){
if(active){
$('.rule_protect_box .cust—checkbox-input').addClass('active').prop('checked',true);
$('.rule_protect_box .setBatchStatus,.rule_protect_box [name="status"]').removeAttr('disabled');
}else{
$('.rule_protect_box .cust—checkbox-input').removeClass('active').prop('checked',false);
$('.rule_protect_box .setBatchStatus,.rule_protect_box [name="status"]').attr('disabled','disabled');
}
}else{
if(active){
$(this).addClass('active').prop('checked',true);
$('.rule_protect_box .setBatchStatus,.rule_protect_box [name="status"]').removeAttr('disabled');
}else{
$(this).removeClass('active').prop('checked',false);
}
}
active_length = $('#site_exclude_path tbody tr .cust—checkbox-input.active').length;
if(active_length === length){
$('.rule_protect_box [data-checkbox="all"]').addClass('active');
}else if(active_length === 0){
$('.rule_protect_box .setBatchStatus,.rule_protect_box [name="status"]').attr('disabled','disabled');
}else{
$('.rule_protect_box [data-checkbox="all"]').removeClass('active');
}
});
$('.rule_protect_box .setBatchStatus').click(function(){
var siteState = parseInt($('.rule_protect_box [name="status"]').val());
var rules = [];
$('#site_exclude_path tbody tr .cust—checkbox-input.active').each(function(){
var i = $(this).data('checkbox');
rules.push(rdata.protectExt[i]);
});
if(isNaN(siteState)){
layer.msg({status:false,msg:'请选择批量操作类型'});
return false;
}
layer.confirm('批量删除选中的扩展名或文件名,该操作可能会存在风险,是否继续?',{title: "批量删除",icon: 3,closeBtn: 2}, function () {
that.batch_del_ext_name({siteName:siteName,rule:rules.join(',')});
});
});
if (callback) {
callback(rdata);
}
},'正在获取受保护列表,请稍候..');
},
// 批量删除排除规则
batch_del_rule_out:function(config){
appPost('remove_excloud',{siteName:config.siteName,excludePath:config.rule},function(res){
var res = $.parseJSON(res.data);
if(!res.status && typeof res.msg === "string"){
layer.msg(res.msg, {icon: 1});
return false;
}
if(res.status){
anti_tamper.site_exclude_path_post(config.siteName)
layer.msg(res.msg, {icon: 1});
}
},'正在批量删除,请稍侯...');
},
//添加排除目录
add_exclude_path: function (siteName, path, event) {
path = $("#input-exclude").val();
pdata = {siteName: siteName,excludePath: path};
appPost('add_excloud', pdata, function (rdata) {
var rdata = $.parseJSON(rdata.data);
if (rdata.status) {
$(event).prev().val('');
anti_tamper.site_exclude_path_post(siteName, function () {
layer.msg(rdata.msg, {icon: 1});
});
} else {
layer.msg(rdata.msg, {icon: 2});
}
},'正在添加排除目录,请稍候..');
},
//删除排除目录
remove_exclude_path: function (siteName, path) {
pdata = {siteName: siteName,excludePath: path}
appPost('remove_excloud', pdata, function (rdata) {
if (rdata.status) {
$(event).prev().val('');
anti_tamper.site_exclude_path_post(siteName, function () {
layer.msg(rdata.msg, {icon: 1});
});
} else {
layer.msg(rdata.msg, {icon: 2});
}
},'正在删除排除目录,请稍候..');
},
//添加受保护的文件类型
add_protect_ext: function (siteName, ext, event) {
ext = $("#input-safe").val();
pdata = {siteName: siteName,protectExt: ext}
appPost('add_protect_ext',pdata, function (rdata) {
var rdata = $.parseJSON(rdata.data);
if (rdata.status) {
$(event).prev().val('');
anti_tamper.site_tmaper_ext_post(siteName, function () {
layer.msg(rdata.msg, {icon: 1});
});
} else {
layer.msg(rdata.msg, {icon: 2});
}
},'正在添加受保护文件或类型,请稍候..');
},
//删除受保护的文件类型
remove_protect_ext: function (siteName, ext) {
pdata = {siteName: siteName,protectExt: ext};
appPost('remove_protect_ext',pdata, function (rdata) {
var rdata = $.parseJSON(rdata.data);
if (rdata.status) {
$(event).prev().val('');
anti_tamper.site_tmaper_ext_post(siteName, function () {
layer.msg(rdata.msg, {icon: 1});
});
} else {
layer.msg(rdata.msg, {icon: 2});
}
},'正在删除受保护文件类型,请稍候..');
},
// 批量删除保护扩展名/文件名
batch_del_ext_name:function(config){
appPost('remove_protect_ext',{siteName:config.siteName,protectExt:config.rule},function(res){
var res = $.parseJSON(res.data);
if(!res.status && typeof res.msg === "string"){
layer.msg(res.msg, {icon: 1});
return false;
}
if(res.status){
anti_tamper.site_tmaper_ext_post(config.siteName)
layer.msg(res.msg,{icon: 1});
}
},'正在批量删除,请稍侯...');
},
//获取溯源日志
get_traceability_log:function(siteName,item){
layer.open({
type: 1,
title: '溯源日志['+ siteName +']',
area: '700px',
shadeClose: false,
closeBtn: 2,
content: '<div class="setchmod bt-form">'
+ '<pre class="run-log" style="overflow: auto; border: 0px none; line-height:23px;padding: 15px; margin: 0px; white-space: pre-wrap; height: 405px; background-color: rgb(51,51,51);color:#f1f1f1;border-radius:0px;font-family: \"微软雅黑\"">' + (item[3].length == '' ? '当前日志为空' : item[3].join('\n')) + '</pre>'
+ '</div>'
});
},
//取操作日志
operation_log: function (p) {
if (p == undefined) p = 1;
var loadT = layer.msg('正在获取操作日志,请稍候..', {icon: 16,time: 0,shade: 0.3});
$.get('/plugin?action=a&s=get_logs&name=tamper_proof&tojs=anti_tamper.operation_log&p=' + p, function (rdata) {
layer.close(loadT);
var logBody = '';
for (var i = 0; i < rdata.data.length; i++) {
logBody += '<tr><td>' + rdata.data[i].addtime +
'</td><td><span style="width: 605px;" class="nowrap_block" title="' + rdata.data[i].log + '">' +
rdata.data[i].log + '</span></td></tr>'
}
var con = '<div class="anti_rule_list"><div class="divtable">\
<table class="table table-hover">\
<thead>\
<tr><th>时间</th><th>详情</th></tr>\
</thead>\
<tbody>' + logBody + '</tbody>\
</table>\
</div><div class="page" style="margin-top:15px">' + rdata.page + '</div</div>';
$('.anti-tamper-con').html(con);
});
},
// 模拟攻击
sim_test: function (data, callback) {
appPost('sim_test', data, function(rdata){
var rdata = $.parseJSON(rdata.data);
if (rdata.status) {
callback && callback(rdata);
} else {
layer.msg(rdata.msg, { icon: 2 });
}
},'正在模拟攻击,请稍候..');
},
//时间戳转换
timestampToTime: function (date) {
var date = new Date(date * 1000);
var Y = date.getFullYear() + '-';
var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
var D = (date.getDate() < 10 ? '0' + (date.getDate()) : date.getDate()) + ' ';
var h = (date.getHours() < 10 ? '0' + date.getHours() : date.getHours()) + ':';
var m = (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes()) + ':';
var s = (date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds());
return Y + M + D + h + m + s;
},
//定义周期时间
getBeforeDate: function (n) {
var n = n;
var d = new Date();
var year = d.getFullYear();
var mon = d.getMonth() + 1;
var day = d.getDate();
if (day <= n) {
if (mon > 1) {
mon = mon - 1;
} else {
year = year - 1;
mon = 12;
}
}
d.setDate(d.getDate() - n);
year = d.getFullYear();
mon = d.getMonth() + 1;
day = d.getDate();
s = year + "-" + (mon < 10 ? ('0' + mon) : mon) + "-" + (day < 10 ? ('0' + day) : day);
return s;
}
/// END
}
anti_tamper.get_day();
anti_tamper.get_speed();
</script>