메뉴 건너뛰기

조회 수 775 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

[mysql,mariaDB] 컬럼 암호화, 복호화

 

INTRO

 

 

클라이언트의 요청사항 : 기존 테이블의 컬럼을 암호화 하고싶어요!! 중요한 자료이니깐요!!

작업 내용 : INSERT, UPDATE 시 암호화, SELECT시 복호화

사용 기능 : AES 암복호화

바로 시작합니다.

 

CONTENTS

 

 

 

varchar타입은 단순한 문자열을 저장하는 타입으로 암호화된 내용을 저장하려고하면 incorrect string value 에러가 뜹니다.

일단 varchar로 되어있던 기존의 컬럼을 blob로 바꾸도록 하겠습니다.

ALTER TABLE 테이블명 MODIFY 컬럼명 blob;

 

암호화

AES_ENCRYPT('암호화할 내용',SHA2('key',512))

 

복호화

AES_DECRYPT(암호화된컬럼명,SHA2('key',512))

 

기본적인 코드는 위와 같습니다.

다만 한글을 저장 할경우 인코딩이 맞지 않아 SELECT가 잘 되지 않을 경우가 있으니 CONVERT함수를 넣어줍니다.

CONVERT(AES_DECRYPT(암호화된컬럼명,SHA2('key',512))using euckr) 컬럼명

 


List of Articles
번호 제목 날짜 조회 수
86 MySQL 에서 테이블에 이미 존재하는 값으로 UPDATE 하는 경우 file 2018.07.18 1533
85 MyISAM 스토리지 엔진에서 테이블의 최대 저장 row 개수 2018.07.18 1558
84 MySQL replication SQL 문 실행 오류 해결 방법 2018.07.18 1608
83 mysql-bin 로그를 SQL 문으로 변환한는 방법 2018.07.18 1672
82 InnoDB 스토리지 엔진에서 테이블의 최대 저장 row 개수 2018.07.18 1675
81 MySQL 마스터/마스터 replication 에서 AUTO_INCREMENT 문제 해결 방법 2018.07.18 1941
80 MySQL 중복 데이터 찾아서 삭제하기 2019.01.11 1949
79 MySQL DB 에 한글 utf8 문자열 INSERT 오류 해결 방법 file 2018.07.18 2039
78 [MySQL] 세로열을 가로열로 출력하기 2019.03.05 2097
77 한글정렬 order by 2019.02.19 2424
76 MySQL 클라이언트/서버 프로토콜 2018.07.18 2750
75 특정 테이블만 replication 하거나 제외하는 방법 2018.07.18 2822
74 중복데이터 하나만 빼고 삭제 2019.01.11 3163
73 서브쿼리 file 2017.11.16 3444
72 mysql(union,join) file 2017.11.16 3837
71 일반적인 오류를 해결하는 유용한 정보들 file 2020.11.23 3862
70 MySQL〃오라클의 nextval을 MySQL에서 사용하기 2018.07.24 3864
69 전체 텍스트 검색과 파티션 file 2017.12.22 3868
68 MySQL 연결 속도 2017.12.28 3917
67 Union 사용법. 여러 테이블의 같은 값을 한번 쿼리로 추출하기 2017.11.21 3918
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved