0

ファイル (すべての形式) をサーバーにアップロードし、ファイルの場所をデータベース (MySQL) に保存したいロングブロブ形式を使用してデータベースにファイル (すべての形式) を保存しようとしましたが、次のファイルサイズを受け入れません1kb以下で、テキストファイルのみを受け入れます。ここに私のhtmlコードがあります

<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>JSP Page</title>
</head>
<body>
    <form enctype="multipart/form-data" action="upload.jsp" method="post">
        <br/><br/><br/>
        <center>
            <table border="0" bgcolor=#ccFDDEE>
                <tr>
                    <td colspan="2" align="center"><b>UPLOAD THE FILE</b></td>
                </tr>
                <tr>
                    <td colspan="2" align="center"> </td>
                </tr>
                <tr>
                    <td><b>Choose the file To Upload:</b></td>
                    <td><INPUT NAME="file" TYPE="file">      </td>
                </tr>
                <tr>
                    <td colspan="2" align="center"> </td>
                </tr>
                <tr>
                    <td colspan="2" align="center"><input type="submit" value="Send File"> </td>
                </tr>
            <table>
        </center> 
    </form>
</body>
</html>

ファイルをデータベースに保存するためのjspコードを次に示します(ロングブロブを使用)。

<%@ page import="java.io.*,java.sql.*" %>
<%
String saveFile="";
String contentType = request.getContentType();
if ((contentType != null) && (contentType.indexOf("multipart/form-data") >= 0)) {
    DataInputStream in = new DataInputStream(request.getInputStream());
    int formDataLength = request.getContentLength();
    byte dataBytes[] = new byte[formDataLength];
    int byteRead = 0;
    int totalBytesRead = 0;
    while (totalBytesRead < formDataLength) {
        byteRead = in.read(dataBytes, totalBytesRead,formDataLength);
        totalBytesRead += byteRead; 
    }
    String file = new String(dataBytes);
    saveFile = file.substring(file.indexOf("filename=\"") + 10);
    saveFile = saveFile.substring(0, saveFile.indexOf("\n"));
    saveFile = saveFile.substring(saveFile.lastIndexOf("\\") + 1,saveFile.indexOf("\""));
    int lastIndex = contentType.lastIndexOf("=");
    String boundary = contentType.substring(lastIndex + 1,contentType.length());
    int pos;
    pos = file.indexOf("filename=\"");
    pos = file.indexOf("\n", pos) + 1;
    pos = file.indexOf("\n", pos) + 1;
    pos = file.indexOf("\n", pos) + 1;
    int boundaryLocation = file.indexOf(boundary, pos) - 4;
    int startPos = ((file.substring(0, pos)).getBytes()).length;
    int endPos = ((file.substring(0, boundaryLocation)).getBytes()).length;
    saveFile="/home/adapco/Desktop"+saveFile;
    File ff = new File(saveFile);
    FileOutputStream fileOut = new FileOutputStream(ff);
    fileOut.write(dataBytes, startPos, (endPos - startPos));
    fileOut.flush();
    fileOut.close();
%>
<br>
    <table border="2">
        <tr>
            <td><b>You have successfully upload the file by the name of:</b><% out.println(saveFile);%></td>
        </tr>
    </table>
<%
    Connection connection = null;
    String connectionURL = "jdbc:mysql://localhost:3306/ksa";
    ResultSet rs = null;
    PreparedStatement psmnt = null;
    FileInputStream fis;
    try {
        Class.forName("com.mysql.jdbc.Driver").newInstance();
        connection = DriverManager.getConnection(connectionURL, "root", "root");
        File f = new File(saveFile);
        psmnt = connection.prepareStatement("insert into file(file_data) values(?)");
        fis = new FileInputStream(f);
        psmnt.setBinaryStream(1, (InputStream)fis, (int)(f.length()));
        int s = psmnt.executeUpdate();
        if(s>0) {
            System.out.println("Uploaded successfully !");
        }
        else{
            System.out.println("unsucessfull to upload file.");
        }
    }
    catch(Exception e){
        e.printStackTrace();
    }
}
%>

今、私はファイルをサーバーに保存し、そのパスをdbに保存するか、netbeansとglassfishサーバー(red hat linux)を使用してlong-blob type.iamを使用してファイル(すべての形式)をデータベースに保存する必要があります。考え。

4

2 に答える 2

0

マルチパート ファイルのアップロード処理用に作成された既存のモジュールの 1 つを使用することを強くお勧めします。Commons Fileuploadはより人気のあるものです。調べてみることをお勧めします (使用例はこちら)。

あなたのコードはかなり乱雑で、バイト配列と文字列を混用しているため、確実にエラーが発生します。これ:

int boundaryLocation = file.indexOf(boundary, pos) - 4;
int startPos = ((file.substring(0, pos)).getBytes()).length;
int endPos = ((file.substring(0, boundaryLocation)).getBytes()).length;
...
fileOut.write(dataBytes, startPos, (endPos - startPos));

特に毛深いです。とにかく、どうしても自分でやりたい場合は、コードをクリーンアップする必要があります。文字列とバイト配列を混在させないでください (文字列の 1 文字が 1 バイトであるとは限らないことに注意してください)。ただし、これが学習経験でない限り、お勧めしません。その場合、インターネット上でマルチパート フォーム処理のサンプル コードを探してみます。

于 2012-04-20T08:19:57.327 に答える
0

Use mediumblob(upto 16mb upload) or longblob(upto 1 gb or 4 gb) in mysql. and add below the [mysqld] line in my.ini

  • if you use mediumblob in mysql: max_allowed_packet=16M
  • if you use largeblob in mysql: max_allowed_packet=1024M
于 2014-02-28T10:05:23.810 に答える