I'm uploading an image through primefaces in Java and using the input stream gives me the following error:
java.io.FileNotFoundException: C:\eclipseLuna\workspaceVsg\.metadata\.plugins\org.eclipse.wst.server.core\tmp1\work\Catalina\localhost\vsg\upload_383ccbdb_b6e0_4892_ba6b_f4ff4fdd5e99_00000006.tmp (El sistema no puede encontrar el archivo especificado)
at java.io.FileInputStream.open0(Native Method)
at java.io.FileInputStream.open(FileInputStream.java:195)
at java.io.FileInputStream.<init>(FileInputStream.java:138)
at org.apache.tomcat.util.http.fileupload.disk.DiskFileItem.getInputStream(DiskFileItem.java:188)
at org.apache.catalina.core.ApplicationPart.getInputStream(ApplicationPart.java:100)
at org.primefaces.model.NativeUploadedFile.getInputstream(NativeUploadedFile.java:45)
at cl.ecm.vsg.mantencion.bean.pruebaBean.cargarFoto(pruebaBean.java:120)
at cl.ecm.vsg.mantencion.bean.pruebaBean.cargaFoto(pruebaBean.java:79)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at org.apache.el.parser.AstValue.invoke(AstValue.java:247)
at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:267)
at com.sun.faces.facelets.el.TagMethodExpression.invoke(TagMethodExpression.java:105)
at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:87)
at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:102)
at javax.faces.component.UICommand.broadcast(UICommand.java:315)
at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:790)
at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1282)
at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:658)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:292)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:207)
at org.primefaces.webapp.filter.FileUploadFilter.doFilter(FileUploadFilter.java:78)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:240)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:207)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:240)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:207)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:212)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:141)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:616)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:528)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1099)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:670)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1520)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1476)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
These are the methods I'm using:
public void uploadFile(FileUploadEvent event) {
FacesMessage msg = null;
// System.out.println("\nEntra al metodo ...");
// Get information you from the uploaded file
if (event.getFile() != null) {
// System.out.println("\nNombreArchivo---> " +
// event.getFile().getFileName());
// System.out.println("\nTamaño---> " + event.getFile().getSize());
if (event.getFile().getFileName().contains(".png")
|| event.getFile().getFileName().contains(".jpg")
|| event.getFile().getFileName().contains(".gif")
|| event.getFile().getFileName().contains(".JPG")
|| event.getFile().getFileName().contains(".PNG")) {
if (event.getFile().getSize() <= 50000) {
this.setFile(event.getFile());
this.btnDisableFoto = false;
} else {
msg = new FacesMessage(FacesMessage.SEVERITY_WARN,
"El Archivo No Debe Pesar Mas de 50 KB", "");
FacesContext.getCurrentInstance().addMessage(null, msg);
}
} else {
msg = new FacesMessage(FacesMessage.SEVERITY_ERROR,
"SE DEBE SELECIONAR ARCHIVO CON FORMATO DE IMAGEN", "");
FacesContext.getCurrentInstance().addMessage(null, msg);
}
}
}
public void cargaFoto() {
if (file != null) {
cargarFoto(file);
this.btnDisableFoto = true;
}
}
public void cargarFoto(UploadedFile file) {
FacesMessage msg = null;
File folder = new File(
ParamSistema.getParametro("PersonalRutaFotoOrigen"));
if (!folder.exists()) {
folder.mkdir();
}
File files = null;
File fichero = null;
try {
String[] rutDiv = MantenedorClienteBness.divideRut(rutCompleto);
fichero = new File("id" + rutDiv[0] + rutDiv[1] + ".png");
files = new File(
ParamSistema.getParametro("PersonalRutaFotoOrigen")
+ fichero.toString());
InputStream input = file.getInputstream();
OutputStream output = new FileOutputStream(files);
try {
IOUtils.copy(input, output);
} finally {
IOUtils.closeQuietly(output);
IOUtils.closeQuietly(input);
}
} catch (IOException e1) {
e1.printStackTrace();
}
if (file != null) {
this.setRutaImagen("");
this.setRutaImagen(fichero.toString());
msg = new FacesMessage("Foto Cargado", file.getFileName()
+ " Correctamente.");
FacesContext.getCurrentInstance().addMessage(null, msg);
} else {
msg = new FacesMessage(FacesMessage.SEVERITY_ERROR,
"Error al Cargar Foto ", "");
FacesContext.getCurrentInstance().addMessage(null, msg);
}
}
I've done traces and the error is given by the file.getInputStream (); I hope you can help me. Thank you in advance.