乖兔博客

乖兔 > CMS系统 > 微擎Could not resolve host: cloud.zhifun.cc; Unknown error错误解决方法

微擎Could not resolve host: cloud.zhifun.cc; Unknown error错误解决方法

乖兔 更新于: 2020-11-26 分类:CMS系统 评论 ( 0 )

微擎Could not resolve host cloud.zhifun.cc Unknown error错误解决方法.jpg

安装微擎离线版的朋友最近应该都会遇到一个问题,在安装插件的时候出现“Could not resolve host: cloud.zhifun.cc; Unknown error”的错误提示,无法继续安装。出现这个错误的原因是因为cloud.zhifun.cc已经无法访问。

所以,解决这个问题的方法就是直接屏蔽这个域名即可。可以手动去\framework\model目录下的cloud.mod.php文件中注释掉相关代码货直接复制下面代码覆盖掉原文件里的全部代码。

<?php
/**
 * [WeEngine System] Copyright (c) 2014 WE7.CC
 * WeEngine is NOT a free software, it under the license terms, visited http://www.we7.cc/ for more details.
 */
defined('IN_IA') or exit('Access Denied');
$_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
define('CLOUD_GATEWAY_URL', $_URLTYPE.$_SERVER['HTTP_HOST']);
define('CLOUD_GATEWAY_URL_NORMAL', $_URLTYPE.$_SERVER['HTTP_HOST']);
function cloud_client_define() {
    return array(
        '/framework/function/communication.func.php',
        '/framework/model/cloud.mod.php',
        '/web/source/cloud/upgrade.ctrl.php',
        '/web/source/cloud/process.ctrl.php',
        '/web/source/cloud/dock.ctrl.php',
        '/web/themes/default/cloud/upgrade.html',
        '/web/themes/default/cloud/process.html'
    );
}
  
  
function _cloud_build_params($must_authorization_host = true) {
    global $_W;
    $pars = array();
    $pars['host'] = strexists($_SERVER['HTTP_HOST'], ':') ? parse_url($_SERVER['HTTP_HOST'], PHP_URL_HOST) : $_SERVER['HTTP_HOST'];
    if (is_array($_W['setting']['site']) && !empty($_W['setting']['site']['url']) && $must_authorization_host) {
        $pars['host'] = parse_url($_W['setting']['site']['url'], PHP_URL_HOST);
    }
    $pars['https'] = $_W['ishttps'] ? 1 : 0;
    $pars['family'] = IMS_FAMILY;
    $pars['version'] = IMS_VERSION;
    $pars['php_version'] = PHP_VERSION;
    $pars['current_host'] = $_SERVER['HTTP_HOST'];
    $pars['release'] = IMS_RELEASE_DATE;
    if (!empty($_W['setting']['site'])) {
        $pars['key'] = $_W['setting']['site']['key'];
        $pars['password'] = md5($_W['setting']['site']['key'] . $_W['setting']['site']['token']);
    }
    $clients = cloud_client_define();
    $string = '';
    foreach($clients as $cli) {
        $string .= md5_file(IA_ROOT . $cli);
    }
    $pars['client'] = md5($string);
    return $pars;
}
  
function _cloud_shipping_parse($dat, $file) {
        /*if (is_error($dat)) {
        return error(-1, '网络传输故障,详情: ' . (strpos($dat['message'], 'Connection reset by peer') ? '云服务瞬时访问过大而导致网络传输中断,请稍后重试。' : $dat['message']));
    }
    $tmp = iunserializer($dat['content']);
    if (is_array($tmp) && is_error($tmp)) {
        if ($tmp['errno'] == '-2') {
            file_put_contents(IA_ROOT . '/framework/version.inc.php', str_replace("'x'", "'v'", file_get_contents(IA_ROOT . '/framework/version.inc.php')));
        }
        return $tmp;
    }
    if ($dat['content'] == 'patching') {
        return error(-1, '补丁程序正在更新中,请稍后再试!');
    }
    if ($dat['content'] == 'frequent') {
        return error(-1, '更新操作太频繁,请稍后再试!');
    }
    if ($dat['content'] == 'blacklist') {
        return error(-1, '抱歉,您的站点已被列入云服务黑名单,云服务一切业务已被禁止,请联系微擎客服!');
    }
    if ($dat['content'] == 'install-theme-protect' || $dat['content'] == 'install-module-protect') {
        return error('-1', '此' . ($dat['content'] == 'install-theme-protect' ? '模板' : '模块') . '已设置版权保护,您只能通过云平台来安装,请先删除该模块的所有文件,购买后再行安装。');
    }
  
    $content = json_decode($dat['content'], true);
    if (!empty($content['error'])) {
        return error(-1, $content['error']);
    }
    if (!empty($content) && is_array($content)) {
        return $content;
    }
  
    if (strlen($dat['content']) != 32) {
        $dat['content'] = iunserializer($dat['content']);
        if (is_array($dat['content']) && isset($dat['content']['files'])) {
            if (!empty($dat['content']['manifest'])) {
                $dat['content']['manifest'] = base64_decode($dat['content']['manifest']);
            }
            if (!empty($dat['content']['scripts'])) {
                $dat['content']['scripts'] = base64_decode($dat['content']['scripts']);
            }
            return $dat['content'];
        }
        if (is_array($dat['content']) && isset($dat['content']['data'])) {
            $data = $dat['content'];
        } else {
            return error(-1, '云服务平台向您的服务器传输数据过程中出现错误,详情:' . $dat['content']);
        }
    } else {
        $data = @file_get_contents($file);
        @unlink($file);
    }
      
    $ret = @iunserializer($data);
    if (empty($data) || empty($ret)) {
        return error(-1, '云服务平台向您的服务器传输的数据校验失败,请稍后重试.');
    }
    $ret = iunserializer($ret['data']);
    if (is_array($ret) && is_error($ret)) {
        if ($ret['errno'] == '-2') {
            file_put_contents(IA_ROOT . '/framework/version.inc.php', str_replace("'x'", "'v'", file_get_contents(IA_ROOT . '/framework/version.inc.php')));
        }
        if ($ret['errno'] == '-3') {            return array(
                'errno' => $ret['errno'],
                'message' => $ret['message'],
                'cloud_id' => $ret['data'],
            );
        }
    }
    if (!is_error($ret) && is_array($ret)) {
        if (!empty($ret) && $ret['state'] == 'fatal') {
            return error($ret['errorno'], '发生错误: ' . $ret['message']);
        }
        return $ret;
    } else {
        return error($ret['errno'], "发生错误: {$ret['message']}");
    }*/
    return array();
}
  
function cloud_request($url, $post = '', $extra = array(), $timeout = 60) {
    global $_W;
    load()->func('communication');
    if (!empty($_W['setting']['cloudip']['ip']) && empty($extra['ip'])) {
//  $extra['ip'] = $_W['setting']['cloudip']['ip'];
        $extra['ip'] = $_SERVER['HTTP_HOST'];
    }
/*  if (strexists($url, 's.w7.cc')) {
        $extra = array();
    }
    $response = ihttp_request($url, $post, $extra, $timeout);
    if (is_error($response)) {
        setting_save(array(), 'cloudip');
    }
    return $response;
*/
    return array();
}
function local_salt($length = 8) {
    $result = '';
    while(strlen($result) < $length) {
        $result .= sha1(uniqid('', true));
    }
    return substr($result, 0, $length);
}
  
function cloud_api($method, $data = array(), $extra = array(), $timeout = 60) {
    if ($method == 'site/register/profile') {
        $pars = _cloud_build_params();
                $_URLTYPE = $pars['https'] ? 'https://' : 'http://';
                $tmp1 =  $pars['key'] ? $pars['key'] : local_salt(6);
                $tmp2 =  $_URLTYPE . $pars['host'];
                $site_tmp = array (  'key' => $tmp1,  'token' => md5($tmp1),  'url' => $tmp2,  'version' => $pars['version'],  'family' => $pars['family'],  'type' => 'register',);
                //$site_tmp = serialize($site_tmp);
                pdo_update('core_settings', array('value' => iserializer($site_tmp)), array('key' => 'site'));
                cache_updatecache();
  
    }
/*  $cache_key = cache_system_key('cloud_api', array('method' => md5($method . implode('', $data))));
    $cache = cache_load($cache_key);
    if (!empty($cache) && !$extra['nocache']) {
        return $cache;
    }
    $api_url = 'http://api.w7.cc/%s';
    $must_authorization_host = !in_array($method, array('module/setting/index', 'module/setting/save'));
    $pars = _cloud_build_params($must_authorization_host);
    if ($method != 'site/token/index') {
        $pars['token'] = cloud_build_transtoken();
    }
    $data = array_merge($pars, $data);
    if ($GLOBALS['_W']['config']['setting']['development'] == 3) {
        $extra['CURLOPT_USERAGENT'] = 'development';
    }
    $response = ihttp_request(sprintf($api_url, $method), $data, $extra, $timeout);
    $file = IA_ROOT . '/data/' . (!empty($data['file']) ? $data['file'] : $data['method']);
    $file = $file . cache_random();
    $ret = _cloud_shipping_parse($response, $file);
    if (!is_error($ret) && !empty($ret)) {
        cache_write($cache_key, $ret, CACHE_EXPIRE_MIDDLE);
    }
    return $ret;
*/
    return null;
}
  
function cloud_prepare() {
    global $_W;
    setting_load();
/*  if(empty($_W['setting']['site']['key']) || empty($_W['setting']['site']['token'])) {
        return error('-1', '站点注册信息丢失, 请通过"重置站点ID和通信密钥"重新获取 !');
    }
    */
    return true;
}
  
function cloud_build($nocache = false) {
/*
    $pars['method'] = 'application.build4';
    $pars['file'] = 'application.build';
    $extra = $nocache ? array('nocache' => $nocache) : array();
    $ret = cloud_api('site/build/index', $pars, $extra);
    if (is_error($ret)) {
        return $ret;
    }
  
    if($ret['state'] == 'warning') {
        $ret['files'] = cloud_client_define();
        unset($ret['schemas']);
        unset($ret['scripts']);
    } else {
        $patch_path = sprintf('%s/data/patch/upgrade/%s', IA_ROOT, date('Ymd'));
        if (!is_dir($patch_path)) {
            mkdirs($patch_path);
        }
  
        $files = $files_allowed = array();
        if(!empty($ret['files'])) {
            foreach($ret['files'] as $file) {
                $entry = IA_ROOT . $file['path'];
                if(!is_file($entry) || md5_file($entry) != $file['checksum']) {
                    $files_allowed[] = $file['path'];
                }
  
                $entry = $patch_path . $file['path'];
                if (!is_file($entry)) {
                    $entry = IA_ROOT . $file['path'];
                }
                if(!is_file($entry) || md5_file($entry) != $file['checksum']) {
                    $files[] = $file['path'];
                }
            }
        }
        $ret['files'] = $files;
        if (!empty($ret['files'])) {
            cloud_bakup_files($ret['files']);
        } else {
            if (!empty($files_allowed)) {
                foreach ($files_allowed as $file) {
                    $dir = pathinfo(IA_ROOT . $file, PATHINFO_DIRNAME);
                    if (!is_dir($dir)) {
                        mkdirs($dir);
                    }
                    file_put_contents(IA_ROOT . $file, file_get_contents($patch_path . $file));
                }
                rmdirs($patch_path);
            }
        }
        $schemas = array();
        if(!empty($ret['schemas'])) {
            load()->func('db');
            foreach($ret['schemas'] as $remote) {
                $name = substr($remote['tablename'], 4);
                $local = db_table_schema(pdo(), $name);
                unset($remote['increment']);
                unset($local['increment']);
                if(empty($local)) {
                    $schemas[] = $remote;
                } else {
                    $sqls = db_table_fix_sql($local, $remote);
                    if(!empty($sqls)) {
                        $schemas[] = $remote;
                    }
                }
            }
        }
        $ret['schemas'] = $schemas;
    }
  
    if (IMS_FAMILY != $ret['family']) {
        $update_version_success = setting_upgrade_version($ret['family'], IMS_VERSION, IMS_RELEASE_DATE);
        if (empty($update_version_success)) {
            message('切换版本失败,请修改 /framework/version.inc.php 文件权限为 User 可写或是 777', 'refresh', 'error');
        } else {
            message('更新系统正在为您自动切换版本', 'refresh');
        }
    }
    $ret['upgrade'] = false;
    if(!empty($ret['files']) || !empty($ret['schemas']) || !empty($ret['scripts'])) {
        $ret['upgrade'] = true;
    }
  
    return $ret;
*/
    return null;
}
  
