메뉴 건너뛰기

조회 수 790 추천 수 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
번호 제목 날짜 조회 수
126 BEGIN, COMMIT, ROLLBACK 2021.03.26 326
125 binlog 조회 / 삭제 / 보관 기간 설정 file 2023.01.10 152
124 CASE 문법 사용 하기 file 2023.01.10 120
123 column의 정보 중에서 column 설명(column_comment) 2021.03.26 140
122 Create Procedure 2016.12.23 6028
121 DB의 모든 테이블을 삭제하는 쿼리 2016.08.29 6784
120 DISTINCT와 ALL 2016.12.23 5514
119 Dump & Restore 2016.12.23 5802
118 dump 를 db에 올릴때 인코딩 문제 2016.12.23 6187
117 flush privileges 명령어 file 2017.04.12 5316
116 FORMAT 문법 사용 하기(숫자 자리수 나타내기) file 2023.01.10 122
115 fulltext 관련 글 2021.03.26 135
114 group by, distinct, count 를 이용한 겹치지 않는것의 개수 2021.03.26 273
113 group by로 뽑아온 값중에 가장큰 값(max)의 상태값을 가져오기 2021.03.26 611
112 IMPORT 2016.12.23 5464
111 IN 연산자 2016.12.23 5820
110 InnoDB 스토리지 엔진에서 테이블의 최대 저장 row 개수 2018.07.18 1689
109 InnoDB, MyISAM 2016.12.23 5550
108 LIMIT 속도 저하 2021.03.26 263
107 MariaDB can't create test file lower-test 2023.02.16 165
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved