import java.io.*; import java.net.*; import javax.net.ssl.*; public class ServidorHTTPSAutorizando2 { public static void main(String[] args) throws IOException { // Utilizar una SocketFactory para crear sockets SSL: SSLServerSocketFactory ssf = (SSLServerSocketFactory)SSLServerSocketFactory.getDefault(); SSLServerSocket ss = (SSLServerSocket)ssf.createServerSocket(8080); // Requerir autentificación del cliente ss.setNeedClientAuth(true); // Bucle infinito para aceptar conexiones permanentemente while (true) { try { Socket s = ss.accept(); boolean permitido = false; // Obtener la sesion SSLSession sesion = ((SSLSocket) s).getSession(); // Comprobar la autentificación del cliente con el AutentificadorCN AutentificadorCN autentificador = new AutentificadorCN(sesion); try { autentificador.comprobarPermiso(); permitido = true; } catch (ExcepcionAutentificacion ea) { permitido = false; System.out.println("Acceso denegado." + ea); } // Los streams de entrada y salida están encriptados // pero esto es transparente OutputStream out = s.getOutputStream(); BufferedReader in = new BufferedReader( new InputStreamReader(s.getInputStream())); // Leer la entrada del cliente y mostrarla en la pantalla String linea = null; while (((linea = in.readLine())!= null) && (!("".equals(linea)))) { System.out.println(linea); } System.out.println(""); // Construir una respuesta StringBuffer buffer = new StringBuffer(); buffer.append("\n"); buffer.append( "