function cloud_schema() {
    $pars['method'] = 'application.schema';
    $pars['file'] = 'application.schema';
    $ret = cloud_api('site/schema/index', $pars);
      
    if(!is_error($ret)) {
        $schemas = array();
        if(!empty($ret['schemas'])) {
            load()->func('db');
            foreach($ret['schemas'] as $remote) {
                $name = substr($remote['tablename'], 4);
                $local = db_table_schema(pdo(), $name);
                unset($remote['increment']);
                unset($local['increment']);
                if(empty($local)) {
                    $schemas[] = $remote;
                } else {
                    $diffs = db_schema_compare($local, $remote);
                    if(!empty($diffs)) {
                        $schemas[] = $remote;
                    }
                }
            }
        }
        $ret['schemas'] = $schemas;
    }
    return $ret;
}
  
function cloud_download($path, $type = '') {
    global $_W;
    $pars = _cloud_build_params();
    $pars['method'] = 'application.shipping';
    $pars['path'] = $path;
    $pars['type'] = $type;
    $pars['gz'] = function_exists('gzcompress') && function_exists('gzuncompress') ? 'true' : 'false';
    $pars['download'] = 'true';
    $headers = array('content-type' => 'application/x-www-form-urlencoded');
    $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
    $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, $headers, 300);
    if(is_error($dat)) {
        return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
    }
    if($dat['content'] == 'success') {
        return true;
    }
    $ret = @json_decode($dat['content'], true);
    if (isset($ret['error'])) {
        return error(1, $ret['error']);
    }
    if(is_error($ret)) {
        return $ret;
    } else {
        $post = $dat['content'];
        $data = base64_decode($post);
        if (base64_encode($data) !== $post) {
            $data = $post;
        }
        $ret = iunserializer($data);
        $gz = function_exists('gzcompress') && function_exists('gzuncompress');
        $file = base64_decode($ret['file']);
        if($gz) {
            $file = gzuncompress($file);
        }
        $_W['setting']['site']['token'] = authcode(cache_load(cache_system_key('cloud_transtoken')), 'DECODE');
        $string = (md5($file) . $ret['path'] . $_W['setting']['site']['token']);
        if(!empty($_W['setting']['site']['token']) && md5($string) === $ret['sign']) {
            $error_file_list = array();
            if (!cloud_file_permission_pass($error_file_list)) {
                return error(-1, '请修复下列文件读写权限 : ' . implode('; ', $error_file_list));
            }
                        if ($type == 'module' || $type == 'theme') {
                $patch_path = IA_ROOT;
            } else {
                $patch_path = sprintf('%s/data/patch/upgrade/%s', IA_ROOT, date('Ymd'));
            }
            $path = $patch_path . $ret['path'];
            load()->func('file');
            @mkdirs(dirname($path));
            if (file_put_contents($path, $file)) {
                return true;
            } else {
                return error(-1, '写入失败,请检查是否有写入权限或是否磁盘已满!');
            }
        }
        return error(-1, '写入失败!');
    }
}
  
function cloud_m_prepare($name) {
/*  $ret = cloud_api('module/check', array(
        'method' => 'module.check',
        'module' => $name,
    ));
    if (is_error($ret)) {
        return $ret;
    }*/
    return true;
}
  
  
function cloud_m_build($modulename, $type = ''){
/*  $type = in_array($type, array('uninstall', 'upgrade', 'install')) ? $type : '';
    if (empty($modulename)) {
        return array();
    }
    if ($type == 'upgrade') {
        $module_info = cloud_m_info($modulename);
        if (is_error($module_info)) {
            return $module_info['message'];
        }
        $module = array('version' => $module_info['version']['version']);
    } else {
        $module = table('modules')->getByName($modulename);
    }
    $pars['module'] = $modulename;
    $pars['type'] = $type;
    if (!empty($module)) {
        $pars['module_version'] = $module['version'];
    }
      
    $pars['file'] = 'module.build';
    $ret = cloud_api('module/build', $pars);
  
    if (!is_error($ret)) {
        $dir = IA_ROOT . '/addons/' . $modulename;
        $files = array();
        if (!empty($ret['files'])) {
            foreach ($ret['files'] as $file) {
                if ($file['path'] == '/map.json') {
                    continue;
                }
                $entry = $dir . $file['path'];
                if (!is_file($entry) || md5_file($entry) != $file['checksum']) {
                    $files[] = '/' . $modulename . $file['path'];
                }
            }
        }
        $ret['files'] = $files;
        $schemas = array();
        if (!empty($ret['schemas'])) {
            load()->func('db');
            foreach ($ret['schemas'] as $remote) {
                $name = substr($remote['tablename'], 4);
                $local = db_table_schema(pdo(), $name);
                unset($remote['increment']);
                unset($local['increment']);
                if (empty($local)) {
                    $schemas[] = $remote;
                } else {
                    $diffs = db_table_fix_sql($local, $remote);
                    if (!empty($diffs)) {
                        $schemas[] = $remote;
                    }
                }
            }
        }
        $ret['upgrade'] = true;
        $ret['type'] = 'module';
        $ret['schemas'] = $schemas;
                if (empty($module)) {
            $ret['install'] = 1;
        }
    }
    return $ret;
    */
    return null;
}
  
  
function cloud_m_query($module = array(), $page = 1) {
/*  $pars['method'] = 'module.query';
    if (empty($module)) {
        $module = cloud_extra_module();
    }
    if (!is_array($module)) {
        $module = array($module);
    }
    $pars['page'] = max(1, intval($page));
    $pars['module'] = base64_encode(iserializer($module));
    $ret = cloud_api('module/query', $pars);
    if (isset($ret['error'])) {
        return error(1, $ret['error']);
    }
    if (!is_error($ret)) {
        $pirate_apps = $ret['pirate_apps'];
        unset($ret['pirate_apps']);
        $support_names = array('app', 'wxapp', 'webapp', 'system_welcome', 'android', 'ios', 'xzapp', 'aliapp', 'baiduapp', 'toutiaoapp');
        $record_module = array();
        foreach ($ret['data'] as $modulename => &$info) {
            if ($info['is_record']) {
                $record_module[] = $info['name'];
            }
            if (empty($info['site_branch'])) {
                continue;
            }
            foreach ($support_names as $support) {
                if (in_array($support, $info['site_branch']['bought']) && !empty($info['site_branch']["{$support}_support"]) && $info['site_branch']["{$support}_support"] == 2) {
                    $info['site_branch']["{$support}_support"] = 2;
                } else {
                    $info['site_branch']["{$support}_support"] = 1;
                }
            }
        }
        $ret['pirate_apps'] = $pirate_apps;
        if (!empty($record_module)) {
            table('modules')->where(array('name IN' => $record_module))->fill(array('cloud_record' => STATUS_ON))->save();
        }
    } */
    //return $ret;
    return array();
}
  
