开发者

Limiting file upload type

Simple question. Is there a way to only allow txt files upon uploading? I've开发者_Go百科 looked around and all I find is text/php, which allows PHP.

$uploaded_type=="text/php


When you upload a file with PHP its stored in the $_FILES array. Within this there is a key called "type" which has the mime type of the file EG $_FILES['file']['type']

So to check it is a txt file you do

if($_FILES['file']['type'] == 'text/plain'){
    //Do stuff with it.
}

It's explained very well here. Also, don't rely on file extentions it's very unreliable.


Simply put: there's no way. Browsers don't consistently support type limiters on file upload fields (AFAIK that was planned or even is integrated into the HTML standard, but barely implemented at best). Both the file extension and mime-type information are user supplied and hence can't be trusted.

You can really only try to parse the file and see if it validates to whatever format you expect, that's the only reliable way. What you need to be careful with are buffer overflows and the like caused by maliciously malformed files. If all you want are text files, that's probably not such a big deal though.


You could check the mime type of the uploading file. In codeIgniter, this code is used in the upload library:

$this->file_type = preg_replace("/^(.+?);.*$/", "\\1", $_FILES[$field]['type']);

The variable $this->file_type then used to check the upload configuration, to see if the uploaded file is in allowed type or not. You can see the complete code in the CodeIgniter upload library file.


You need to check the file extension of the uploaded file.

There is Pear HttpUpload, it supports this.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