私の Codeigniter コントローラーには、ファイルのアップロードを検証する次のプライベート関数があります。
private function avatar_file_validation()
{
$config['upload_path'] = './uploads/avatars/';
$config['allowed_types'] = 'jpg|png';
$config['overwrite'] = TRUE; //overwrite user avatar
$config['max_size'] = '800'; //in KB
$this->load->library('upload', $config);
if (! $this->upload->do_upload('avatar_upload'))
{
$error_data = array('error' => $this->upload->display_errors());
$this->avatar_view($error_data); //loads view
return FALSE;
}
}
アップロードでエラーが発生した場合、この機能の続行を停止したい
function upload_avatar()
{
//some code
if($_FILES['entry_upload']['error'] !== 4) //if file added to file field
{
$this->avatar_file_validation(); //if returns FALSE stop code
}
//code continues: adds data to database, redirects
}
ただし、false を返しても機能は継続します。1 つの関数でコード全体を使用する場合にのみ機能しますが、複数の関数でアップロードの検証を使用するため、それらを分離する必要があります。ここで何が間違っていますか?