新增百度云、火山引擎

This commit is contained in:
net909 2024-08-24 19:42:31 +08:00
parent 0d1d7d3c67
commit b8addd6d27
13 changed files with 450 additions and 24 deletions

View File

@ -362,6 +362,10 @@ class Domain extends BaseController
$row['LineName'] = isset($recordLine[$row['Line']]) ? $recordLine[$row['Line']]['name'] : $row['Line']; $row['LineName'] = isset($recordLine[$row['Line']]) ? $recordLine[$row['Line']]['name'] : $row['Line'];
} }
if($dns->type == 'baidu'){
return json($domainRecords['list']);
}
return json(['total'=>$domainRecords['total'], 'rows'=>$domainRecords['list']]); return json(['total'=>$domainRecords['total'], 'rows'=>$domainRecords['list']]);
} }

View File

@ -39,6 +39,17 @@ class DnsHelper
'redirect' => false, 'redirect' => false,
'log' => false, 'log' => false,
], ],
'baidu' => [
'name' => '百度云',
'config' => [
'ak' => 'AccessKey',
'sk' => 'SecretKey'
],
'remark' => 2,
'status' => false,
'redirect' => false,
'log' => false,
],
'west' => [ 'west' => [
'name' => '西部数码', 'name' => '西部数码',
'config' => [ 'config' => [
@ -50,6 +61,17 @@ class DnsHelper
'redirect' => false, 'redirect' => false,
'log' => false, 'log' => false,
], ],
'huoshan' => [
'name' => '火山引擎',
'config' => [
'ak' => 'AccessKeyId',
'sk' => 'SecretAccessKey'
],
'remark' => 2,
'status' => true,
'redirect' => false,
'log' => false,
],
'dnsla' => [ 'dnsla' => [
'name' => 'DNSLA', 'name' => 'DNSLA',
'config' => [ 'config' => [
@ -95,6 +117,7 @@ class DnsHelper
$config['domain'] = $domain; $config['domain'] = $domain;
$config['domainid'] = $domainid; $config['domainid'] = $domainid;
$model = new $class($config); $model = new $class($config);
$model->type = $dnstype;
return $model; return $model;
} }
return false; return false;
@ -108,6 +131,7 @@ class DnsHelper
$config['domain'] = $config['name']; $config['domain'] = $config['name'];
$config['domainid'] = $config['thirdid']; $config['domainid'] = $config['thirdid'];
$model = new $class($config); $model = new $class($config);
$model->type = $dnstype;
return $model; return $model;
} }
return false; return false;

View File

@ -13,6 +13,8 @@ class OptimizeService
'huawei' => ['DEF'=>'default_view', 'CT'=>'Dianxin', 'CU'=>'Liantong', 'CM'=>'Yidong', 'AB'=>'Abroad'], 'huawei' => ['DEF'=>'default_view', 'CT'=>'Dianxin', 'CU'=>'Liantong', 'CM'=>'Yidong', 'AB'=>'Abroad'],
'west' => ['DEF'=>'', 'CT'=>'LTEL', 'CU'=>'LCNC', 'CM'=>'LMOB', 'AB'=>'LFOR'], 'west' => ['DEF'=>'', 'CT'=>'LTEL', 'CU'=>'LCNC', 'CM'=>'LMOB', 'AB'=>'LFOR'],
'dnsla' => ['DEF'=>'', 'CT'=>'84613316902921216', 'CU'=>'84613316923892736', 'CM'=>'84613316953252864', 'AB'=>''], 'dnsla' => ['DEF'=>'', 'CT'=>'84613316902921216', 'CU'=>'84613316923892736', 'CM'=>'84613316953252864', 'AB'=>''],
'huoshan' => ['DEF'=>'default', 'CT'=>'telecom', 'CU'=>'unicom', 'CM'=>'mobile', 'AB'=>'oversea'],
'baidu' => ['DEF'=>'default', 'CT'=>'ct', 'CU'=>'cnc', 'CM'=>'cmnet', 'AB'=>''],
]; ];
private $ip_address = []; private $ip_address = [];

View File

@ -50,8 +50,8 @@ class baidu implements DnsInterface {
//获取解析记录列表 //获取解析记录列表
public function getDomainRecords($PageNumber=1, $PageSize=20, $KeyWord = null, $SubDomain = null, $Value = null, $Type = null, $Line = null, $Status = null){ public function getDomainRecords($PageNumber=1, $PageSize=20, $KeyWord = null, $SubDomain = null, $Value = null, $Type = null, $Line = null, $Status = null){
$query = ['rr' => $KeyWord]; $query = ['rr' => $KeyWord];
if(!isNullOrEmpty(($SubDomain))){ if(!isNullOrEmpty($SubDomain)){
$param['rr'] = $SubDomain; $query['rr'] = $SubDomain;
} }
$data = $this->send_reuqest('GET', '/v1/dns/zone/'.$this->domain.'/record', $query); $data = $this->send_reuqest('GET', '/v1/dns/zone/'.$this->domain.'/record', $query);
if($data){ if($data){

View File

@ -91,7 +91,7 @@ class dnspod implements DnsInterface {
]; ];
} }
return ['total' => $data['RecordCountInfo']['TotalCount'], 'list' => $list]; return ['total' => $data['RecordCountInfo']['TotalCount'], 'list' => $list];
}elseif($this->error == '记录列表为空。'){ }elseif($this->error == '记录列表为空。' || $this->error == 'No records on the list.'){
return ['total' => 0, 'list' => []]; return ['total' => 0, 'list' => []];
} }
return false; return false;

383
app/lib/dns/huoshan.php Normal file
View File

