Fatal error: Uncaught Error: Call to und

帝国EmpireCMS前台没有问题,后台登陆空白,打开php错误提示以及数据库连接提示,出现如下错误提示:

Fatal error: Uncaught Error: Call to undefined function mysql_connect() in /www/wwwroot/

解决方案:

当前使用的PHP版本高了,不支持mysql_connect函数,改用PHP 5.6或其以下版本的就好了。

手动更新WordPress

在线升级不行可以下载最新版的程序包手动升级。

在升级之前:

  • 请确保备份旧有数据以及被您修改过的文件,例如index.php、footer.php。
  • 再次记得备份修改过的内容。
  • 下载最新版的然后删掉wp-content文件夹,其它的通过FTP等工具手动上传覆盖。
  • 在浏览器中访问/wp-admin/upgrade.php

升级WordPress时提示”另一更新正在进行”原因与解决办法

升级WordPress时由于国内连接WP服务器慢会造成更新中途停止,并在数据库wp_options表中增加core_updater.lock记录,当再次更新时会提示:另一更新正在进行。

这是由于在升级Wordpress时,Wordpress会在数据库wp_options表中增加core_updater.lock记录。如中途打断Wordpress升级,这个记录会留在数据库中。当下次升级时,Wordpress检测到此记录的存在就会返回”另一更新正在进行”。

可通过以下方法解决:
1、通过phpmyadmin或navicat等工具管理Wordpress数据库,在wp_options表中找到core_updater.lock记录并删除。
2、将下面的代码添加到当前主题函数模板 functions.php 中:

global $wpdb;
$wpdb->query("DELETE FROM wp_options WHERE option_name = 'core_updater.lock'");

core_updater.lock.JPG

添加之后,刷新一下网站页面,会自动删除该记录,可以正常升级程序了。该代码运行一次就够了,没有必要留在主题中,用后删除即可。

另外,升级插件如果出现错误,可能会一直显示“正在执行例行维护,请一分钟后回来。”的提示,可以FTP进入在WP程序目录中找到.maintenance文件,删除即可。

Typecho文章浏览次数统计

介绍
一个cookie统计1次,不清空浏览器缓存不会增加次数,只有别人再访问才会增加

1. function.php 页面底部加入代码

function get_post_view($archive)
{
    $cid    = $archive->cid;
    $db     = Typecho_Db::get();
    $prefix = $db->getPrefix();
    if (!array_key_exists('views', $db->fetchRow($db->select()->from('table.contents')))) {
        $db->query('ALTER TABLE `' . $prefix . 'contents` ADD `views` INT(10) DEFAULT 0;');
        echo 0;
        return;
    }
    $row = $db->fetchRow($db->select('views')->from('table.contents')->where('cid = ?', $cid));
    if ($archive->is('single')) {
 $views = Typecho_Cookie::get('extend_contents_views');
        if(empty($views)){
            $views = array();
        }else{
            $views = explode(',', $views);
        }
if(!in_array($cid,$views)){
       $db->query($db->update('table.contents')->rows(array('views' => (int) $row['views'] + 1))->where('cid = ?', $cid));
array_push($views, $cid);
            $views = implode(',', $views);
            Typecho_Cookie::set('extend_contents_views', $views); //记录查看cookie
        }
    }
    echo $row['views'];
}

2. 在需要的地方引入代码

<?php get_post_view($this) ?>

在首页添加计数
打开文件: usr/themes/default/index.php
找到下面行:

<li itemprop="interactionCount"> <a itemprop="discussionUrl" href="<?php $this->permalink() ?>#comments"><?php $this->commentsNum('评论', '1 条评论', '%d 条评论'); ?></a></li> 

添加:

<li><span class="view-times"><?php get_post_view($this) ?>次浏览</span></li> 

在文章内容页添加计数
打开文件: usr/themes/default/index/post.php
找到下面行:

<li><?php _e('分类: '); ?><?php $this->category(','); ?></li>

在后面添加:

<li><span class="view-times"><?php get_post_view($this) ?>次浏览</span></li> 

Linux安装ss

安装ss
CentOS

yum install python-setuptools && easy_install pip
pip install shadowsocks

Debian/Ubuntu

apt-get install python-pip
pip install shadowsocks

配置ss
ss启动时可通过命令参数或配置文件,本文采用配置文件的方式,好处就是修改方便。 创建/etc/shadowsocks.json文件,例如

{
    "server":"my_server_ip",
    "server_port":8388,
    "local_address": "127.0.0.1",
    "local_port":1080,
    "password":"mypassword",
    "timeout":300,
    "method":"aes-256-cfb",
    "fast_open": false
}

其中主要配置server,server_port,password字段,其中server为上步购买的服务器ip地址,server_port可选择一个大于1024的端口,password填入连接密码,后面需要用到。

启动ss

nohup ssserver -c /etc/shadowsocks.json &

执行

ps -ef | grep ssserver

若结果中含有类似
/usr/bin/python /usr/bin/ssserver -c /etc/shadowsocks.json
输出,则表示服务启动成功。

配置文件shadowsocks.json

配置文件shadowsocks.json

/etc/shadowsocks/config.json

{
    "server":"my_server_ip",
    "server_port":8388,
    "local_address": "127.0.0.1",
    "local_port":1080,
    "password":"mypassword",
    "timeout":300,
    "method":"aes-256-cfb",
    "fast_open": false,
    "workers": 1,
    "prefer_ipv6": false
}

名称 解释
server 服务端监听地址
server_port 服务端端口
local_address 本地监听地址
local_port 本地端口
password 用于加密的密码
timeout 超时时间(秒)
method 默认为 aes-256-cfb,参阅 Encryption
mode 是否启用 TCP / UDP 转发,参阅 shadowsocks-libev(8)
fast_open 是否启用 TCP Fast Open
workers worker 数量