doddsey_65 Posted January 16, 2011 Share Posted January 16, 2011 i am trying to get the allowed file types from the database into a switch statement but with no luck so far. They types are in the database like: jpg, png, gif. All seperated with a comma and all in one db column. I am then splitting them at the comma and inserting them into $file_list. In the switch statement i want it to be like: switch($ext) { case "jpg": case "png": case "gif": break; } how can i make this possible? here is my code so far: $ext = strtolower(pathinfo($_FILES['Filedata']['name'], PATHINFO_EXTENSION)); $f_types = $f_types_info['file_types']; $f_types = preg_split("|\,|", $f_types); $types = count($f_types); $file_list = ""; for($i=0; $i<$types; $i++) { $file_list .= $f_types[$i]; } switch ($ext) { case $file_list: break; default: $error = "File Type Not Allowed"; break; } Quote Link to comment https://forums.phpfreaks.com/topic/224589-for-loop-to-populate-switch-statement/ Share on other sites More sharing options...
kenrbnsn Posted January 16, 2011 Share Posted January 16, 2011 You're over thinking this. Just use explode to put the allowed filetypes into an array and in_array to see if the extension is valid: <?php $ext = strtolower(pathinfo($_FILES['Filedata']['name'], PATHINFO_EXTENSION)); $f_types = explode(',',$f_types_info['file_types']); $error = (!in_array($ext,$f_types))?'File Type Not Allowed':''; ?> Ken Quote Link to comment https://forums.phpfreaks.com/topic/224589-for-loop-to-populate-switch-statement/#findComment-1160152 Share on other sites More sharing options...
Anti-Moronic Posted January 16, 2011 Share Posted January 16, 2011 You should instead look into in_array(). Makes this very simple: $allowed_exts = array('jpg','png'); $file_ext = 'jpg'; if(!in_array($file_ext, $allowed_exts)){ $error = "File Type Not Allowed"; } ..ken beat me to it. Well, here's a simple example anyhow. Quote Link to comment https://forums.phpfreaks.com/topic/224589-for-loop-to-populate-switch-statement/#findComment-1160153 Share on other sites More sharing options...
doddsey_65 Posted January 16, 2011 Author Share Posted January 16, 2011 thanks for the help. I cant get it to work though. It shows an error on allowed extensions. here is the code now: $ext = strtolower(pathinfo($_FILES['Filedata']['name'], PATHINFO_EXTENSION)); $f_types = explode(',',$f_types_info['file_types']); if (!in_array($ext, $f_types)) { $error = "File Type (.$ext) Not Allowed<br />Only $f_types[1] are allowed"; } but when i load something with ext .jpg it shows an error even though .jpg is in the array list: content of db table: .jpg, .jpeg, .png, .gif Quote Link to comment https://forums.phpfreaks.com/topic/224589-for-loop-to-populate-switch-statement/#findComment-1160154 Share on other sites More sharing options...
kenrbnsn Posted January 16, 2011 Share Posted January 16, 2011 You said the extensions were comma separated, not comma-space. You have to explode on ", ": <?php $f_types = explode(', ',$f_types_info['file_types']); ?> Ken Quote Link to comment https://forums.phpfreaks.com/topic/224589-for-loop-to-populate-switch-statement/#findComment-1160155 Share on other sites More sharing options...
doddsey_65 Posted January 16, 2011 Author Share Posted January 16, 2011 if only i could think before posting lol. Thanks for the addon info ken. Works perfect. Quote Link to comment https://forums.phpfreaks.com/topic/224589-for-loop-to-populate-switch-statement/#findComment-1160156 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.