@ -0,0 +1,383 @@
<?php
namespace app\lib\dns;
use app\lib\DnsInterface;
class huoshan implements DnsInterface {
private $AccessKeyId;
private $SecretAccessKey;
private $endpoint = "open.volcengineapi.com";
private $service = "DNS";
private $version = "2018-08-01";
private $region = "cn-north-1";
private $error;
private $domain;
private $domainid;
private $domainInfo;
private static $trade_code_list = [
'free_inner' => ['level' => 1, 'name' => '免费版', 'ttl' => 600],
'professional_inner' => ['level' => 2, 'name' => '专业版', 'ttl' => 300],
'enterprise_inner' => ['level' => 3, 'name' => '企业版', 'ttl' => 60],
'ultimate_inner' => ['level' => 4, 'name' => '旗舰版', 'ttl' => 1],
'ultimate_exclusive_inner' => ['level' => 5, 'name' => '尊享版', 'ttl' => 1],
];
function __construct($config){
$this->AccessKeyId = $config['ak'];
$this->SecretAccessKey = $config['sk'];
$this->domain = $config['domain'];
$this->domainid = $config['domainid'];
}
public function getError(){
return $this->error;
}
public function check(){
if($this->getDomainList() != false){
return true;
}
return false;
}
//获取域名列表
public function getDomainList($KeyWord=null, $PageNumber=1, $PageSize=20){
$query = ['PageNumber' => $PageNumber, 'PageSize' => $PageSize, 'Key' => $KeyWord];
$data = $this->send_reuqest('GET', 'ListZones', $query);
if($data){
$list = [];
if(!empty($data['Zones'])){
foreach($data['Zones'] as $row){
$list[] = [
'DomainId' => $row['ZID'],
'Domain' => $row['ZoneName'],
'RecordCount' => $row['RecordCount'],
];
}
}
return ['total' => $data['Total'], 'list' => $list];
}
return false;
}
//获取解析记录列表
public function getDomainRecords($PageNumber=1, $PageSize=20, $KeyWord = null, $SubDomain = null, $Value = null, $Type = null, $Line = null, $Status = null){
$query = ['ZID' => intval($this->domainid), 'PageNumber' => $PageNumber, 'PageSize' => $PageSize, 'SearchOrder' => 'desc'];
if(!empty($SubDomain) || !empty($Type) || !empty($Line) || !empty($Value)){
$query += ['Host' => $SubDomain, 'Value' => $Value, 'Type' => $Type, 'Line' => $Line];
}elseif(!empty($KeyWord)){
$query += ['Host' => $KeyWord];
}
$data = $this->send_reuqest('GET', 'ListRecords', $query);
if($data){
$list = [];
foreach($data['Records'] as $row){
$list[] = [
'RecordId' => $row['RecordID'],
'Domain' => $this->domain,
'Name' => $row['Host'],
'Type' => $row['Type'],
'Value' => $row['Value'],
'Line' => $row['Line'],
'TTL' => $row['TTL'],
'MX' => $row['Weight'],
'Status' => $row['Enable'] ? '1' : '0',
'Weight' => $row['Weight'],
'Remark' => $row['Remark'],
'UpdateTime' => $row['UpdatedAt'],
];
}
return ['total' => $data['TotalCount'], 'list' => $list];
}
return false;
}
//获取子域名解析记录列表
public function getSubDomainRecords($SubDomain, $PageNumber=1, $PageSize=20, $Type = null, $Line = null){
return $this->getDomainRecords($PageNumber, $PageSize, null, $SubDomain, null, $Type, $Line);
}
//获取解析记录详细信息
public function getDomainRecordInfo($RecordId){
$data = $this->send_reuqest('GET', 'QueryRecord', ['RecordID' => $RecordId]);
if($data){
if($data['name'] == $data['zone_name']) $data['name'] = '@';
return [
'RecordId' => $data['RecordID'],
'Domain' => $this->domain,
'Name' => $data['Host'],
'Type' => $data['Type'],
'Value' => $data['Value'],
'Line' => $data['Line'],
'TTL' => $data['TTL'],
'MX' => $data['Weight'],
'Status' => $data['Enable'] ? '1' : '0',
'Weight' => $data['Weight'],
'Remark' => $data['Remark'],
'UpdateTime' => $data['UpdatedAt'],
];
}
return false;
}
//添加解析记录
public function addDomainRecord($Name, $Type, $Value, $Line = '0', $TTL = 600, $MX = 1, $Remark = null){
$params = ['ZID' => intval($this->domainid), 'Host' => $Name, 'Type' => $this->convertType($Type), 'Value' => $Value, 'Line'=>$Line, 'TTL' => intval($TTL), 'Remark' => $Remark];
if($Type == 'MX')$param['Weight'] = intval($MX);
$data = $this->send_reuqest('POST', 'CreateRecord', $params);
return is_array($data) ? $data['RecordID'] : false;
}
//修改解析记录
public function updateDomainRecord($RecordId, $Name, $Type, $Value, $Line = '0', $TTL = 600, $MX = 1, $Remark = null){
$params = ['RecordID' => $RecordId, 'Host' => $Name, 'Type' => $this->convertType($Type), 'Value' => $Value, 'Line'=>$Line, 'TTL' => intval($TTL), 'Remark' => $Remark];
if($Type == 'MX')$param['Weight'] = intval($MX);
$data = $this->send_reuqest('POST', 'UpdateRecord', $params);
return is_array($data);
}
//修改解析记录备注
public function updateDomainRecordRemark($RecordId, $Remark){
return false;
}
//删除解析记录
public function deleteDomainRecord($RecordId){
$data = $this->send_reuqest('POST', 'DeleteRecord', ['RecordID' => $RecordId]);
return $data;
}
//设置解析记录状态
public function setDomainRecordStatus($RecordId, $Status){
$params = ['RecordID' => $RecordId, 'Enable' => $Status == '1'];
$data = $this->send_reuqest('POST', 'UpdateRecordStatus', $params);
return is_array($data);
}
//获取解析记录操作日志
public function getDomainRecordLog($PageNumber = 1, $PageSize = 20, $KeyWord = null, $StartDate = null, $endDate = null){
return false;
}
//获取解析线路列表
public function getRecordLine(){
$domainInfo = $this->getDomainInfo();
if(!$domainInfo) return false;
$level = $this->getTradeInfo($domainInfo['TradeCode'])['level'];
$data = $this->send_reuqest('GET', 'ListLines', []);
if($data){
$list = [];
$list['default'] = ['name' => '默认', 'parent' => null];
foreach($data['Lines'] as $row){
if($row['Value'] == 'default') continue;
if($row['Level'] > $level) continue;
$list[$row['Value']] = ['name' => $row['Name'], 'parent' => isset($row['FatherValue']) ? $row['FatherValue'] : null];
}
$data = $this->send_reuqest('GET', 'ListCustomLines', []);
if($data && $data['TotalCount'] > 0){
$list['N.customer_lines'] = ['name' => '自定义线路', 'parent' => null];
foreach($data['CustomerLines'] as $row){
$list[$row['Line']] = ['name' => $row['NameCN'], 'parent' => 'N.customer_lines'];
}
}
return $list;
}
return false;
}
//获取域名概览信息
public function getDomainInfo(){
if(!empty($this->domainInfo)) return $this->domainInfo;
$query = ['ZID' => intval($this->domainid)];
$data = $this->send_reuqest('GET', 'QueryZone', $query);
if($data){
$this->domainInfo = $data;
return $data;
}
return false;
}
//获取域名最低TTL
public function getMinTTL(){
$domainInfo = $this->getDomainInfo();
if($domainInfo){
$ttl = $this->getTradeInfo($domainInfo['TradeCode'])['ttl'];
return $ttl;
}
return false;
}
private function convertType($type){
return $type;
}
private function getTradeInfo($trade_code){
if(array_key_exists($trade_code, self::$trade_code_list)){
$trade_code = $trade_code;
}else{
$trade_code = 'free_inner';
}
return self::$trade_code_list[$trade_code];
}
private function send_reuqest($method, $action, $params = []){
if(!empty($params)){
$params = array_filter($params, function($a){ return $a!==null;});
}
$query = [
'Action' => $action,
'Version' => $this->version,
];
$body = '';
if($method == 'GET'){
$query = array_merge($query, $params);
}else{
$body = !empty($params) ? json_encode($params) : '';
}
$time = time();
$headers = [
'Host' => $this->endpoint,
'X-Date' => gmdate("Ymd\THis\Z", $time),
//'X-Content-Sha256' => hash("sha256", $body),
];
if($body){
$headers['Content-Type'] = 'application/json';
}
$path = '/';
$authorization = $this->generateSign($method, $path, $query, $headers, $body, $time);
$headers['Authorization'] = $authorization;
$url = 'https://'.$this->endpoint.$path.'?'.http_build_query($query);
$header = [];
foreach($headers as $key => $value){
$header[] = $key.': '.$value;
}
return $this->curl($method, $url, $body, $header);
}
private function generateSign($method, $path, $query, $headers, $body, $time){
$algorithm = "HMAC-SHA256";
// step 1: build canonical request string
$httpRequestMethod = $method;
$canonicalUri = $path;
if(substr($canonicalUri, -1) != "/") $canonicalUri .= "/";
$canonicalQueryString = $this->getCanonicalQueryString($query);
[$canonicalHeaders, $signedHeaders] = $this->getCanonicalHeaders($headers);
$hashedRequestPayload = hash("sha256", $body);
$canonicalRequest = $httpRequestMethod."\n"
.$canonicalUri."\n"
.$canonicalQueryString."\n"
.$canonicalHeaders."\n"
.$signedHeaders."\n"
.$hashedRequestPayload;
// step 2: build string to sign
$date = gmdate("Ymd\THis\Z", $time);
$shortDate = substr($date, 0, 8);
$credentialScope = $shortDate . '/' .$this->region . '/' . $this->service . '/request';
$hashedCanonicalRequest = hash("sha256", $canonicalRequest);
$stringToSign = $algorithm."\n"
.$date."\n"
.$credentialScope."\n"
.$hashedCanonicalRequest;
// step 3: sign string
$kDate = hash_hmac("sha256", $shortDate, $this->SecretAccessKey, true);
$kRegion = hash_hmac("sha256", $this->region, $kDate, true);
$kService = hash_hmac("sha256", $this->service, $kRegion, true);
$kSigning = hash_hmac("sha256", "request", $kService, true);
$signature = hash_hmac("sha256", $stringToSign, $kSigning);
// step 4: build authorization
$credential = $this->AccessKeyId . '/' . $shortDate . '/' . $this->region . '/' . $this->service . '/request';
$authorization = $algorithm . ' Credential=' . $credential . ", SignedHeaders=" . $signedHeaders . ", Signature=" . $signature;
return $authorization;
}
private function escape($str)
{
$search = ['+', '*', '%7E'];
$replace = ['%20', '%2A', '~'];
return str_replace($search, $replace, urlencode($str));
}
private function getCanonicalQueryString($parameters)
{
if(empty($parameters)) return '';
ksort($parameters);
$canonicalQueryString = '';
foreach ($parameters as $key => $value) {
$canonicalQueryString .= '&' . $this->escape($key). '=' . $this->escape($value);
}
return substr($canonicalQueryString, 1);
}
private function getCanonicalHeaders($oldheaders){
$headers = array();
foreach ($oldheaders as $key => $value) {
$headers[strtolower($key)] = trim($value);
}
ksort($headers);
$canonicalHeaders = '';
$signedHeaders = '';
foreach ($headers as $key => $value) {
$canonicalHeaders .= $key . ':' . $value . "\n";
$signedHeaders .= $key . ';';
}
$signedHeaders = substr($signedHeaders, 0, -1);
return [$canonicalHeaders, $signedHeaders];
}
private function curl($method, $url, $body, $header){
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);
if(!empty($body)){
curl_setopt($ch, CURLOPT_POSTFIELDS, $body);
}
$response = curl_exec($ch);
$errno = curl_errno($ch);
if ($errno) {
$this->setError('Curl error: ' . curl_error($ch));
}
curl_close($ch);
if ($errno) return false;
$arr=json_decode($response,true);
if($arr){
if(isset($arr['ResponseMetadata']['Error']['MessageCN'])){
$this->setError($arr['ResponseMetadata']['Error']['MessageCN']);
return false;
}elseif(isset($arr['ResponseMetadata']['Error']['Message'])){
$this->setError($arr['ResponseMetadata']['Error']['Message']);
return false;
}elseif(isset($arr['Result'])){
return $arr['Result'];
}else{
return true;
}
}else{
$this->setError('返回数据解析失败');
return false;
}
}
private function setError($message){
$this->error = $message;
//file_put_contents('logs.txt',date('H:i:s').' '.$message."\r\n", FILE_APPEND);
}
}

View File

@ -198,7 +198,7 @@ function save(){
}, function(){ }, function(){
layer.closeAll(); layer.closeAll();
$("#modal-store").modal('hide'); $("#modal-store").modal('hide');
searchSubmit(); searchRefresh();
}); });
}else{ }else{
layer.alert(data.msg, {icon: 2}) layer.alert(data.msg, {icon: 2})
@ -220,7 +220,7 @@ function delItem(id) {
layer.close(ii); layer.close(ii);
if(data.code == 0){ if(data.code == 0){
layer.closeAll(); layer.closeAll();
searchSubmit(); searchRefresh();
}else{ }else{
layer.alert(data.msg, {icon: 2}); layer.alert(data.msg, {icon: 2});
} }

View File

@ -244,7 +244,7 @@ function saveAdd(){
}, function(){ }, function(){
layer.closeAll(); layer.closeAll();
$("#modal-store").modal('hide'); $("#modal-store").modal('hide');
searchSubmit(); searchRefresh();
}); });
}else{ }else{
layer.alert(data.msg, {icon: 2}) layer.alert(data.msg, {icon: 2})
@ -289,7 +289,7 @@ function saveEdit(){
}, function(){ }, function(){
layer.closeAll(); layer.closeAll();
$("#modal-store2").modal('hide'); $("#modal-store2").modal('hide');
searchSubmit(); searchRefresh();
}); });
}else{ }else{
layer.alert(data.msg, {icon: 2}) layer.alert(data.msg, {icon: 2})
@ -311,7 +311,7 @@ function delItem(id) {
layer.close(ii); layer.close(ii);
if(data.code == 0){ if(data.code == 0){
layer.closeAll(); layer.closeAll();
searchSubmit(); searchRefresh();
}else{ }else{
layer.alert(data.msg, {icon: 2}); layer.alert(data.msg, {icon: 2});
} }

View File

@ -225,11 +225,12 @@ td{overflow: hidden;text-overflow: ellipsis;white-space: nowrap;max-width:360px;
<script src="{$cdnpublic}bootstrap-table/1.21.4/bootstrap-table.min.js"></script> <script src="{$cdnpublic}bootstrap-table/1.21.4/bootstrap-table.min.js"></script>
<script src="{$cdnpublic}bootstrap-table/1.21.4/extensions/page-jump-to/bootstrap-table-page-jump-to.min.js"></script> <script src="{$cdnpublic}bootstrap-table/1.21.4/extensions/page-jump-to/bootstrap-table-page-jump-to.min.js"></script>
<script src="/static/js/bootstrapValidator.min.js"></script> <script src="/static/js/bootstrapValidator.min.js"></script>
<script src="/static/js/custom.js?v=1002"></script> <script src="/static/js/custom.js?v=1003"></script>
<script> <script>
var recordLine = {$recordLine|json_encode|raw}; var recordLine = {$recordLine|json_encode|raw};
var dnsconfig = {$dnsconfig|json_encode|raw}; var dnsconfig = {$dnsconfig|json_encode|raw};
var defaultLine = recordLine[0].id; var defaultLine = recordLine[0].id;
var sidePagination = dnsconfig.type == 'baidu' ? 'client' : 'server';
$(document).ready(function(){ $(document).ready(function(){
updateToolbar(); updateToolbar();
let defaultPageSize = getCookie('record_pagesize') ? getCookie('record_pagesize') : 15; let defaultPageSize = getCookie('record_pagesize') ? getCookie('record_pagesize') : 15;
@ -242,7 +243,7 @@ $(document).ready(function(){
pageSize: pageSize, pageSize: pageSize,
classes: 'table table-striped table-hover table-bordered', classes: 'table table-striped table-hover table-bordered',
uniqueId: 'RecordId', uniqueId: 'RecordId',
sidePagination: "{if $dnsconfig.type=='baidu'}client{else}server{/if}", sidePagination: sidePagination,
columns: [ columns: [
{ {
field: '', field: '',
@ -436,7 +437,7 @@ function save(){
}, function(){ }, function(){
layer.closeAll(); layer.closeAll();
$("#modal-store").modal('hide'); $("#modal-store").modal('hide');
searchSubmit(); searchRefresh();
}); });
}else{ }else{
layer.alert(data.msg, {icon: 2}) layer.alert(data.msg, {icon: 2})
@ -456,7 +457,7 @@ function setStatus(recordid, status){
if(data.code == 0){ if(data.code == 0){
layer.closeAll(); layer.closeAll();
layer.msg(status=='1'?'开启成功':'暂停成功', {icon: 1, time:500}); layer.msg(status=='1'?'开启成功':'暂停成功', {icon: 1, time:500});
searchSubmit(); searchRefresh();
}else{ }else{
layer.alert(data.msg, {icon: 2}); layer.alert(data.msg, {icon: 2});
} }
@ -478,7 +479,7 @@ function delItem(recordid) {
if(data.code == 0){ if(data.code == 0){
layer.closeAll(); layer.closeAll();
layer.msg('删除成功', {icon: 1, time:800}); layer.msg('删除成功', {icon: 1, time:800});
searchSubmit(); searchRefresh();
}else{ }else{
layer.alert(data.msg, {icon: 2}); layer.alert(data.msg, {icon: 2});
} }
@ -510,7 +511,7 @@ function setRemark(recordid) {
if(data.code == 0){ if(data.code == 0){
layer.closeAll(); layer.closeAll();
layer.msg('保存成功', {icon: 1, time:800}); layer.msg('保存成功', {icon: 1, time:800});
searchSubmit(); searchRefresh();
}else{ }else{
layer.alert(data.msg, {icon:2}); layer.alert(data.msg, {icon:2});
} }
@ -570,7 +571,7 @@ function operation(action){
if(data.code == 0){ if(data.code == 0){
layer.closeAll(); layer.closeAll();
layer.alert(data.msg, {icon: 1}); layer.alert(data.msg, {icon: 1});
searchSubmit(); searchRefresh();
}else{ }else{
layer.alert(data.msg, {icon: 2}); layer.alert(data.msg, {icon: 2});
} }
@ -612,7 +613,7 @@ function batch_save(){
}, function(){ }, function(){
layer.closeAll(); layer.closeAll();
$("#modal-store2").modal('hide'); $("#modal-store2").modal('hide');
searchSubmit(); searchRefresh();
}); });
}else{ }else{
layer.alert(data.msg, {icon: 2}) layer.alert(data.msg, {icon: 2})
@ -642,7 +643,7 @@ function batch_save_line(){
}, function(){ }, function(){
layer.closeAll(); layer.closeAll();
$("#modal-store3").modal('hide'); $("#modal-store3").modal('hide');
searchSubmit(); searchRefresh();
}); });
}else{ }else{
layer.alert(data.msg, {icon: 2}) layer.alert(data.msg, {icon: 2})
@ -673,7 +674,7 @@ function batch_edit_remark(recordids) {
closeBtn: false closeBtn: false
}, function(){ }, function(){
layer.closeAll(); layer.closeAll();
searchSubmit(); searchRefresh();
}); });
}, },
error:function(data){ error:function(data){

View File

@ -253,7 +253,7 @@ function save(){
}, function(){ }, function(){
layer.closeAll(); layer.closeAll();
$("#modal-store").modal('hide'); $("#modal-store").modal('hide');
searchSubmit(); searchRefresh();
}); });
}else{ }else{
layer.alert(data.msg, {icon: 2}) layer.alert(data.msg, {icon: 2})
@ -271,7 +271,7 @@ function setStatus(id,status) {
success : function(data) { success : function(data) {
layer.close(ii); layer.close(ii);
if(data.code == 0){ if(data.code == 0){
searchSubmit(); searchRefresh();
}else{ }else{
layer.msg(data.msg, {icon:2, time:1500}); layer.msg(data.msg, {icon:2, time:1500});
} }
@ -292,7 +292,7 @@ function delItem(id) {
layer.close(ii); layer.close(ii);
if(data.code == 0){ if(data.code == 0){
layer.closeAll(); layer.closeAll();
searchSubmit(); searchRefresh();
}else{ }else{
layer.alert(data.msg, {icon: 2}); layer.alert(data.msg, {icon: 2});
} }

View File

@ -31,7 +31,7 @@ return [
'show_error_msg' => true, 'show_error_msg' => true,
'exception_tmpl' => \think\facade\App::getAppPath() . 'view/exception.tpl', 'exception_tmpl' => \think\facade\App::getAppPath() . 'view/exception.tpl',
'version' => '1012', 'version' => '1013',
'dbversion' => '1011' 'dbversion' => '1011'
]; ];

Binary file not shown.

After

Width:  |  Height:  |  Size: 68 KiB

View File

@ -14,8 +14,16 @@ if (parameter_str !== undefined) {
window.$_GET = []; window.$_GET = [];
} }
function searchRefresh(){
$('#listTable').bootstrapTable('refresh');
return false;
}
function searchSubmit(){ function searchSubmit(){
$('#listTable').bootstrapTable('selectPage', 1); if(typeof sidePagination != 'undefined' && sidePagination == 'client'){
$('#listTable').bootstrapTable('refresh');
}else{
$('#listTable').bootstrapTable('selectPage', 1);
}
return false; return false;
} }
function searchClear(){ function searchClear(){
@ -25,7 +33,11 @@ function searchClear(){
$('#searchToolbar').find('select[name]').each(function() { $('#searchToolbar').find('select[name]').each(function() {
$(this).find('option:first').prop("selected", 'selected'); $(this).find('option:first').prop("selected", 'selected');
}); });
$('#listTable').bootstrapTable('selectPage', 1); if(typeof sidePagination != 'undefined' && sidePagination == 'client'){
$('#listTable').bootstrapTable('refresh');
}else{
$('#listTable').bootstrapTable('selectPage', 1);
}
} }
function updateToolbar(){ function updateToolbar(){
$('#searchToolbar').find(':input[name]').each(function() { $('#searchToolbar').find(':input[name]').each(function() {