Ver Mensaje Individual
  #3 (permalink)  
Antiguo 27/07/2011, 22:06
fortizh
 
Fecha de Ingreso: julio-2011
Mensajes: 1
Antigüedad: 13 años, 5 meses
Puntos: 0
Respuesta: leer y cargar txt desde jsp usando sql2008

Consulta, podrias agregar el proyecto para tenerlo de referencia. Seria de gran utilidad para la comunidad.

Gracias!
Saludos.
;)

Cita:
Iniciado por crisoof Ver Mensaje
ia lo hice gracias por su ayuda xD

es asi
Código:
======== pagina de inicio donde se seleccionara el archivo
<script type="text/javascript">
    function validar()
    {
    var mensaje="";
        if(document.formulario.acc.value==""){
            mensaje="debe ingresar la cantidad total de acciones"}
            var acc=document.formulario.acc.value;
            var regex=/^\d{1,20}$/;
            if(!regex.test(acc)){
                mensaje = mensaje+"debe ingresar solo numeros";
            alert(mensaje);
        return false
        }else
    return true
    }
</script>
<form name="formulario" method="POST" enctype='multipart/form-data' action="/Prueba/Sube"
      onsubmit="return validar()">
Acciones:<input type="text" name="acc" value=""><br>
Por favor, seleccione el trayecto del archivo a cargar
<br><input type="file" name="archivoaleer">
 <input type="submit" >
</form>
servlet para leer el archivo======
Código:
import java.io.*;

import javax.servlet.*;
import javax.servlet.http.*;

import org.apache.commons.fileupload.*;
import java.util.*;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;

public class Sube extends HttpServlet {
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        procesaArchivo(request);
        String acc= request.getParameter("acc");
        String enviara = "/Controla.jsp";
        RequestDispatcher envio = getServletContext().getRequestDispatcher(enviara);
        envio.forward(request, response);
    }
    void depura(String cadena)
    {
        System.out.println("El error es " + cadena);
    }

    public boolean procesaArchivo(HttpServletRequest req) {
        try {
            // construimos el objeto que es capaz de parsear la perición
 /*FileItemFactory es una interfaz para crear FileItem*/
        FileItemFactory file_factory = new DiskFileItemFactory();
         /*ServletFileUpload esta clase convierte los input file a FileItem*/
         ServletFileUpload servlet_up = new ServletFileUpload(file_factory);
         List items = servlet_up.parseRequest(req);
         for(int i=0;i<items.size();i++){
             /*FileItem representa un archivo en memoria que puede ser pasado al disco duro*/
             FileItem item = (FileItem) items.get(i);
             if (! item.isFormField()){
                /*definición de ruta donde se guardará en el servidor*/
                 String destino = getServletContext().getContextPath();
                 String destinofinal = getServletContext().getRealPath(destino+"/..");
                 File archivo_server = new File(destinofinal+"/doctos/salida.txt");
                 item.write(archivo_server);
             }
 else
             {
                 System.out.println("campos de texto "+item.getFieldName()+" --- "+item.getString()+"<br>");
              }
         }
        }
        catch(Exception e) {
            depura("Error de Aplicación " + e.getMessage());
            return false;
        }
        return true;
    }

    /** Handles the HTTP <code>POST</code> method.
     * @param request servlet request
     * @param response servlet response
     */
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        processRequest(request, response);
    }
}
la pagina q conecta y ingresa los datos a la base de datos
Código:
import java.io.*;

import javax.servlet.*;
import javax.servlet.http.*;

import org.apache.commons.fileupload.*;
import java.util.*;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;

public class Sube extends HttpServlet {
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        procesaArchivo(request);
        String acc= request.getParameter("acc");
        String enviara = "/Controla.jsp";
        RequestDispatcher envio = getServletContext().getRequestDispatcher(enviara);
        envio.forward(request, response);
    }
    void depura(String cadena)
    {
        System.out.println("El error es " + cadena);
    }

    public boolean procesaArchivo(HttpServletRequest req) {
        try {
            // construimos el objeto que es capaz de parsear la perición
 /*FileItemFactory es una interfaz para crear FileItem*/
        FileItemFactory file_factory = new DiskFileItemFactory();
         /*ServletFileUpload esta clase convierte los input file a FileItem*/
         ServletFileUpload servlet_up = new ServletFileUpload(file_factory);
         List items = servlet_up.parseRequest(req);
         for(int i=0;i<items.size();i++){
             /*FileItem representa un archivo en memoria que puede ser pasado al disco duro*/
             FileItem item = (FileItem) items.get(i);
             if (! item.isFormField()){
                /*definición de ruta donde se guardará en el servidor*/
                 String destino = getServletContext().getContextPath();
                 String destinofinal = getServletContext().getRealPath(destino+"/..");
                 File archivo_server = new File(destinofinal+"/doctos/salida.txt");
                 item.write(archivo_server);
             }
 else
             {
                 System.out.println("campos de texto "+item.getFieldName()+" --- "+item.getString()+"<br>");
              }
         }
        }
        catch(Exception e) {
            depura("Error de Aplicación " + e.getMessage());
            return false;
        }
        return true;
    }

    /** Handles the HTTP <code>POST</code> method.
     * @param request servlet request
     * @param response servlet response
     */
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        processRequest(request, response);
    }
}
mi campo del txt esta separado por ";" por leo por cada";"

claro q falta la clase Accionista con los metodos insertpara la base de datos desde ahi me conecto a la base

gracias por su molestia