function cloud_m_info($name) {
    $pars['method'] = 'module.info';
    $pars['module'] = $name;
    $ret = cloud_api('module/info', $pars);
    if (empty($ret)) {
        return array();
    }  
    return $ret;
}
  
  
function cloud_m_upgradeinfo($modulename) {
    load()->model('module');
  
    $module = module_fetch($modulename);
  
    $pars['method'] = 'module.info';
    $pars['module'] = $modulename;
    $pars['curversion'] = $module['version'];
    $pars['isupgrade'] = 1;
    $ret = cloud_api('module/info', $pars);
  
    if (empty($ret)) {
        return array();
    }
    if (is_error($ret)) {
        return $ret;
    }
    if (version_compare($ret['version']['version'], $module['version'], '>')) {
        $ret['upgrade'] = true;
    }
        $ret['site_branch'] = $ret['branches'][$ret['version']['branch_id']];
        $ret['from'] = 'cloud';
        foreach ($ret['branches'] as &$branch) {
        if ($branch['displayorder'] > $ret['site_branch']['displayorder'] || ($branch['displayorder'] == $ret['site_branch']['displayorder'] && $ret['site_branch']['id'] < intval($branch['id']))) {
            $ret['new_branch'] = true;
            }
        $branch['id'] = intval($branch['id']);
        $branch['version']['description'] = preg_replace('/\n/', '<br/>', htmlspecialchars_decode($branch['version']['description']));
        $branch['displayorder'] = intval($branch['displayorder']);
        $branch['day'] = intval(date('d', $branch['version']['createtime']));
        $branch['month'] = date('Y.m', $branch['version']['createtime']);
        $branch['hour'] = date('H:i', $branch['version']['createtime']);
    }
    unset($branch);
    return $ret;
}
  
function cloud_t_prepare($name){
/*  $pars['method'] = 'theme.check';
    $pars['theme'] = $name;
    $dat = cloud_api('theme/check', $pars);
    if (is_error($dat)) {
        return $dat;
    }
  
*/
    return true;
}
  
  
function cloud_t_query(){
/*
    $pars['method'] = 'theme.query';
    $pars['theme'] = cloud_extra_theme();
    $ret = cloud_api('theme/query', $pars);
    return $ret;
    */
    return null;
}
  
function cloud_t_info($name){
/* 
    $pars['method'] = 'theme.info';
    $pars['theme'] = $name;
    $ret = cloud_api('theme/info', $pars);
    return $ret;
  
*/
    return null;
}
  
function cloud_t_build($name) {
    if (empty($name)) {
        return array();
    }
    $theme = table('site_templates')->getByName(trim($name));
    $pars['method'] = 'theme.build';
    $pars['theme'] = $name;
    if(!empty($theme)) {
        $pars['themeversion'] = $theme['version'];
    }
    $ret = cloud_api('theme/build', $pars);
    if (empty($ret)) {
        return array();
    }  
    if(!is_error($ret)) {
        $dir = IA_ROOT . '/app/themes/' . $name;
        $files = array();
        if(!empty($ret['files'])) {
            foreach($ret['files'] as $file) {
                $entry = $dir . $file['path'];
                if(!is_file($entry) || md5_file($entry) != $file['checksum']) {
                    $files[] = '/'. $name . $file['path'];
                }
            }
        }
        $ret['files'] = $files;
        $ret['upgrade'] = true;
        $ret['type'] = 'theme';
                if(empty($theme)) {
            $ret['install'] = 1;
        }
    }
    return $ret;
}
  
  
function cloud_t_upgradeinfo($name) {
    if (empty($name)) {
        return array();
    }
    $theme = table('site_templates')->getByName(trim($name));
    if (empty($theme)) {
        return array();
    }
    return cloud_api('theme/upgrade', array(
        'method' => 'theme.upgrade',
        'theme' => $theme['name'],
        'version' => $theme['version'],
        'isupgrade' => 1,
    ));
}
  
function cloud_sms_send($mobile, $content, $postdata = array(), $custom_sign = '', $use_system_balance = false) {
    global $_W;
    if(!preg_match('/^1\d{10}$/', $mobile) || empty($content)) {
        return error(1, '发送短信失败, 原因: 手机号错误或内容为空.');
    }
    $uniacid = empty($use_system_balance) ? $_W['uniacid'] : 0;
  
    if (empty($uniacid)) {
        $sms_info = cloud_sms_info();
        $balance = empty($sms_info['sms_count']) ? 0 : $sms_info['sms_count'];
        if (!empty($custom_sign)) {
            $sign = $custom_sign;
        }
    } else {
        $row = pdo_get('uni_settings' , array('uniacid' => $uniacid), array('notify'));
        $row['notify'] = @iunserializer($row['notify']);
  
        $config = $row['notify']['sms'];
        $balance = intval($config['balance']);
          
        $sign = empty($custom_sign) ? $config['signature'] : $custom_sign;
        $account_name = empty($_W['account']['type_name']) ? '' : $_W['account']['type_name'];
        $account_name .= empty($_W['account']['name']) ? '' : " [{$_W['account']['name']}] ";
    }
    if(empty($sign) || $sign == 'null') {
                $sign = '短信宝';
        }
        //判断剩余条数
      if($balance<1){
                return error(-1, '短信发送失败, 原因:余额不足');
        }
        //短信宝账号
       // $smsbao_info=pdo_get('uni_settings' , array('uniacid' => $_W['uniacid']), array('copyright'));
        //$smsbao_info=setting_load($key = 'copyright');
        $sms_param['u']=$_W['setting']['copyright']['sms_name'];
        $sms_param['p']=md5($_W['setting']['copyright']['sms_password']);
        $sms_param['m']=$mobile;
        $sms_param['c']='【'.$sign.'】'.$content;
        $response = file_get_contents("http://api.smsbao.com/sms?".http_build_query($sms_param));
        if (trim($response)!='0') {
        return error($response['errno'], '短信发送失败, 原因:'.$response['message']);
        }
   
        if (trim($response)=='0') {
        if (!empty($uniacid)) {
            $row['notify']['sms']['balance'] = $row['notify']['sms']['balance'] - 1;
            if ($row['notify']['sms']['balance'] < 0) {
                $row['notify']['sms']['balance'] = 0;
            }
            pdo_update('uni_settings', array('notify' => iserializer($row['notify'])), array('uniacid' => $uniacid));
            uni_setting_save('notify', $row['notify']);
        } else {
            $sms_info['sms_count'] = $sms_info['sms_count'] - 1;
            if ($sms_info['sms_count'] < 0) {
                $sms_info['sms_count'] = 0;
            }
            setting_save($sms_info, 'sms.info');
        }
    }
    return true;
}
  
  
function cloud_sms_info() {
        global $_W;
   
        $data=array();
        //返回短信的剩余条数以及签名
        $sms_name=$_W['setting']['copyright']['sms_name'];
        $sms_password=md5($_W['setting']['copyright']['sms_password']);
        $res=file_get_contents("http://api.smsbao.com/query?u={$sms_name}&p={$sms_password}");
        $retArr = explode("\n", $res);
        $balanceArr = explode(",", $retArr[1]);
    $data['sms_count']=$retArr[0] == 0 ? $balanceArr[1]:0;
        return $data;
}
function cloud_sms_count_remained(){
    $cache_key = cache_system_key('cloud_api', array('method' => md5('cloud_sms_count_remained')));
    $cache = cache_load($cache_key);
    if (!empty($cache) && $cache['expire'] > TIMESTAMP) {
        return $cache['cloud_sms_count_remained'];
    }
    $sms_info = cloud_sms_info();
    if (is_error($sms_info)){
        return $sms_info;
    }
    $sms_count = $sms_info['sms_count'];
    $sms_accounts = table('uni_settings')->select(array('uniacid', 'notify'))->where(array('notify LIKE' => '%sms%'))->getall();
    $setting_sms_blance = setting_load('system_sms_balance');
    $system_sms_balance = !empty($setting_sms_blance['system_sms_balance']) ? $setting_sms_blance['system_sms_balance'] : 0;
    $sms_count -= $system_sms_balance;
    if (empty($sms_accounts)){
        return $sms_count;
    }
    foreach ($sms_accounts as $sms_account) {
        $notify = iunserializer($sms_account['notify']);
        $sms_count -= $notify['sms']['balance'];
    }
    $sms_count = max(0, $sms_count);
    $cache_data = array(
        'cloud_sms_count_remained' => $sms_count
    );
    cache_write($cache_key, $cache_data, CACHE_EXPIRE_MIDDLE);
    return $sms_count;
}
  
function cloud_extra_account() {
    $data = array();
    $data['accounts'] = pdo_fetchall("SELECT name, account, original FROM ".tablename('account_wechats') . " GROUP BY account");
    return serialize($data);
}
  
  
function cloud_extra_module() {
    load()->model('module');
    $module_support_type = array_keys(module_support_type());
    $installed = table('modules')->getInstalled();
    $recycle = table('modules_recycle')->where('type', 2)->getall('name');
  
    $result = array();
    foreach($installed as $install_module) {
        if ($install_module['cloud_record']) {
            continue;
        }
        $result[$install_module['name']] = array(
            'name' => $install_module['name'],
            'version' => $install_module['version'],
        );
        $all_uninstall = true;
        foreach ($module_support_type as $support) {
            $type = str_replace('_support', '', $support);
            if ($install_module[$support] == 2) {
                $all_uninstall = false;
                $result[$install_module['name']]['support'][$type]['is_install'] = 2;
            }
        }
        if ($all_uninstall) {
            unset($result[$install_module['name']]);
        }
    }
    $result = array_slice($result, 0, 100, true);
    foreach($recycle as $recycle_module) {
        if (empty($result[$recycle_module['name']])) {
            $result[$recycle_module['name']] = array(
                'name' => $recycle_module['name'],
            );
        }
        $in_recycle = false;
        foreach ($module_support_type as $support) {
            $type = str_replace('_support', '', $support);
            if ($recycle_module[$support]) {
                $in_recycle = true;
                $result[$recycle_module['name']]['support'][$type] = array(
                    'is_recycle' => 2
                );
            }
        }
        if (!$in_recycle) {
            unset($result[$recycle_module['name']]);
        }
    }
    return $result;
}
  
  
function cloud_extra_theme() {
    $sql = 'SELECT `name` FROM ' . tablename('site_templates') . ' WHERE `name` <> :name';
    $themes = pdo_fetchall($sql, array(':name' => 'default'), 'name');
    if (!empty($themes)) {
        return base64_encode(iserializer(array_keys($themes)));
    } else {
        return '';
    }
}
  
  
function cloud_extra_webtheme() {
    $sql = 'SELECT `name` FROM ' . tablename('webtheme_templates') . ' WHERE `name` <> :name';
    $themes = pdo_fetchall($sql, array(':name' => 'default'), 'name');
    if (!empty($themes)) {
        return base64_encode(iserializer(array_keys($themes)));
    } else {
        return '';
    }
}
  
function cloud_module_setting($acid, $module) {
    $pars = array(
        'acid' => $acid,
        'module_name' => $module['name'],
        'module_version' => $module['version'],
    );
    return cloud_api('module/setting/index', $pars);
}
  
function cloud_module_setting_save($acid, $module_name, $setting) {
    $pars = array(
        'acid' => $acid,
        'module_name' => $module_name,
        'setting' => $setting,
    );
    return cloud_api('module/setting/save', $pars);
}
function cloud_module_list($title, $support_type, $page = 1, $per_page = 20) {
    $pars = array(
        'title' => $title,
        'support_type' => $support_type,
        'page' => $page,
        'per_page' => $per_page,
    );
    return cloud_api('module/list', $pars);
}
  
  
function cloud_cron_create($cron) {
    $pars = array(
        'cron' => base64_encode(iserializer($cron)),
    );
    return cloud_api('site/cron/save', $pars);
}
  
  
function cloud_cron_update($cron) {
    return cloud_cron_create($cron); }
  
  
function cloud_cron_get($cron_id) {
    $pars = array(
        'cron_id' => $cron_id,
    );
    return cloud_api('site/cron/get', $pars);
}
  
  
function cloud_cron_change_status($cron_id, $status) {
    $pars = array(
        'cron_id' => $cron_id,
        'status' => $status,
    );
    return cloud_api('site/cron/status', $pars);
}
  
  
function cloud_cron_remove($cron_id) {
    $pars = array(
        'cron_id' => $cron_id,
    );
    return cloud_api('site/cron/remove', $pars);
}
  
function cloud_site_info() {
    return cloud_api('site/info');
}
  
function cloud_reset_siteinfo() {
    global $_W;
    return cloud_api('site/register/profile', array('url' => $_W['siteroot']));
}
  
  
function cloud_auth_url($forward, $data = array()){
    global $_W;
    if (!empty($_W['setting']['site']['url']) && !strexists($_W['siteroot'], $_W['setting']['site']['url'])) {
        $url = $_W['setting']['site']['url'];
    } else {
        $url = rtrim($_W['siteroot'], '/');
    }
    $auth = array();
    $auth['key'] = '';
    $auth['password'] = '';
    $auth['url'] = $url;
    $auth['referrer'] = intval($_W['config']['setting']['referrer']);
    $auth['version'] = IMS_VERSION;
    $auth['forward'] = $forward;
    $auth['family'] = IMS_FAMILY;
  
    if(!empty($_W['setting']['site']['key']) && !empty($_W['setting']['site']['token'])) {
        $auth['key'] = $_W['setting']['site']['key'];
        $auth['password'] = md5($_W['setting']['site']['key'] . $_W['setting']['site']['token']);
    }
    if ($data && is_array($data)) {
        $auth = array_merge($auth, $data);
    }
    $query = base64_encode(json_encode($auth));
    $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
    $auth_url = $_URLTYPE.$_SERVER['HTTP_HOST'] . $query;
  
    return $auth_url;
}
  
  
function cloud_module_setting_prepare($module, $binding) {
    global $_W;
    $auth = _cloud_build_params();
    $auth['arguments'] = array(
        'binding' => $binding,
        'acid' => $_W['uniacid'],
        'type' => 'module',
        'module' => $module,
    );
    $iframe_auth_url = cloud_auth_url('module', $auth);
  
    return $iframe_auth_url;
}
  
  
function cloud_resource_to_local($uniacid, $type, $url){
    global $_W;
  
    load()->func('file');
  
    $setting = $_W['setting']['upload'][$type];
    if (substr($url, 0, 2) == '//') {
        $url = 'http:' . $url;
    }
  
    if (!file_is_image($url)) {
        return error(1, '远程图片后缀非法,请重新上传');
    }
    $pathinfo = pathinfo($url);
    $extension = $pathinfo['extension'];
  
    if ($uniacid == 0) {
        $setting['folder'] = "{$type}s/global/".date('Y/m/');
    } else {
        $setting['folder'] = "{$type}s/{$uniacid}/".date('Y/m/');
    }
  
    $originname = pathinfo($url, PATHINFO_BASENAME);
    $filename = file_random_name(ATTACHMENT_ROOT .'/'. $setting['folder'], $extension);
    $pathname = $setting['folder'] . $filename;
    $fullname = ATTACHMENT_ROOT . $pathname;
  
    mkdirs(dirname($fullname));
  
    load()->func('communication');
    $response = ihttp_get($url);
    if (is_error($response)) {
        return error(1, $response['message']);
    }
    if (file_put_contents($fullname, $response['content']) == false) {
        return error(1, '提取文件失败');
    }
  
    if (!empty($_W['setting']['remote']['type'])) {
        $remotestatus = file_remote_upload($pathname);
        if (is_error($remotestatus)) {
            return error(1, '远程附件上传失败,请检查配置并重新上传');
        } else {
            file_delete($pathname);
        }
    }
  
    $data = array(
        'uniacid' => $uniacid,
        'uid' => intval($_W['uid']),
        'filename' => $originname,
        'attachment' => $pathname,
        'type' => $type == 'image' ? 1 : 2,
        'createtime' => TIMESTAMP,
    );
    pdo_insert('core_attachment', $data);
  
    $data['url'] = tomedia($pathname);
    $data['id'] = pdo_insertid();
  
    return $data;
}
  
function cloud_bakup_files($files) {
    global $_W;
    if (empty($files)) {
        return false;
    }
    $map = json_encode($files);
    $hash  = md5($map.$_W['config']['setting']['authkey']);
    if ($handle = opendir(IA_ROOT . '/data/patch/backup/' . date('Ymd'))) {
        while (false !== ($patchpath = readdir($handle))) {
            if ($patchpath != '.' && $patchpath != '..') {
                if (strexists($patchpath, $hash)) {
                    return false;
                }
            }
        }
    }
  
    $path = IA_ROOT . '/data/patch/backup/' . date('Ymd') . '/' . date('Hi') . '_' . $hash;
    load()->func('file');
    if (!is_dir($path) && mkdirs($path)) {
        foreach ($files as $file) {
            if (file_exists(IA_ROOT . $file)) {
                mkdirs($path . '/' . dirname($file));
                file_put_contents($path . '/' . $file, file_get_contents(IA_ROOT . $file));
            }
        }
        file_put_contents($path . '/' . 'map.json', $map);
    }
    return false;
}
  
function cloud_build_transtoken() {
    $pars['method'] = 'application.token';
    $pars['file'] = 'application.build';
    $ret = cloud_api('site/token/index', $pars);
    cache_write(cache_system_key('cloud_transtoken'), authcode($ret['token'], 'ENCODE'));
    return $ret['token'];
}
  
function cloud_build_schemas($schemas) {
    $database = array();
    if (empty($schemas) || !is_array($schemas)) {
        return $database;
    }
    foreach ($schemas as $remote) {
        $row = array();
        $row['tablename'] = $remote['tablename'];
        $name = substr($remote['tablename'], 4);
        $local = db_table_schema(pdo(), $name);
        unset($remote['increment']);
        unset($local['increment']);
        if (empty($local)) {
            $row['new'] = true;
        } else {
            $row['new'] = false;
            $row['fields'] = array();
            $row['indexes'] = array();
            $diffs = db_schema_compare($local, $remote);
            if (!empty($diffs['fields']['less'])) {
                $row['fields'] = array_merge($row['fields'], $diffs['fields']['less']);
            }
            if (!empty($diffs['fields']['diff'])) {
                $row['fields'] = array_merge($row['fields'], $diffs['fields']['diff']);
            }
            if (!empty($diffs['indexes']['less'])) {
                $row['indexes'] = array_merge($row['indexes'], $diffs['indexes']['less']);
            }
            if (!empty($diffs['indexes']['diff'])) {
                $row['indexes'] = array_merge($row['indexes'], $diffs['indexes']['diff']);
            }
            $row['fields'] = implode($row['fields'], ' ');
            $row['indexes'] = implode($row['indexes'], ' ');
        }
        $database[] = $row;
    }
    return $database;
}
  
  
function cloud_file_permission_pass(&$error_file_list = array()) {
    $cache_key = cache_system_key('cloud_file_permission_pass');
    $cache = cache_load($cache_key);
    if ($cache) {
        return true;
    }
    $check_path = array(
        '/api',
        '/app/common',
        '/app/resource',
        '/app/source',
        '/app/themes/default',
        '/web/common',
        '/web/resource',
        '/web/source',
        '/web/themes/default',
        '/web/themes/black',
        '/web/themes/classical',
        '/web/themes/2.0',
        '/framework/builtin',
        '/framework/class',
        '/framework/model',
        '/framework/function',
        '/framework/table',
        '/framework/library',
        '/payment',
    );
  
    $check_file = array(
        '/web/index.php',
        '/framework/bootstrap.inc.php',
        '/framework/version.inc.php',
        '/framework/const.inc.php',
    );
    $sub_paths = array();
    foreach ($check_path as $path) {
        $file_list = cloud_file_tree(IA_ROOT . $path);
        if (!empty($file_list)) {
            foreach ($file_list as $file) {
                if (is_file($file)) {
                    $sub_path = pathinfo($file, PATHINFO_DIRNAME);
                    if (empty($sub_paths[$sub_path])) {
                        if (!cloud_path_is_writable($sub_path)) {
                            $error_file_list[] = str_replace(IA_ROOT, '', $sub_path);
                        }
                        $sub_paths[$sub_path] = $sub_path;
                    }
                }
                if (!is_writable($file)) {
                    $error_file_list[] = str_replace(IA_ROOT, '', $file);
                }
            }
        }
    }
  
    foreach ($check_file as $file) {
        if (!is_writable(IA_ROOT . $file)) {
            $error_file_list[] = str_replace(IA_ROOT, '', $file);
        }
    }
    if (empty($error_file_list)) {
        cache_write($cache_key, true, 600);
        return true;
    }
    return false;
}
  
function cloud_file_tree($path, $include = array()) {
    $files = array();
    if (!empty($include)) {
        $ds = glob($path . '/{' . implode(',', $include) . '}', GLOB_BRACE);
    } else {
        $ds = glob($path . '/*');
    }
    if (is_array($ds)) {
        foreach ($ds as $entry) {
            if (is_file($entry)) {
                $files[] = $entry;
            }
            if (is_dir($entry)) {
                $rs = cloud_file_tree($entry);
                foreach ($rs as $f) {
                    $files[] = $f;
                }
            }
        }
    }
    return $files;
}
  
function cloud_path_is_writable($dir) {
    $writeable = false;
    if (!is_dir($dir)) {
        @mkdir($dir, 0755);
    }
    if (is_dir($dir)) {
        if($fp = fopen("$dir/test.txt", 'w')) {
            fclose($fp);
            unlink("$dir/test.txt");
            $writeable = true;
        } else {
            $writeable = false;
        }
    }
    return $writeable;
}
  
  
function cloud_get_store_notice() {
    load()->classs('cloudapi');
    $api = new CloudApi();
    $result = $api->get('store', 'official_dynamics');
    return $result;
}
  
function cloud_v_to_xs($url) {
    if (empty($url)) {
        return false;
    }
    /*$pars = _cloud_build_params();
    $pars['method'] = 'module.query';
    $pars['url'] = urlencode($url);
    cloud_request('http://api.w7.cc/site/pirate/index', $pars);
    */
    return true;
}
  
function cloud_workorder() {
    $result = cloud_api('work-order/status/index');
    return $result;
}
function cloud_account_info() {
    $site_info = cloud_site_info();
    $account_num = max(0, intval($site_info['quantity']));
    return $account_num;
}
  
  
function cloud_w7_request_token($js_secret, $nocache = false) {
    global $_W;
    if (empty($_W['setting']['site']) || empty($_W['setting']['site']['key'])) {
        return '';
    }
    if (!$nocache) {
        $cache_key = cache_system_key('cloud_w7_request_token');
        $cache = cache_load($cache_key);
        if ($cache) {
            return $cache;
        }
    }
    $js_token = authcode($js_secret, 'ENCODE', $_W['setting']['site']['key']);
    $data = array('js_token' => $js_token);
    $ret = cloud_api('site/accesstoken/with-js-token', $data);
    if (is_error($ret)) {
        return '';
    }
    cache_write($cache_key, $ret['access_token'], $ret['expire_time']);
    return $ret['access_token'];
}


打赏

