csv没有使用laravel上传到db

时间:2017-07-19 05:44:42

标签: php mysql laravel laravel-5

控制器

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 文件上传到数据库。我在这做错了什么?

2 个答案:

答案 0 :(得分:3)

你的路线错了。上传是POST请求,所以:

Route::post('uploadFile', 'Chatbot\ChatbotController@uploadFile');

答案 1 :(得分:-1)

真正的问题是:为什么不使用Eloquent或至少使用QueryBuilder插入数据库