wordpress 3.0 中使用session

wordpress在处理query variables时,会对$_GET和$_POST变量进行处理,大概是这样子:对$_GET和$_POST数组进行遍历,将数据的key处理为php变量,举个例子,有一个值为$_GET['category_name'] or $_POST['category_name']的query variables,wordpress处理后就会把它变为$category_name变量,这样就可以使用$category_name变量了。

然后就会华丽的忽略SESSION。在3.0版本中在wp-includes/load.php下第23行,唯独没有Session变量!

// Variables that shouldn't be unset
$no_unset = array( 'GLOBALS', '_GET', '_POST', '_COOKIE', '_REQUEST', '_SERVER', '_ENV', '_FILES', 'table_prefix' );

那我要想在wordpress中使用SESSION,该怎么办咧?

我们可以使用Filter Reference,手动开启SESSION

具体代码如下,例如我想在single模板下特定的文章页面使用Session


//开启SESSION
add_action('init','session_manager');
function session_manager(){
session_start();
}
add_filter('single_template','session_single');
function session_single(){
//判斷特定的文章頁面
if(is_single('108') || is_single('106') ||is_single('74') || is_single('131') || is_single('128')){
$_SESSION[session_id()] = true;
}
}

参考资源:

Enabling Sessions in WordPress 3.0

How To: Enable the Use of Sessions On Your WordPress Blog

wordpress对请求的处理 简单架构

WordPress Code Flow

wp-setting.php文件详解

学习vim

因为在工作中不可避免用用到linux主机,要操作终端,但是我对vi编辑器一筹莫展,总是看黑糊糊的框框感到很无奈,功力不够啊,想在终端操作文本,还是有困难,觉得需要认真学习下vi编辑器的操作。

以下文章参考Vi编辑器的基本使用方法进行整理,版权归原作者所有。

基本上vi可以分为三种状态,分别是

命令模式(command mode):控制屏幕光标的移动,字符、字或行的删除,移动复制某区段及进入Insert mode下,或者到 last line mode。

插入模式(Insert mode):只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。

底行模式(last line mode):将文件保存或退出vi,也可以设置编辑环境,如寻找字符串、列出行号……等。

不过一般我们在使用时把vi简化成两个模式,就是将底行模式(last line mode)也算入命令行模式command mode)。

vi的基本操作

在系统提示符号输入vi及文件名称后,就进入vi全屏幕编辑画面:

$ vi myfile

不过有一点要特别注意,就是您进入vi之后, 是处于「命令行模式(command mode)」,您要切换到「插入模式(Insert mode)」才能够输入文字。初次使用vi的人都会想先用上下左右键移动光标,结果电脑一直哔哔叫,把自己气个半死,所以进入vi后,先不要乱动,转换到 「插入模式(Insert mode)」再说吧!

切换插入模式:在「命令行模式(command mode)」下按一下字母「i」就可以进入「插入模式(Insert mode)」,这时候你就可以开始输入文字了。

目前处于「插入模式(Insert mode)」,您就只能一直输入文字,如果您发现输错了字!想用光标键往回移动,将该字删除,就要先按一下「ESC」键转到「命令行模式(command mode)」再删除文字

退出vi及保存文件

在「命令行模式(command mode)」下,按一下「:」冒号键进入「Last line mode」,例如:

: w filename (输入 「w filename」将文章以指定的文件名filename保存)

: wq (输入「wq」,存盘并退出vi)

: q! (输入q!, 不存盘强制退出vi)

命令行模式(command mode)功能键

插入模式

「i」切换进入插入模式「insert mode」,按“i”进入插入模式后是从光标当前位置开始输入文件;

「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字;

「o」进入插入模式后,是插入新的一行,从行首开始输入文字。

从插入模式切换为命令行模式

「ESC」键。

移动光标

vi可以直接用键盘上的光标来上下左右移动,但正规的vi是用小写英文字母「h」「j」「k」「l」,分别控制光标左、下、上、右移一格。

按「ctrl」+「b」:屏幕往“后”移动一页。

按「ctrl」+「f」:屏幕往“前”移动一页。

按「ctrl」+「u」:屏幕往“后”移动半页。

按「ctrl」+「d」:屏幕往“前”移动半页。

按数字「0」:移到文章的开头。

按「G」:移动到文章的最后。

按「$」:移动到光标所在行的“行尾”。

按「^」:移动到光标所在行的“行首”

按「w」:光标跳到下个字的开头

按「e」:光标跳到下个字的字尾

按「b」:光标回到上个字的开头

按「#l」:光标移到该行的第#个位置,如:5l,56l。

删除文字

「x」:每按一次,删除光标所在位置的“后面”一个字符。

「#x」:例如,「6x」表示删除光标所在位置的“后面”6个字符。

「X」:大写的X,每按一次,删除光标所在位置的“前面”一个字符。

「#X」:例如,「20X」表示删除光标所在位置的“前面”20个字符。

「dd」:删除光标所在行。

「#dd」:从光标所在行开始删除#行

复制

「yw」:将光标所在之处到字尾的字符复制到缓冲区中。

「#yw」:复制#个字到缓冲区

「yy」:复制光标所在行到缓冲区。

「#yy」:例如,「6yy」表示拷贝从光标所在的该行“往下数”6行文字。

「p」:将缓冲区内的字符贴到光标所在位置。注意:所有与“y”有关的复制命令都必须与“p”配合才能完成复制与粘贴功能。

替换

「r」:替换光标所在处的字符。

「R」:替换光标所到之处的字符,直到按下「ESC」键为止。

回复上一次操作

「u」:如果您误执行一个命令,可以马上按下「u」,回到上一个操作。按多次“u”可以执行多次回复。