说点什么吧
  • 全部评论(0
    还没有评论,快来抢沙发吧!

    彪彪:老版迅雷可用,就是比较慢。

    士大夫:第一个可以用!

    士大夫:谢谢大佬

    嘿嘿:劲儿劲儿

    人来人往:出现这一错误,安装这个方法解决了,感谢!

    HTML:权限修改对了吗

    织梦:权限修改为777了,没能解决

    后悔:安装这个方法修改了权限,还是不行呢

    44:是呀,旧版的解析不了迅雷链接

    1:第三个没啥用

    逐风戏雨:赞一个,迅雷5.8好用,感谢分享!

    一朵:感谢,我的是ftp软件里面怎么看都是644权限,但是到织梦后台就提示修改。按照这个方法修改后不再提示了。

    ada:好耶,可以用

    ada:用管理员身份绿了半天希望能成

    大在在:有病毒。。。

    K9999:第三个方法好用,第一个不能用(只尝试了一次),第二个现在很多都没有口令

    自学成才:你好 请问有最新版本的教程吗

    A:啊不对 是我下错了文件 画质还是一样的 但是方法一还行下载不了一些版权原因的

    A:方法一真的可以!!谢谢楼主 就是本来1080的会变成普通画质

    大白兔奶糖:这种的估计是种子没有资源

    大白兔奶糖:不过现在又装回来了,感觉只要种子有资源的5.8迅雷就能下载,没资源的换啥版本都不能下载!

    大白兔奶糖:我和你一样,后来发现是没退出迅雷直接卸载导致的,打开迅雷把下载任务删除只有又卸载就删掉了。

    初:楼主,为什么迅雷5.8打开那个卸载后,这个文件夹一直删除不了呀?它下载不了东西而且还和最新的迅雷下载冲突, 最新的也下载不了。。。

    大兵:下载了迅雷5.8但是 nbsp; 也显示正在下载 nbsp; 但是不下载内容

    聆听你的声音:为了破解版权限制,最终还是用上了旧版迅雷,确实管用!界面好复古的样子。不过很简洁,也没广告。另外旧版的迅雷5.8没法登录账号,有点小可惜。

    爽:官方离线安装版本,安全放心!主要是使用官方的安装装工具下载安装实在是太慢了,还是这个理线安装包比较爽!

    mising:很方便,自动插入基本的html框架代码,省去很多重复机械的工作

    请教:请教一下,win7修改了好像还是不能用,有没有具体教程

    米linna:同楼上,我一般都会禁用织梦的模板缓存功能。但是/data/tplcache/目录下面依旧会不断的新增文件,体积都不大,但是文件数量却很多!感谢楼主分享删除方法!

    彩虹泡泡糖:mac可以用迅雷口令解决

    谢谢:mac呢?????

    anon:修改hosts没有用

    puma:试了一下还是不行

    笑笑:host方法有用,现在可以下载了,感谢分享!

    微亚是只猫:win10修改这个文件需要管理员权限的,就是以管理员方式打开,不然修改不成功。另外这个方法解决版权方要求的问题修改后应该是要重启迅雷重新添加下载任务。

    戴老板:我试了第一个方法不行

    小便当:一直在找这款外星人主题,感谢楼主分享!

    大写的C:一直用这个外星人主题,整个色调都很是喜欢~~

    酱紫:很不错,学习了。

    花瓜:不建议去掉织梦后台的验证码,毕竟很多时候设置的密码都不是很复杂,被暴力破解的话就不好了。

    瓜子:一楼说的不错,现在很多的老牌cms都不怎么更新了,这个开源模式的路是不是快走到头了?

    利强:怎么说呢,织梦出的这个问答模块以前还算是很实用的,现在已经感觉很鸡肋了。作为一个插件不如作为一个系统模型卡发出来更加强大。但是现在dedecms官网不光问答模块,就连主程序也已经不怎么更新了。可能是做出这么好的cms程序,又没多少人付费,没有好的变现模式,心凉了吧。毕竟企业都是要生存的。

    木须肉:感谢楼主分享教程,已经用上了,很不错,实现备份了数据库,不过并没有出现什么错误!

    胡乐乐:这个方法很不错,节省了大量的时间,瞬间感觉自己成了技术牛人,有一种人生开挂的感觉,哈哈。

    鹿爷:确实很不错,对我等刚刚接触ftp软件操作的的小菜鸟,非常实用!

    叶新楼:很不错的教程,简单明了,很多人推荐一些别的ftp软件,比如说FileZilla之类的,尝试了虽然他们都很强大,但是我还是觉得flashfxp最好用,可能是每个人的习惯不一样吧。

    你这个瓜娃子:这恐怕是我见过的最简单给力的flashfxp教程了,哈哈,按照这个一步步操作,把我家小盆友不费吹灰之力的轻松教会了!

    米:感谢楼主分享,非常实用

    Linda:很漂亮的css表格样式,感谢楼主分享。希望看到更多精美的css样式分享出来!

    取个什么名字呢?:原来还可以从指定位置来截取指定长度字符串的,受教了。

    取个什么名字呢?:感谢博主的分享,对于小白来说都是一些拿来就可以上手使用的教程。

    取个什么名字呢?:都很实用,介绍简洁明了,代码整理的也很规范,一看就懂。赞赞赞

    取个什么名字?:太全了,收藏保存一下,以备不时之需!

    米启玲:php的这个随机方式挺经典的,可以应用到很多随机抽奖类的小程序中。

    米勒:随机数真的很有用处,可以实现各种各样有意思的小功能,绝对是用php开发各种小工具必备技能...

    猕猴不是桃:第一次使用mt_rand功能,非常方便,以前都是自己写一堆逻辑来实现的,不知道这个mt_rand能不够实现真正意义上的随机数,可以的话以后php从数组中随机取值和php控制随机数的概率的工作做起来就更简单了。

    卡布斯基:正好需要用的php输出随机数的功能就在这里看到了,make一下!

    叙叙还是个孩子:第一个方法很管用,自从修改了host文件之后,这个讨厌的提示就在也没出现过了。整个心情都舒畅了呢!

    小蛮腰:没错,我这边也这样。感觉是网络运营商的问题吧?

    李彤:现在dns污染太厉害了,不知道是大家都有这个问题还是只哟我们这边是这样。还经常莫名其妙的弹各种广告。

    小蛮腰:我的就经常遇到这个DNS_PROBE_FINISHED_NXDOMAIN,真怀疑是网络运营商网络质量不好。

    乐奇小宝贝:感谢,正好需要这个,成功调换,节省了不少时间。

    林溪:一直在用这个功能,notepad++的这个自动插入html模板的功能真的是非常的实用,用了它,整个人都变懒了,哈哈!

    博主牛逼:博主牛逼啊,这个困扰了我几天的问题终于解决了。找了好久都没找到原因,居然最终是因为用户组问题。

    李小妹:感谢分享,我一直很纳闷,我从开始就禁用了dedecms的模板缓存功能,不知道为什么这个目录下还是会不断产生新文件。百思不得姐!

    匿名网友:我就曾经中过好几次木马,全都是被放在了/data/tplcache/这个目录下,真的很就有迷惑性,好几茬扫描后台病毒扫描出来了我都没注意它,知道有一次无聊打开文件的代码看了一下,才发现是个后门程序。隐藏的太好了,很难发现。

    最爱水煮鱼:新技能get,自从有了chrome浏览器,感觉各种小技能不断get,虽然有些小插件会拖慢浏览器的速度,但是真的是非常的方便!

    林溪:很棒的功能,从来都不知道浏览器浏览网页还能知道网页文件的更新时间的。一直都以为什么时候打开这个页面,文件的时间就会更新一次呢!

    华子:正好有个项目经常需要查询每个网页的产生时间,感谢分享!非常实用的浏览器小技能。

    木头:厉害啊,这么快就做到隔天快照了。我的网站都一年了快照还做不到天天更新。羡慕你啊!

    林西:很正常啊,其实我也会经常盼着百度秒收,哈哈,不过相信这一天很快就来了!好好做好内容好好做好基本的SEO就好了!

    乖兔:嗯呢,有时候我也这么觉得,不过还是总在心里希望百度早早收录,可能是有点急功近利了。

    林西:恭喜,我的网站跟你的差不多,也是天天都更新快照,但是收录很少而且收录的很慢,不过断后路了的排名都很不错这点还是很不错的。这说明首页快照隔天更新应该是一个很不错的表现。所以有时候也不太在意收录数量和收录速度,权重和排名才是更重要的。