Servlets - response.setContentType(?????)

 
Vista:

response.setContentType(?????)

Publicado por CARCAHARAS (1 intervención) el 07/07/2005 22:06:07
Hola os explico lo que tengo a ver si me podeis ayudar.
El objetivo es poder insertar y recuperar datos de tipo bfile en oracle 9i desde java. Lo que tengo es un procedimiento almacendao que lo almacena:

create or replace procedure agregaFichero(directorio IN varchar2, fichero IN varchar2, identificador IN varchar2) as
f_lob bfile;
BEGIN
f_lob:=bfilename(directorio,fichero);
INSERT INTO T_fichero VALUES(identificador,f_lob);
END;

vale la tabla T_fichero es muy simple:create table T_fichero(
id varchar2(20),
fich bfile);

Tengo una clase java que lo unico que hace es ejecutar el procedimiento almacenado y no me da ningun problema
Luego tengo en java un servlet que lo que hace es recoger lo que hay en el fichero:

package pruebas_de_la_conexion;
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
import java.sql.*;

public class VerFichero extends HttpServlet {
private static final String CONTENT_TYPE = "text/plain";
private String querySQL3="SELECT fich FROM T_fichero ";

public void init() throws ServletException {
try{
Class.forName("oracle.jdbc.driver.OracleDriver");
}catch(ClassNotFoundException e){ System.out.println("No puedo cargar el driver JDBC de la BD");}

}

//Process the HTTP Get request
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

try {
Connection con = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:SERVAUTO","system","sara_system");
java.sql.Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery(querySQL3);
response.setHeader("Accept-ranges","byttes");

if(rs.next()){
java.io.OutputStream os= response.getOutputStream();
int size;
byte[] buffer = new byte[1024];
java.io.InputStream is= rs.getBinaryStream(1);
while((size = is.read(buffer))!=-1){
os.write(buffer,0,size);
os.flush();
}
os.close();
is.close();

}

}
catch (SQLException ex) {
System.out.println("Message: " + ex.getMessage());
}
catch(Exception e){e.printStackTrace();}
}

}

Y al ejecutar esta clase me dice:
"Tipo de columna no valido" y no me muestra nada. Yo supongoque sera que teng que cambiar el tipo de cabecera mime pero no se que poner. A ver si podeis ayudarme es muy importante.
Saludos!
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder

RE:response.setContentType(?????)

Publicado por shiac (1 intervención) el 08/03/2006 21:42:58
disculpa quiero conseguir este driver porfavor :
"oracle.jdbc.driver.OracleDriver"
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar