Olá.
Estou com um probleminha aqui.
Criei este tópico no JavaFree também, pois preciso desta solução para concluir um projeto aqui.
Quando solicito o envio de arquivos criando um diretório para os mesmos, ocorre o erro no envio. O diretório é criado mas nenhum arquivo é enviado.
Fiz um teste simpes com apenas um arquivo e deu certo, mas com vários falhou.
Bom, vou explicar como é o processo: O diretório é criado com a data atual, mas esta data vem de uma consulta do banco de dados, após isso, cria-se o diretório com a data vinda da consulta e então o recebimento dos 5 arquivos para o diretório.
O código é o seguinte:<%@page language="java" import="schema.Conexao"%>
<%@page contentType="text/html;charset=ISO-8859-1"%>
<%@page import="java.sql.*"%>
<%@page import="java.io.*"%>
<%@page import="java.util.Date"%>
<%
// session.getAttribute("adm001");
String titleEvento = request.getParameter("titleTopic");
String conteudoEvento = request.getParameter("richEdit0");
String contentType = request.getContentType();
if(titleEvento == null || titleEvento == "") {
//session.setAttribute("tit", titleEvento);
response.sendRedirect("new-evento.jsp?TituloVazio");
return;
}
if(titleEvento == "'") {
response.sendRedirect("new-evento.jsp?invalido");
}
if (conteudoEvento == "") {
response.sendRedirect("new-evento.jsp?ConteudoVazio");
}
Conexao c = new Conexao();
Connection conn = null;
conn = c.getConection();
Statement stmt = null;
try {
PreparedStatement pstmt = conn.prepareStatement("SELECT count(*) as topicos FROM tableTopic");
ResultSet rs = pstmt.executeQuery();
rs.next();
int topico = Integer.parseInt(rs.getString("topicos"));
int diretorio = topico+1;
stmt = conn.createStatement();
stmt.execute("INSERT INTO tableTopic (codDiretorio, titleTopic, conteudoTopic, "+
" EndDiretorio) VALUES ('"+diretorio+"', '"+titleEvento+"', '"+conteudoEvento+
"', now() )");// WHERE adm001 == '"+adm001+"');");
PreparedStatement pstmt1 = conn.prepareStatement(
"SELECT date_format(EndDiretorio, '%d-%m-%Y_%H-%i-%s') as data FROM tableTopic "+
" WHERE codDiretorio='"+diretorio+"' and titleTopic = '"+titleEvento+"'");
ResultSet rs1 = pstmt1.executeQuery();
rs1.next();
File dir = new File(application.getRealPath("/") + "/eventos/"+ rs1.getString("data"));
if (dir.mkdir()) {
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);
String 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;
String filepath = dir+"/"+saveFile;
FileOutputStream fileOut = new FileOutputStream(filepath);
fileOut.write(dataBytes, startPos, (endPos - startPos));
fileOut.flush();
fileOut.close();
out.println("diretório criado e imagens enviadas para<br>"+filepath);
} else {
out.println("erro ao enviar imagens para o diretório!");
}
} else {
out.println("erro ao criar diretório!");
}
} catch( SQLException sqlex) {
out.println("Não foi possível criar o evento<br>" +sqlex);
// session.putValue("erroCreate", "Nao foi possível criar o evento!");
// response.sendRedirect("new-evento.jsp?erro");
}
%>
Postei o código completo. Também vão campos preenchidos, mas não tem muita importância, pois o problema é no recebimento das imagens.
Espero uma ajudinha nesse problema que está difícil de se resolver...
[]s