通过api内容自动发布一篇文章,遗留了最后一个问题,为文章添加一个自定义字段,添加自定义字段有两个函数可以选择,一个是add_post_meta,另一个是update_post_meta,顾名思义,前者是添加一个,而后者是更新数据之用。但因为update_post_meta首先会检查指定的post_id的meta_key是否已经存在,如果不存在,则会调用add_post_meta,并返回其结果。所以对于性能要求不高的情况下,直接用update_post_meta取代add_post_meta也是可以的,数据比较多的时候,那自然是步骤越简洁越好。
add_post_meta函数
简介
add_post_meta会添加一个一个自定义字段到指定的日志,或者页面中。如果$unique参数被设置为true,并且指定的键值已经存在,那么这个函数返回false并且不对现有的字段做任何修改,否则添加字段并返回true。但$unique设置为false的话,会导致键值不唯一的情况,当使用update_post_meta更新数值时,如果不另行指定指定键的原有值,会导致同名键的值同时被修改,也算是一个安全隐患吧。
用法
<?php add_post_meta($post_id, $meta_key, $meta_value, $unique); ?>
参数
$post_id
(integer) (required) 将要添加自定义字段的日志 ID。
Default: None
$meta_key
(string) (required) 将要添加自定义字段的名称(key)。
Default: None
$meta_value
(mixed) (required) 将要添加自定义字段的值,如果是一个数组,将会被序列化成字符串。
Default: None
$unique
(boolean) (optional) 设置当前的 key 是否为唯一的,当设置为 true,将保证当前日志没有以 $meta_key 作为 key 的自定义字段,并且如果已经存在,则添加不成功。
Default: false
返回值
(bool)
添加成功返回 true,否则返回 false。
用法实例
<?php add_post_meta(68, 'my_key', 47); ?>
添加一个“隐藏”的自定义字段
默认情况下,你添加的自定义字段会在后台日志或者页面编辑器下面自定义区域显示,或者会被 the_meta() 函数可以调用,但是如果你是一个 WordPress 插件或者主题开发者,打算使用自定义字段来存储一些数据,并且不希望用户能够自己修改它,你可以通过给自定义字段的 key 以下划线(“_”)开始,则不会在后台显示。
<?php add_post_meta(68, '_color', 'red', true); ?>
比如上面实例就是添加了一个 key 名为 "_color" 值为 "red" 的自定义字段,这个字段将不会显示在在后台的日志或者页面的编辑页面。另外,如果 $meta_value 是一个数组,也不会显示在后台的日志或者页面的编辑页面。
update_post_meta函数
简介
根据日志 ID 来更新自定义字段。使用 $prev_value 参数来区分同样的 key 和日志 ID 的自定义字段。
如果指定的 $meta_key 不存在,则添加这个自定义字段。
用法
<?php update_post_meta($post_id, $meta_key, $meta_value, $prev_value); ?>
参数
主要参数同add_post_meta基本相同,需要特别注意的是这个参数:
$pre_value
(boolean) (optional) 将要修改的自定义字段原来的值,这是用来区分相同 key 的几个字段,如果省略了,则当前日志下指定 key 的多个值都将被更新。
Default: Empty
用法实例
<?php update_post_meta(76, 'thumb', 'wordpress_thumb.jpg'); ?>
其他实例
假设一个 ID 为 76 的日志,有下面四个自定义字段:
[key_1] => 'Happy'
[key_1] => 'Sad'
[key_2] => 'Gregory'
[my_key] => 'Steve'
将 key_2 的值修改成 'Hans':
<?php update_post_meta(76, 'key_2', 'Hans'); ?>
将 key_1 的值从 'Sad' 修改成 'Happy':
<?php update_post_meta(76, 'key_1', 'Happy', 'Sad'); ?>
现在的字段将如下所示:
[key_1] => 'Happy'
[key_1] => 'Happy'
[key_2] => 'Hans'
[my_key] => 'Steve'
字符转义
自定义字段在存储时通过stripslashes()函数传递,因此在传递可能包含“”转义字符的值(例如 JSON)时需要小心。
避免存储转义值
考虑JSON值{"key":"value with "escaped quotes""}
<?php
$escaped_json = '{"key":"value with \"escaped quotes\""}';
update_post_meta( $id, 'escaped_json', $escaped_json );
$broken = get_post_meta( $id, 'escaped_json', true );
/*
$broken, after passing through stripslashes() ends up unparsable:
{"key":"value with "escaped quotes""}
*/
?>
解决方法
通过使用函数(在 WP 3.6 中引入)添加更多级别的“”转义函数wp_slash,您可以补偿对 stripslashes() 的调用
<?php
$escaped_json = '{"key":"value with \"escaped quotes\""}';
update_post_meta( $id, 'double_escaped_json', wp_slash( $escaped_json ) );
$fixed = get_post_meta( $id, 'double_escaped_json', true );
/*
$fixed, after stripslashes(), ends up being stored as desired:
{"key":"value with "escaped quotes""}
*/
?>