当信息不恒定时从WP数据库获取数据

时间:2018-05-18 17:08:05

标签: php mysql wordpress gravity-forms-plugin

这是我的阵列:

    Array
    (
        [0] => Array
            (
                [id] => 1387
                [form_id] => 2
                [date_created] => 2018-05-17 21:34:37
         ---->  [67] => a:1:{i:0;a:7:{s:17:"wp_attachement_id";i:5828;s:9:"mime_type";s:9:"video/mp4";s:9:"file_path";s:89:"/home/xxx/public_html/wp-content/uploads/2018/05/703c94b2b97a6479113d9e3020952891.mp4";s:5:"title";s:3:"xxx";s:11:"description";s:3:"xxx";s:8:"video_id";s:6:"QRSTUV";s:9:"video_url";s:43:"https://www.youtube.com/watch?v=QRSTUV";}}
                [36] => New Harpshire
                [34] => Borristown
            )
   )

以下将打印视频ID:

      $undid = unserialize($entry['0']['67']);
      echo $undid['0']['video_id'];

问题在于数字' 67'不会保持不变。如果我不知道是什么' 67'如何检索那个video_id?会吗?

1 个答案:

答案 0 :(得分:0)

我为你快速Demo

理想情况下,您会找到一种方法将密钥设置为语义名称而不是'67'。但如果你不能,而且总是不同,那么最好的办法是检查期望值

由于您期望序列化数组,我们可以通过unserialize()函数运行序列化值来检查序列化值。 注意:这会触发E_NOTICE级错误,因此您可能希望取消@unserialize()@抑制错误)的错误。虽然抑制错误通常是一个坏主意,但这些是我们期望触发的错误,因此它们应该是安全的。

因此,当我们通过unserialize()传递内容时,我们可以检查它是否将$undid设置为真值。一旦它发生,我们需要确保我们有正确的序列化信息,因此我们可以看到是否设置了$undid[0]['video_id'],如果是,则回显该值(或者您想要的任何其他内容)与它有关),然后break foreach循环,因为一旦满足我们的条件就不再需要运行。

这不是最美丽的解决方案,但除非你能弄清楚如何将这个键命名为file_upload_array之类的语义,否则你最好的选择是循环遍历这些值,直到找到你需要的那个。只要你没有无法想象的数量的字段,这应该可以很快地运作。

$entry = [
    [
        'id' => 1387,
        'form_id' => 2,
        'date_created' => '2018-05-17 21:34:37',
        '67' => 'a:1:{i:0;a:7:{s:17:"wp_attachement_id";i:5828;s:9:"mime_type";s:9:"video/mp4";s:9:"file_path";s:89:"/home/xxxxxxx/public_html/wp-content/uploads/2018/05/703c94b2b97a6479113d9e3020952891.mp4";s:5:"title";s:3:"xxx";s:11:"description";s:3:"xxx";s:8:"video_id";s:6:"QRSTUV";s:9:"video_url";s:43:"https://www.youtube.com/watch?v=QRSTUV22222";}}',
        '36' => 'New Harpshire',
        '34' => 'Borristown',
    ]
];

foreach( $entry[0] as $key => $val ){
    if( $undid = @unserialize( $val ) ){ // unserialize returns E_NOTICE warnings on non-serialized items. @ suppresses that.
        if( isset( $undid[0]['video_id'] ) ){ // Make sure this is the correct serialized field
            echo $undid[0]['video_id'];
            break;
        }
    }
}