質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

アップロード

アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

Q&A

解決済

1回答

2112閲覧

ユーザが入力するファイル名について(PHP)

alehalehaleh

総合スコア110

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

アップロード

アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

0グッド

0クリップ

投稿2014/11/22 01:00

PHPでユーザがファイルをアップロードできるフォームがあり、それらのファイル名を[id][lastname][firstname].pdfという形にしたいと考えています。

ファイル名はユーザによって入力されているのですが、ファイル名の中にスラッシュを入れてしまわないかが不安になっています。

ユーザが名前を設定する際に何か制限を設けようかとは思っていません。

もともとの名前がわかるのであればファイル名の中の名前を少し変えてもいいと思っています。他に何か避けるべき文字はありますか?

mysql_real_escape_stringを使う案も考えていますが、他にいい方法がありましたら教えて下さい。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

mysql_real_escape_string()関数を使用してもスラッシュを避けることは出来ないですし、escapeshellarg()関数を使っても不可能だと思います。

下記のstr_replace()関数を使った方法がいいと思います。

$path = 'uploads/1_yamada_kenji/hogehoge.pdf';
$file_name = str_replace('/' , '_', $path);

投稿2014/11/22 02:58

rupin

総合スコア72

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問