• Saltar al contenido principal
  • Skip to secondary menu
  • Saltar a la barra lateral principal
  • Saltar al pie de página
  • Inicio
  • Secciones
    • Ciencia de datos
    • Criptografía
    • Herramientas
    • Machine Learning
    • Noticias
    • Opinión
    • Productividad
    • Programación
      • JavaScript
      • Julia
      • Matlab
      • Python
      • R
  • Programación
    • JavaScript
    • Julia
    • Matlab
    • Python
    • R
  • Laboratorio
    • Estadística
      • Calculadora del Tamaño Muestral en Encuestas
      • Calculadora de estadísticos descriptivos
      • Test de normalidad
      • Calculadora de contrastes de hipotesis
      • Calculadora de tamano del efecto
      • Simulador de Regresión Lineal con Ruido
      • Visualizador de PCA
      • Visualizador de Series Temporales
      • Simulador de Regresión Logística
      • Simulador de K-Means
      • Simulador de DBSCAN
      • Detector de la Ley de Benford
      • Ajuste de Curvas
      • Calculadora de Matrices
    • Probabilidad
      • Calculadora de Probabilidad de Distribuciones
      • Calculadora de Probabilidades de Lotería
      • Simulador del Problema de Monty Hall
      • Simulador de la Estrategia Martingala
    • Finanzas
      • Calculadora de Préstamos e Hipotecas
      • Conversor TIN ↔ TAE
      • Calculadora DCA con ajuste por inflación
      • Calculadora XIRR con Flujos Irregulares
      • Simulador FIRE (Financial Independence, Retire Early)
    • Negocios
      • CLV
      • Scoring
    • Herramientas
      • Formateador / Minificador de JSON
      • Conversor CSV ↔ JSON
      • Comparador y Formateador de Texto y JSON
      • Formateador y Tester de Expresiones Regulares
      • Inspector de JWT
      • Generador y verificador de hashes
      • Codificador / Decodificador Base64 y URL
      • Conversor de bases numericas
      • Conversor de Timestamp Unix
      • Conversor de colores
      • Generador de UUIDs
    • Juegos
      • Tres en Raya
      • Nim con Q-Learning
    • Más
      • Método D’Hondt
      • Generador de Contraseñas Seguras
  • Noticias
  • Boletín
  • Contacto
  • Tienda
    • Libros
    • Equipamiento de oficina
    • Equipamiento en movilidad

Analytics Lane

Ciencia e ingeniería de datos aplicada

  • Ciencia de datos
  • Machine Learning
  • IA Generativa
  • Python
  • Pandas
  • NumPy
  • R
  • Excel

Creación de certificados SSL con OpenSSL

abril 3, 2024 Por Daniel Rodríguez Deja un comentario
Tiempo de lectura: 4 minutos

La seguridad de las conexiones es algo clave en la era digital. Para garantizar la seguridad en las comunicaciones entre los navegadores y los servidores web es necesario contar con certificados SSL (del inglés Secure Sockets Layer). Estos certificados cifran los datos y autentican la identidad del servidor. En el caso de tener un servidor público en Internet estos deben ser emitidos por una Autoridad de Certificación (CA, del inglés Certification Authority) de confianza, para garantizar al usuario que la página web es a la que desean acceder. Pero, cuando se trabaja en una intranet, se pueden crear fácilmente certificados SSL con OpenSSL para encintar las comunicaciones.

Tabla de contenidos

  • 1 ¿Qué es un Certificado SSL?
  • 2 Pasos para crear certificados SSL con OpenSSL
    • 2.1 Paso 1: Generación de una clave privada
    • 2.2 Paso 2: Crear una solicitud de firma de certificado (CSR)
    • 2.3 Paso 3: Generar un el certificado autofirmado
    • 2.4 Paso 4: Validación de la clave privada y el certificado
  • 3 Configurar el servidor web
  • 4 Conclusiones

¿Qué es un Certificado SSL?

Un certificado SSL es un archivo de datos que vincula una clave criptográfica a los detalles de una organización o entidad. En Internet, suele estar emitido por una Autoridad de Certificación (CA) y sirve como prueba de la autenticidad del servidor web. Cuando un navegador se conecta a un servidor seguro, este último envía su certificado SSL al navegador, que luego verifica su validez. Si el certificado es válido y confiable, se establece una conexión segura entre el navegador y el servidor.

Pasos para crear certificados SSL con OpenSSL

Publicidad


Paso 1: Generación de una clave privada

El primer paso para crear un certificado SSL es generar una clave privada. La clave privada es esencialmente la ”llave” que protege la comunicación encriptada entre el servidor y el cliente. Para generar una clave privada RSA de 2048 bits y guardarla en un archivo llamado clave_privada.key, se puede usar el siguiente comando con OpenSSL:

