我是一名在网站上的公司工作的新开发人员。我们有一个导入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有关。
如果有人对这类问题有所了解,请告诉我,谢谢!
答案 0 :(得分:0)
使用getExtension()
方法代替guessExtension()
。 getExtension()
根据文件名返回文件扩展名,而另一种方法根据mime类型返回文件扩展名。
答案 1 :(得分:0)
对于任何可能在将来看这个的人,我发现了问题。基本上Symfony中的xls mime类型已经过时且错误。 guessExtension调用guessMimeType来计算导入文件的mime类型,然后guessExtension使用guessMimeType返回的mime类型来猜测扩展名。 guessExtension方法引用了一个mime类型列表来执行此操作,问题是该列表中的xls mime类型错误,很可能只是过时了。我找到了当前的xls mime类型,并用好的替换了列表中的那个,并且它工作了