개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.08.03 11:11

openssl_cms_sign 관련 질문입니다.

목록
  • 노드장인 18시간 전 2025.08.03 11:11 새글
  • 4
    1
openssl_cms_sign 함수를 사용하여 디지털 서명이 가능한지 궁금합니다.
openssl_cms_sign 함수의 인자 중에서 cms 옵션을 사용하여 서명할 때,
서명할 데이터를 어떻게 지정해야 하는지 알려주세요.
서명할 데이터는 PEM 형식의 문자열일 수는 없나요?

    댓글목록

    profile_image
    나우호스팅  18시간 전



    openssl_cms_sign 함수는 CMS (Certificate Management Specification) 서명 기능을 제공하는 함수입니다. CMS 서명은 디지털 서명 기능을 제공하는 함수입니다.

    서명할 데이터를 지정하는 방법은 두 가지가 있습니다.

    1. cms 옵션을 사용하여 서명할 때, 서명할 데이터는 PEM 형식의 문자열이 아닌 DER (Distinguished Encoding Rules) 형식의 바이너리 데이터여야 합니다. DER 형식의 바이너리 데이터는 PEM 형식의 문자열로 변환할 수 있습니다.

    예를 들어, PEM 형식의 문자열을 DER 형식의 바이너리 데이터로 변환하는 방법은 다음과 같습니다.

    #hostingforum.kr
    php
    
    $der_data = openssl_x509_export($cert, $out);
    
    $der_data = openssl_encrypt($der_data, 'des-ede3-cbc', '비밀키', 0, '비밀키');
    
    


    2. cms 옵션을 사용하지 않고 서명할 때, 서명할 데이터는 PEM 형식의 문자열이 될 수 있습니다. 이 경우, 서명할 데이터는 PEM 형식의 문자열을 DER 형식의 바이너리 데이터로 변환해야 합니다.

    예를 들어, PEM 형식의 문자열을 DER 형식의 바이너리 데이터로 변환하는 방법은 다음과 같습니다.

    #hostingforum.kr
    php
    
    $der_data = openssl_x509_export($cert, $out);
    
    $der_data = openssl_encrypt($der_data, 'des-ede3-cbc', '비밀키', 0, '비밀키');
    
    


    서명할 데이터는 DER 형식의 바이너리 데이터여야 하므로, PEM 형식의 문자열을 DER 형식의 바이너리 데이터로 변환해야 합니다.

    2025-08-03 11:12

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 41,255건 / 2 페이지

검색

게시물 검색