Avatar billede ss Nybegynder
26. november 2007 - 19:12 Der er 1 kommentar

problem med upload - sikkerhedshul

Hejsa alle herinde

Jeg har et uploadscript i PHP.
Jeg har dog fundet et rimeligt stort sikkerhedshul der går ud på at man kan åbne en flat file text editor, skrive noget javascript, gemme det som et-eller-andet.png uploade det via php-scriptet og javascript koden bliver udført når man åbner billedet på serveren.

Min kode ser sådan her ud:
----------------------------------------------------------------------

       

        public function uploadAttachments($articleid){

            $maxsize = $this->maxsize;

            $path = "../Attachments/Articles/" . $articleid;

            $allowedext = $this->allowedext;

            $seterror = false;

            if(count($_FILES) > 0){

                foreach ($_FILES["file"]["error"] as $key => $error) {

                   

                    if ($error == UPLOAD_ERR_OK) {

                        if(!file_exists($path))

                            mkdir($path);

                        $filepath = opendir($path);

                        $totalsize = 0;

                        while (false !== ($file = readdir($filepath))) {

                            if($file != "." && $file != ".."){

                                $totalsize = $totalsize + filesize($path . "/" . $file);

                            }

                        }

                        closedir($filepath);

                       

                        if($_FILES["file"]["size"][$key] + $totalsize > $maxsize)

                            return "error_maxsize";



                        $name = $_FILES["file"]["name"][$key];

                        $ext = strtolower(end(explode(".", $name)));

                        $name = str_replace("." . $ext, "", $name);

                        $name = main::caturlname($name);

                        if($ext == "jpeg")

                            $ext = "jpg";

                        $totalpath = $path . "/" . $name;

                        $count = 0;

                        while(file_exists($totalpath . $name_ext . "." . $ext)){

                            $count++;

                            $count++;

                            $name_ext = " (". $count .")";

                            $count--;

                        }

                       

                            if(in_array($ext, $allowedext)){

                                $tmp_name = main::clean($_FILES["file"]["tmp_name"][$key]);

                                move_uploaded_file($tmp_name, main::clean($path . "/" . $name . $name_ext .".". $ext));

                            } else {

                                $seterror = true;

                            }

                    }

                }

               

                if($seterror == true)

                    return false;

            }

            return true;

        }
-------------------------------------------------------------------------

Mvh. ss
Avatar billede showsource Seniormester
27. november 2007 - 07:31 #1
Du kan bruge getimagesize() til at tjekke det er et billede
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester