개발자 Q&A

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

2025.05.03 19:00

LDAP Mod Replace 관련 질문

목록
  • 보안전문가 19시간 전 2025.05.03 19:00 새글
  • 3
    1
제가 현재 LDAP 서버에 새로운 사용자 정보를 업데이트하려고 합니다. 하지만 ldap_mod_replace 함수를 사용하여 attribute 값을 변경할 때, 기존의 attribute 값이 삭제되고 새로운 값만 등록되는 현상을 경험하고 있습니다.

다음과 같이 ldap_mod_replace 함수를 사용하여 attribute 값을 업데이트하려고 합니다.
c

Ldap* ld;

char* dn = "cn=myuser,dc=example,dc=com";

char* attrName = "mail";

char* new_val = "newmail@example.com";



int rc = ldap_mod_replace(ld, dn, attrName, new_val);



if (rc == LDAP_SUCCESS) {

    printf("성공적으로 업데이트되었습니다.");

} else {

    printf("실패했습니다.").

}


위의 코드에서, 기존의 mail attribute 값은 어떻게 처리되며, 어떻게 새로운 값만 등록할 수 있는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  18시간 전



    LDAP 서버에 새로운 사용자 정보를 업데이트할 때, ldap_mod_replace 함수를 사용하여 attribute 값을 변경할 때 기존의 attribute 값이 삭제되는 현상은 ldap_mod_replace 함수의 특징으로 인한 것입니다.

    ldap_mod_replace 함수는 기존의 attribute 값을 삭제하고 새로운 값을 등록하는 함수로, 기존의 attribute 값이 삭제되는 것은 정상적인 동작입니다.

    기존의 attribute 값을 유지하고 새로운 값을 등록하려면 ldap_mod_add 함수를 사용하는 것이 좋습니다. ldap_mod_add 함수는 기존의 attribute 값을 유지하고 새로운 값을 등록하는 함수로, 기존의 attribute 값이 삭제되지 않습니다.

    다음은 ldap_mod_add 함수를 사용하여 attribute 값을 업데이트하는 예제입니다.

    
    
    Ldap* ld;
    
    char* dn = "cn=myuser,dc=example,dc=com";
    
    char* attrName = "mail";
    
    char* new_val = "newmail@example.com";
    
    
    
    int rc = ldap_mod_add(ld, dn, attrName, new_val);
    
    
    
    if (rc == LDAP_SUCCESS) {
    
        printf("성공적으로 업데이트되었습니다.");
    
    } else {
    
        printf("실패했습니다.");
    
    }
    
    


    이 예제에서는 ldap_mod_add 함수를 사용하여 attribute 값을 업데이트하고, 기존의 attribute 값이 유지됩니다.

    2025-05-03 19:01

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

검색

게시물 검색