控制器
public function uploadFile()
{
if(isset($_POST["uploadFile"])){
$filePath = realpath($_FILES["file"]["tmp_name"]); //GETTING THE FULL PATH OF THE FILE WHICH WANTS TO BE SAVED INTO THE DB
$arr = [];
if (($handle = fopen($filePath, 'r')) !== FALSE){
$i = 0;
while (($lineArray = fgetcsv($handle, 4000)) !== FALSE){
for ($j=0; $j<count($lineArray); $j++){
$arr[$i][$j] = $lineArray[$j];
} $i++;
} fclose($handle);
}
$csv = array_slice($arr,1);
foreach($csv as $line){
mysqli_query($mysqli, "INSERT INTO dialog(`eType`,`eVal`,`intent`,`reply`) VALUES('$line[0]','$line[1]','$line[2]','$line[3]')"); //FOR EACH LINE SAVE INTO THE DB
}
}
}
路线
Route::get('uploadFile', 'Chatbot\ChatbotController@uploadFile');
查看
<form method="post" action="{{action('AltHr\Chatbot\ChatbotController@uploadFile')}}" enctype="multipart/form-data">
<input type="file" name="file"> <br>
<button type="submit" name="uploadFile" class="btn alt-btn-black btn-xs alt-btn">UPLOAD FILE</button>
</form>
所以,它是我学习laravel的第一天,有人可以告诉我为什么我在RouteCollection.php中有这个错误 MethodNotAllowedHttpException
我正在尝试将表单中的 CSV 文件上传到数据库。我在这做错了什么?
答案 0 :(得分:3)
你的路线错了。上传是POST
请求,所以:
Route::post('uploadFile', 'Chatbot\ChatbotController@uploadFile');
答案 1 :(得分:-1)
真正的问题是:为什么不使用Eloquent或至少使用QueryBuilder插入数据库