DefaultLobHandler's "wrapAsLob" mode works with PostgreSQL's getAsciiStream() requirement (SPR-7487)

This commit is contained in:
Juergen Hoeller 2010-09-01 18:09:29 +00:00
parent e56cfb8173
commit 4e3227441b
4 changed files with 64 additions and 22 deletions

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2009 the original author or authors. * Copyright 2002-2010 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -271,12 +271,11 @@ public class DefaultLobHandler extends AbstractLobHandler {
if (streamAsLob || wrapAsLob) { if (streamAsLob || wrapAsLob) {
if (asciiStream != null) { if (asciiStream != null) {
try { try {
Reader reader = new InputStreamReader(asciiStream, "US-ASCII");
if (streamAsLob) { if (streamAsLob) {
ps.setClob(paramIndex, reader, contentLength); ps.setClob(paramIndex, new InputStreamReader(asciiStream, "US-ASCII"), contentLength);
} }
else { else {
ps.setClob(paramIndex, new PassThroughClob(reader, contentLength)); ps.setClob(paramIndex, new PassThroughClob(asciiStream, contentLength));
} }
} }
catch (UnsupportedEncodingException ex) { catch (UnsupportedEncodingException ex) {

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2008 the original author or authors. * Copyright 2002-2010 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2008 the original author or authors. * Copyright 2002-2010 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -91,7 +91,7 @@ class PassThroughBlob implements Blob {
} }
public void free() throws SQLException { public void free() throws SQLException {
throw new UnsupportedOperationException(); // no-op
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2008 the original author or authors. * Copyright 2002-2010 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -16,14 +16,20 @@
package org.springframework.jdbc.support.lob; package org.springframework.jdbc.support.lob;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.Reader; import java.io.Reader;
import java.io.StringReader; import java.io.StringReader;
import java.io.UnsupportedEncodingException;
import java.io.Writer; import java.io.Writer;
import java.sql.Clob; import java.sql.Clob;
import java.sql.SQLException; import java.sql.SQLException;
import org.springframework.util.FileCopyUtils;
/** /**
* Simple JDBC {@link Clob} adapter that exposes a given String or character stream. * Simple JDBC {@link Clob} adapter that exposes a given String or character stream.
* Optionally used by {@link DefaultLobHandler}. * Optionally used by {@link DefaultLobHandler}.
@ -37,6 +43,8 @@ class PassThroughClob implements Clob {
private Reader characterStream; private Reader characterStream;
private InputStream asciiStream;
private long contentLength; private long contentLength;
@ -50,13 +58,52 @@ class PassThroughClob implements Clob {
this.contentLength = contentLength; this.contentLength = contentLength;
} }
public PassThroughClob(InputStream asciiStream, long contentLength) {
this.asciiStream = asciiStream;
this.contentLength = contentLength;
}
public long length() throws SQLException { public long length() throws SQLException {
return this.contentLength; return this.contentLength;
} }
public Reader getCharacterStream() throws SQLException { public Reader getCharacterStream() throws SQLException {
return (this.content != null ? new StringReader(this.content) : this.characterStream); try {
if (this.content != null) {
return new StringReader(this.content);
}
else if (this.characterStream != null) {
return this.characterStream;
}
else {
return new InputStreamReader(this.asciiStream, "US-ASCII");
}
}
catch (UnsupportedEncodingException ex) {
throw new SQLException("US-ASCII encoding not supported: " + ex);
}
}
public InputStream getAsciiStream() throws SQLException {
try {
if (this.content != null) {
return new ByteArrayInputStream(this.content.getBytes("US-ASCII"));
}
else if (this.characterStream != null) {
String tempContent = FileCopyUtils.copyToString(this.characterStream);
return new ByteArrayInputStream(tempContent.getBytes("US-ASCII"));
}
else {
return this.asciiStream;
}
}
catch (UnsupportedEncodingException ex) {
throw new SQLException("US-ASCII encoding not supported: " + ex);
}
catch (IOException ex) {
throw new SQLException("Failed to read stream content: " + ex);
}
} }
@ -68,10 +115,6 @@ class PassThroughClob implements Clob {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();
} }
public InputStream getAsciiStream() throws SQLException {
return null;
}
public OutputStream setAsciiStream(long pos) throws SQLException { public OutputStream setAsciiStream(long pos) throws SQLException {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();
} }
@ -101,7 +144,7 @@ class PassThroughClob implements Clob {
} }
public void free() throws SQLException { public void free() throws SQLException {
throw new UnsupportedOperationException(); // no-op
} }
} }