Bonjour,
Je reprend un vieux morceau de code qui doit permettre d'import un fichier vers un champ de type Blob pour oracle:
Puis j'ai un autre morceau de code qui permet d'extraire un fichier d'un blob :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43 ..... //Charge le Fichier ServletContext sc = getServletContext(); String destPath = sc.getRealPath("/importFiles"); inputBinaryFile = new File(destPath+"/"+str_inputFileName); inputFileInputStream = new FileInputStream(inputBinaryFile); sqlText =" SELECT Gp_File as myObject " + " From PIECEANNEXE where trim(Gp_Id_Cdt)=trim('"+user_IdProsCand+"') and GP_ID_PIECEANNEXE="+idPieceAnnexe; //" FOR UPDATE"; rset = statSelect.executeQuery(sqlText); rset.next(); myObject = ((OracleResultSet) rset).getBLOB("myObject"); /*bufferSize = myObject.getBufferSize(); byteBuffer = new byte[bufferSize]; blobOutputStream = myObject.getBinaryOutputStream(); while ((bytesRead = inputFileInputStream.read(byteBuffer)) != -1) { blobOutputStream.write(byteBuffer, 0, bytesRead); totBytesRead += bytesRead; totBytesWritten += bytesRead; } inputFileInputStream.close();*/ chunkSize = myObject.getChunkSize(); binaryBuffer = new byte[chunkSize]; position = 1; while((bytesRead = inputFileInputStream.read(binaryBuffer)) != -1 ) { bytesWritten = myObject.putBytes(position, binaryBuffer);//, bytesRead); position += bytesRead; totbytesRead += bytesRead; totbytesWritten += bytesWritten; } inputFileInputStream.close(); conRes.commit(); rset.close(); statSelect.close();
Avec des fichiers type pdf, jpg, doc pas de soucis.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26 outputBinaryFile = new File(destPath+"/"+fileName); outputFileOutputStream = new FileOutputStream(outputBinaryFile); //blobInputStream = file.getBinaryStream(); //chunkSize = file.getChunkSize(); //binaryBuffer = new byte[chunkSize]; //while ((bytesRead = blobInputStream.read(binaryBuffer)) != -1) //{ outputFileOutputStream.write(binaryBuffer, 0, bytesRead); // totBytesRead += bytesRead; // totBytesWritten += bytesRead; //} //outputFileOutputStream.close(); //blobInputStream.close(); blobLength = file.length(); chunkSize = file.getChunkSize(); binaryBuffer = new byte[chunkSize]; for (position = 1; position <= blobLength; position += chunkSize) { bytesRead = file.getBytes(position, chunkSize, binaryBuffer); outputFileOutputStream.write(binaryBuffer, 0, bytesRead); totbytesRead += bytesRead; totbytesWritten += bytesRead; } outputFileOutputStream.close();
J'ai un soucis avec les fichiers de types Docx , le fichier est soit disant corrompu à l'ouverture.
Est ce que quelqu'un a une idée ?
Je me suis inspiré de cet exemple :
http://www.idevelopment.info/data/Pr...leExample.java
Merci à vous.
Partager