La caverna del consumo, o cómo Greenspan miraba calzoncillos para hacer política monetaria – El bestiario de los indicadores económicos absurdos (parte 1)
En Analytics Lane
La caverna del consumo, o cómo Greenspan miraba calzoncillos para hacer política monetaria – El bestiario de los indicadores económicos absurdos (parte 1)

openssl genpkey -algorithm RSA -out clave_privada.key -pkeyopt rsa_keygen_bits:2048

Este comando generará una nueva clave privada RSA y la guardará en el archivo clave_privada.key. Los parámetros que se han usado para configurar son los siguientes:

  • openssl genpkey: Comando para generar una clave privada.
  • -algorithm RSA: Especifica el algoritmo RSA para generar la clave privada.
  • -out clave_privada.key: Especifica el nombre del archivo de salida donde se guardará la clave privada.
  • -pkeyopt rsa_keygen_bits:2048: Define el tamaño de bits de la clave RSA, en este caso, 2048 bits.

Paso 2: Crear una solicitud de firma de certificado (CSR)

Una vez creado la clave privada, es necesario crear una Solicitud de Firma de Certificado (CSR, del inglés Certificate Signing Request). El CSR es un documento que contiene información sobre el solicitante del certificado, como el nombre de dominio y la organización. Utilizamos la clave privada generada anteriormente y se puede crear un CSR para el servidor. Para ello se puede ejecutar el siguiente comando e ir respondiendo a la información que aparece en pantalla:

openssl req -new -key clave_privada.key -out solicitud.csr

Este comando generará una nueva solicitud de firma de certificado utilizando la clave privada especificada y la guardará en el archivo solicitud.csr. Los parámetros que se han usado son:

  • openssl req: Comando para crear una solicitud de certificado.
  • -new: Indica que se está creando una nueva solicitud.
  • -key clave_privada.key: Especifica la clave privada que se utilizará para generar la solicitud.
  • -out solicitud.csr: Especifica el nombre del archivo de salida donde se guardará la solicitud CSR.

Paso 3: Generar un el certificado autofirmado

Ahora, una vez generada la clave privada y el CSR se puede generar un certificado autofirmado. Al no estar emitido por una CA no se puede usar en servidores públicos en Internet ya que no cuenta con el respaldo de una de estas entidades. Pero puede ser útil para entornos de desarrollo o pruebas locales.

Un certificado autofirmado válido por un año se puede generar y guardar en el archivo certificado.crt ejecutando el siguiente comando:

openssl x509 -req -in solicitud.csr -signkey clave_privada.key -out certificado.crt -days 365

Este comando utilizará la solicitud de firma de certificado (CSR) generada anteriormente, junto con la clave privada, para crear un certificado autofirmado válido por un año. Los parámetros que se han usado son:

  • openssl x509: Comando para firmar certificados X.509.
  • -req: Indica que se está utilizando una solicitud de certificado como entrada.
  • -in solicitud.csr: Especifica el archivo de solicitud de certificado a utilizar.
  • -signkey clave_privada.key: Especifica la clave privada con la que se firmará el certificado.
  • -out certificado.crt: Especifica el nombre del archivo de salida donde se guardará el certificado.
  • -days 365: Especifica la cantidad de días durante los cuales el certificado será válido, en este caso, un año (365 días).

Publicidad


Paso 4: Validación de la clave privada y el certificado

Si los pasos anteriores se han ejecutado correctamente la clave y el certificado servirán para validar de forma correcta el servidor web. Para estar seguro de ello, OpenSSL proporciona herramientas para validar la correspondencia entre ambas.

El método más sencillo para verificar si un certificado es válido para una clave privada es mediante la herramienta de línea de comandos openssl. Asumiendo que tenemos los archivos del certificado (certificado.crt) y la clave privada (clave_privada.key) en el directorio actual, ejecutado el siguiente comando se puede obtener el hash SHA-256 de la clave pública correspondiente a la clave privada y al certificado, respectivamente

openssl pkey -in clave_privada.key -pubout -outform pem | sha256sum
openssl x509 -in certificado.crt -pubkey -noout -outform pem | sha256sum

Si los hashes son iguales, significa que la clave privada y el certificado se corresponden correctamente una con la otra.

Configurar el servidor web

Finalmente, es necesario configurar el servidor web para utilizar el archivo de clave privada (clave_privada.key) y el certificado (certificado.crt) que acaba de generar. Este paso varía según el servidor web y se debe realizar siguiendo la documentación específica del servidor. Por ejemplo, para un servidor Express se pueden seguir los pasos que se muestran en esta publicación anterior.

Conclusiones

La creación y validación de certificados SSL son pasos fundamentales para garantizar la seguridad y la autenticidad de la comunicación en línea. En esta entrada se han visto los pasos para generar certificados SSL con OpenSSL de una forma fácil y rápida. Además de indicar cómo validar estos en línea de comandos.

Imagen de Myriams-Fotos en Pixabay

¿Te ha parecido de utilidad el contenido?

¡Puntúalo entre una y cinco estrellas!

Puntuación promedio 0 / 5. Votos emitidos: 0

Ya que has encontrado útil este contenido...

¡Síguenos en redes sociales!

¡Siento que este contenido no te haya sido útil!

¡Déjame mejorar este contenido!

Dime, ¿cómo puedo mejorar este contenido?

Publicidad


Publicaciones relacionadas

  • La caverna del consumo, o cómo Greenspan miraba calzoncillos para hacer política monetaria – El bestiario de los indicadores económicos absurdos (parte 1)
  • La vanidad del paisaje, o por qué un becario sale a contar grúas a Manhattan – El bestiario de los indicadores económicos absurdos (parte 2)
  • Augurios deportivos y portadas malditas, o cuando The Economist predice mejor al revés – El bestiario de los indicadores económicos absurdos (parte 3)
  • El Binning en Credit Scoring: El Arte de Discretizar Variables
  • Cómo comparar tendencias con gráficos de líneas en Matplotlib: guía práctica paso a paso
  • Analytics Lane lanza la versión 1.2 del laboratorio con nuevas herramientas de ajuste de curvas y cálculo matricial
  • Subplots en Matplotlib: cómo organizar múltiples gráficos en una sola figura
  • Ley de Benford: cómo detectar datos manipulados con ejemplos reales
  • Síndrome del objeto brillante en ciencia de datos: el error simétrico a los costes hundidos

Publicado en: Criptografía Etiquetado como: Ciberseguridad, Linux, SSL

Interacciones con los lectores

Deja una respuesta Cancelar la respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

I accept the Terms and Conditions and the Privacy Policy

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.

Barra lateral principal

Suscríbete a nuestro boletín

Suscríbete al boletín semanal para estar al día de todas las publicaciones.

Política de Privacidad

Analytics Lane en redes sociales

  • Amazon
  • Bluesky
  • Facebook
  • GitHub
  • Instagram
  • Mastodon
  • Pinterest
  • RSS
  • Telegram
  • Tumblr
  • Twitter
  • YouTube

Publicidad

Entradas recientes

Augurios deportivos y portadas malditas, o cuando The Economist predice mejor al revés – El bestiario de los indicadores económicos absurdos (parte 3)

junio 18, 2026 Por Daniel Rodríguez

El Binning en Credit Scoring: El Arte de Discretizar Variables

junio 16, 2026 Por Daniel Rodríguez

Noticias

Analytics Lane lanza la versión 1.2 del laboratorio con nuevas herramientas de ajuste de curvas y cálculo matricial

junio 12, 2026 Por Daniel Rodríguez

Publicidad

Es tendencia

  • Buscar en Excel con dos o más criterios publicado el septiembre 7, 2022 | en Herramientas
  • Numpy básico: valores mínimos y máximos en arrays Numpy publicado el octubre 23, 2019 | en Python
  • Programador de tareas de Windows: Guía definitiva para automatizar tu trabajo (BAT, PowerShell y Python) publicado el octubre 7, 2025 | en Herramientas, Productividad
  • Cómo eliminar caracteres inválidos en nombres de archivos en Windows y Linux usando Python publicado el octubre 16, 2024 | en Herramientas, Python
  • Gráficos de barras en Matplotlib publicado el julio 5, 2022 | en Python

Publicidad

Lo mejor valorado

4.9 (24)

Seleccionar filas y columnas en Pandas con iloc y loc

4.6 (16)

Archivos JSON con Python: lectura y escritura

4.4 (14)

Ordenación de diccionarios en Python mediante clave o valor

4.7 (13)

Operaciones de filtrado de DataFrame con Pandas en base a los valores de las columnas

4.1 (11)

Aplicar el método D’Hondt en Excel

Comentarios recientes

  • bif en JSON en bases de datos: cuándo es buena idea y cuándo no
  • bif en Cómo desinstalar Oracle Database 19c en Windows
  • M. Pilar en Cómo eliminar las noticias en Windows 11 y recuperar tu concentración
  • Daniel Rodríguez en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • Pepe en Probabilidad básica: cómo entender el azar en nuestra vida diaria

Publicidad


Footer

Analytics Lane

  • Acerca de Analytics Lane
  • Boletín de noticias
  • Contacto
  • Libros
  • Lo más popular
  • Noticias
  • Tienda
  • Tiendas afiliadas

Secciones

  • Ciencia de datos
  • Criptografía
  • Herramientas
  • Machine Learning
  • Opinión
  • Productividad
  • Programación
  • Reseñas

Sobre de Analytics Lane

En Analytics Lane tratamos de explicar los principales conceptos de la ciencia e ingeniería de datos con un enfoque práctico. Los principales temas tratados son ciencia de datos, ingeniería de datos, inteligencia artificial, machine learning, deep learning y criptografía. Además, también se habla de los principales lenguajes de programación y herramientas utilizadas por los científicos e ingenieros de datos.

Copyright © 2018-2026 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto