PHPでのファイルアップロード処理で二重送信での重複した処理に対して、
その重複したデータを許す場合の処理について質問です。
PHP
1$path ='../upload/' . bin2hex(openssl_random_pseudo_bytes(32) . mime_content_type($_FILES['upfile']['tmp_name']); 2 3//アップロード先に存在しないファイル名を生成するまでループ 4while (is_file($path)){ 5 $path = '../upload/' . bin2hex(openssl_random_pseudo_bytes(32) . mime_content_type($_FILES['upfile']['tmp_name']); 6}; 7 8fopen($path , 'x'); 9 10move_uploaded_file($_FILES['upfile']['tmp_name'], $path);
fopen関数のモードxでファイルを作成した後、move_uploaded_fileでファイルを移動させているのですが、ここでのfopen関数は必要でしょうか?
そもそも「重複データを許す」とはどういう意味でしょうか? 同一ディレクトリに同じファイル名は通常許可されないと思いますが…上書きするという意味ですか? それとも、二重に送信されても別ファイル名で保存するという意味ですか?
二重に送信されても別ファイル名で保存するという意味で質問させていただきました。ファイル名を生成してからmove_uploaded_fileをする間に他の送信との競合を防ぐ為fopenで排他的にファイルを作成という処理のつもりでした。
了解しましたが、このプログラムはコンパイルエラーになりますよね。1行目の 32) のところは、32)) でないと括弧の対応があいません。そこを修正して動かしたところ、../upload/7421d91290e9e579d8c56cca54919b07a795459d22928baf0ba482cff20820a9application/octet-stream のようなファイル名になりました。これは意図した動作ではないように思えます。せめて手元でテストしてから質問されたらいかがでしょうか?
回答1件
あなたの回答
tips
プレビュー