sql >> データベース >  >> RDS >> Mysql

Word文書をアップロードし、それをmysqlに保存して、表示します

    ここで説明するトピックがいくつかあります。

    フォーム

    ファイルをアップロードするには、フォームのenctype属性を変更します。

    <form action="insert.php" method="post" enctype="multipart/form-data">
        :
    </form>
    

    ファイルの保存

    ファイルをデータベースに保存することも、サーバーディスクシステムにファイルとして保存することもできます。どちらを選択しても、ファイルをその行に分割する必要はありません。ファイルを単一のユニットとして保存します。

    トピックについて説明しているこのエントリをお読みください。

    ここで、データベースフィールドは、ファイルを保持するための適切なタイプとサイズである必要があると言えば十分です。

    個人的には、ファイルをディスクに保存し、ファイル名をデータベースに保存するのが好きです。

    ファイルのアップロード処理

    ファイルをディスクに保存できます。これはそれを行うための最良の方法ではありませんが、最も簡単にデモを行うことができます。 SOには十分な例があります。たとえば、希望の名前でファイルをアップロードして保存する方法

     $info = pathinfo($_FILES['upload']['name']);
     $ext = $info['extension']; // get the extension of the file
     $newname = "newname.".$ext; 
    
     $target = 'mydocs/'.$newname;
     move_uploaded_file( $_FILES['upload']['tmp_name'], $target);
    

    ファイルのダウンロード ファイルを表示してダウンロードするには、コンテンツをブラウザに印刷するだけです。

    ob_start();
     // do things. See below
    ob_clean();
    flush();
    readfile($file);
    ob_flush();
    

    これによりファイルが表示され、ブラウザが混乱する可能性があります。ファイルをWord文書として処理するようにブラウザに指示するには、ファイルを送信する前に適切なヘッダーをブラウザに送信する必要があります。

        ob_start();
        if(isset($_REQUEST['dlink']))
        {
            $file = $_REQUEST['dlink'];
            header('Content-Description: File Transfer');
            header('Content-Type: application/octet-stream');
            header('Content-Disposition: attachment; filename='.basename($file));
            header('Content-Transfer-Encoding: binary');
            header('Expires: 0');
            header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
            header('Pragma: public');
            header('Content-Length: ' . filesize($file));
            ob_clean();
            flush();
            readfile($file);
             exit;
        }
    ob_flush();
    



    1. MySQLのAES_ECRYPT関数を使用して値を暗号化し、PHPを使用してURL文字列で値を渡します

    2. 同じIDのselectを使用して、選択した列の値を別の行に変換しますpart2

    3. PL/pgSQL匿名コードブロック

    4. OracleのEntityFrameworkサポートを使用してパスカルケースを強制するにはどうすればよいですか?