无法导入.xls - Symfony PHP

时间:2016-04-05 16:04:55

标签: php excel symfony import xls

我是一名在网站上的公司工作的新开发人员。我们有一个导入excel文件的错误,它不接受xls作为有效的扩展,但接受xlsx和其他。这是给出错误的方法。

public function orderAddUload(Request $ request){

    /*
    Filepath: /web/uploads/files/{entity_name}/{entity_id}/{filename}
     */

    $response = array();

    $entity = $request->request->get('upload_entity');
    $id     = $request->request->get('upload_id');
    $user   = $this->get('security.context')->getToken()->getUser();

    $em = $this->getDoctrine()->getManager();

    $valid_ext = array( 'doc', 'docx', 'xls', 'xlsx', 'pdf', 'txt', 'gif', 'jpg', 'jpeg', 'png' );

    $file = $request->files->get('files');
    if( is_array($file) ) $file = reset( $file );


    try{
        if( empty($file) ){
            throw new Exception($this->get('translator')->trans('upload.failure'), 1);
        }

        if( ! in_array($file->guessExtension(), $valid_ext) ){
            throw new Exception($this->get('translator')->trans('file.invalid.extension')." (" . $file->guessExtension() . "), ".$this->get('translator')->trans('only')." ".implode( ', ', $valid_ext ) . " ".$this->get('translator')->trans('are.accepted').".", 2);
        }

        $upload = new Upload();
        $upload
            ->setFiletype( $file->guessExtension() )
            ->setEntityName( $entity )
            ->setEntityId( $id )
            ->setUploader( $user );

        $name    = basename( $file->getClientOriginalName(),  '.' . $file->getClientOriginalExtension() );
        $ext     = $file->guessExtension();
        $counter = 1;

        $newname = "{$name}.{$ext}";

        while( file_exists($newname) ){
            $newname = "{$name}_{$counter}.{$ext}";
            $counter++;
        }

        $upload->setFilename( $newname );

        $file->move( $upload->getFilePath(), $upload->getFilename() );

        $em->persist( $upload );
        $em->flush();


    }catch(Exception $e){
        return new Response( json_encode(array( 'type' => 'error', 'message' => $e->getMessage(), )) );
    }

    $response['code'] = 'uploaded';

    return new Response( json_encode($response) );
}

据我所知,当我尝试导入xls文件时,它将扩展名返回为NULL而不是xls,并抛出Exception'file.invalid.extension'。

我不明白为什么会发生这种情况,因为xls是在$ valid_ext数组中定义为有效的exentions之一。导入该阵列中的所有其他扩展没有问题。我深入研究了guessExtension方法,并进一步使用了它所使用的guessMimeType,但是在这些方面似乎一切正常。

当我注释掉Exception'file.invalid.extension'并尝试导入xls文件时,我得到的错误告诉我文件类型列不能为NULL,这与SQL有关。

如果有人对这类问题有所了解,请告诉我,谢谢!

2 个答案:

答案 0 :(得分:0)

使用getExtension()方法代替guessExtension()getExtension()根据文件名返回文件扩展名,而另一种方法根据mime类型返回文件扩展名。

答案 1 :(得分:0)

对于任何可能在将来看这个的人,我发现了问题。基本上Symfony中的xls mime类型已经过时且错误。 guessExtension调用guessMimeType来计算导入文件的mime类型,然后guessExtension使用guessMimeType返回的mime类型来猜测扩展名。 guessExtension方法引用了一个mime类型列表来执行此操作,问题是该列表中的xls mime类型错误,很可能只是过时了。我找到了当前的xls mime类型,并用好的替换了列表中的那个,并且它工作了