问题描述
我正在尝试将所有包含 http://api.example.com/data/
到 https://example.com/data/
的 URL
在使用 Fat-Free 框架时从数据库的数组中,下面尝试的代码 iv 给了我
内部服务器错误,数组到字符串的转换
$f3->route('GET /details/@itemid',function($f3) {
$arr = array('result' => $f3->get('DBh')->exec('SELECT * FROM DB_table WHERE id=?',$f3->get('ParaMS.itemid')));
str_replace('http://api.example.com/data/','https://example.com/data/',$arr);
$f3->mset($arr);
echo \Template::instance()->render('views/details.html');
}
);
解决方法
好吧,您有几个简单的选项可以帮助您解决这个问题。我还将假设您的意思是引用 $arr['result']
而不仅仅是 $arr
并且我需要假设您只在 db 列中查找一列。我将此列称为 url
。
选项 1
foreach($arr['result'] as $key => $value) {
if(empty($value['url'])) {
continue;
}
$arr['result'][$key]['url'] = str_replace('http://api.example.com/data/','https://example.com/data/',$value['url']);
}
选项 2
foreach($arr['result'] as &$value) {
if(empty($value['url'])) {
continue;
}
$value['url'] = str_replace('http://api.example.com/data/',$value['url']);
}
选项 3
$arr['result'] = array_map(function($value) {
$value['url'] = str_replace('http://api.example.com/data/',$value['url']);
return $value;
},$arr['result']);
我个人对可读性和简单性的偏好是选项 2。我相信 foreach 语句已经过优化,实际上比 array_map 运行得更快,这……很有趣。