更改

「cw」:更改光标所在处的字到字尾处

「c#w」:例如,「c3w」表示更改3个字

跳至指定的行

「ctrl」+「g」列出光标所在行的行号。

「#G」:例如,「15G」,表示移动光标至文章的第15行行首。

Last line mode下命令简介

在使用「last line mode」之前,请记住先按「ESC」键确定您已经处于「command mode」下后,再按「:」冒号即可进入「last line mode」。

列出行号

「set nu」:输入「set nu」后,会在文件中的每一行前面列出行号。

跳到文件中的某一行

「#」:「#」号表示一个数字,在冒号后输入一个数字,再按回车键就会跳到该行了,如输入数字15,再回车,就会跳到文章的第15行。

查找字符

「/关键字」:先按「/」键,再输入您想寻找的字符,如果第一次找的关键字不是您想要的,可以一直按「n」会往后寻找到您要的关键字为止。

「?关键字」:先按「?」键,再输入您想寻找的字符,如果第一次找的关键字不是您想要的,可以一直按「n」会往前寻找到您要的关键字为止。

保存文件

「w」:在冒号输入字母「w」就可以将文件保存起来。

离开vi

「q」:按「q」就是退出,如果无法离开vi,可以在「q」后跟一个「!」强制离开vi。

「qw」:一般建议离开时,搭配「w」一起使用,这样在退出的时候还可以保存文件。

看到这里说明你是真的很喜欢vim啦,这里有一份用VIM 做 PHP 开发环境的教程 ,好东东哦

下面还有一些可能对你会有用的链接:

VIM之NERDtree说明

初学者简易 .vimrc 编写指南

2010.11.12 Update(C、C++、java、c#版):

把VIM打造成一个真正的IDE(1)

把VIM打造成一个真正的IDE(2)

把VIM打造成一个真正的IDE(3)

vim所支持的自动完成详解

2010.11.13 Update(Windows下的IDE配置):

手把手教你把Vim改装成一个IDE编程环境(图文Version:0.5)

手把手教你把Vim改装成一个IDE编程环境(在线pdf 0.7版)

你也可以在我的博客上阅读

这里有一个具有类似于IDE功能的容易安装的VIM

php的AOP编程实例

最近研究下php下面的AOP实现,在网上也看到不少的文章,老王在他的手册里利用魔术方法实现准AOP 这个方法很好。

下面是实例代码

//应用程序中某个业务逻辑类
class BIZ
{
      public function foobar(){
           echo '业务逻辑<br />';
     }
}

//业务逻辑类的包装类
class AOP
{
    private $instance;

    public function __construct($instance){
        $this->instance = $instance;
    }

    public function __call($method, $argument){
        if(! method_exists($this->instance, $method)){
            throw new Exception('未定义的方法:' . $method);
        }

        echo '权限检查<br />';

        $callBack = array($this->instance, $method);

        $return = call_user_func_array($callBack, $argument);

        echo '日志记录<br />';

        return $return;
}
}

//工厂方法
class Factory
{
    public function getBizInstance(){
        return new AOP(new BIZ());
    }
}

//客户端调用演示
header("Content-Type: text/html; charset=utf8");

try
{
    $obj = Factory::getBizInstance();

    $obj->foobar();
}
catch(Exception $e)
{
    echo 'Caught exception: ',  $e->getMessage();
}

当然,很优雅的利用php5内置的魔术方法__call来实现AOP,唯一的缺点是要在AOP类里面实例客户端对象,返回的是被AOP包装后的对象,这样在get_class会有一些麻烦!

在看PHP实战的时候发现可以不用在AOP类里面实例客户端对象,但是需要继承一个父类。

部分代码如下,对书上的例子稍作修改。

//要记录方法调用的父类
class loggingClass{
    function __call($method,$args){
        if(strchr($method,'Aop_')){
            $method = str_replace('Aop_','',$method);
            if(!method_exists($this,$method)){
                throw new Exception("Call undefinded method ".get_class($this)."::$method");
           }
            $log = Log::getInstance();
            $log->log("调用方法".$method."之前做点啥");
            $return = call_user_func_array(array($this,$method),$args);
            $log->log("调用方法".$method."后再做点啥");
            return $return;
       }
   }
}

利用父类的魔术方法__call实现记录日志操作,当从客户端调用不存在的方法,__call会拦截它,然后就开始记录日志,调用真正的方法,然后日志记录结束。在这个例子中,我修改对方法的判断,只有调用以Aop_为前缀的方法时才会调用__call方法。

//具体的日志记录类
class Log{
    private static $log;
    function __construct(){

    }
    static function getInstance(){
        if(self::$log == null){
            self::$log = new Log();
        }
        return self::$log;
    }
    function log($str){
        echo $str.'<br/>';
    }

}

实现一个具体的日志类的单一实例的方法

//带有可记录日子方法的Date类
class Date extends loggingClass{
    private $timestamp;
    function __construct($timestamp = false){
        $this->setinit($timestamp);
    }
    protected function setinit($timestamp){
        $this->timestamp = $timestamp?$timestamp:time();
    }
    protected function setTime(){
        echo '业务逻辑<br/>';
    }
}
$date = new Date();
$date->Aop_setTime();

具体的业务逻辑类,需要继承loggingClass类,然后就可以开始调用,在这个例子中,客户端是不能调用该类中的setTime方法,因为是protected属性,可修改为public这样客户端进行实例就能调用了。如果有的同学对这样实现起来不是很满意的话,这里有牛人用.net的思想实现的AOP,扩展性很强,当然代码也很多,请看
PHP三层结构(上)——简单三层结构
PHP三层结构(下)——PHP实现AOP