Exception com SimpleDateFormat

1 resposta
zirocool

Lí a documentação da API, e escreví o seguinte código:

SimpleDateFormat dFormat = new SimpleDateFormat();
			try {
				dFormat.applyPattern("dd/MM/yyyy");
				String data = miniImage.getData();
				Date date = dFormat.parse( data );
				data = date.toString();
				miniImage.setData( data );
			} catch (ParseException e) {
			
				e.printStackTrace();
			}

Eu pego uma data do banco no formato “yyyy-MM-dd”, e to tentando passar para “dd/mm/yyyy”.

Só que isso gera a seguinte exception:

java.text.ParseException: Unparseable date: "2007-12-02"
	at java.text.DateFormat.parse(Unknown Source)
	at br.com.minimages.controller.Controller.doPost(Controller.java:50)
	at br.com.minimages.controller.Controller.doGet(Controller.java:29)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:252)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:173)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:178)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:126)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:107)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:148)
	at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:869)
	at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:664)
	at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:527)
	at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:80)
	at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:684)
	at java.lang.Thread.run(Unknown Source)

Alguém tem idéia do que esteja errado nisso?!

1 Resposta

zirocool

Resolvido

SimpleDateFormat dFormat = new SimpleDateFormat("yyyy-MM-dd");
			try {
				String data = miniImage.getData();
				Date date = dFormat.parse( data );
				dFormat.applyPattern("dd/MM/yyyy");
				data = dFormat.format( date );
				
				miniImage.setData( data );
			} catch (ParseException e) {
			
				e.printStackTrace();
			}

No construtor se passa a máscara de entrada da data, no meu caso yyyy-MM-dd e no aplyPattern, o cara poe a máscara da saída desejada…

Criado 22 de maio de 2007
Ultima resposta 22 de mai. de 2007
Respostas 1
Participantes 1