KR101989956B1 - 암호화 장치 및 방법 - Google Patents
암호화 장치 및 방법 Download PDFInfo
- Publication number
- KR101989956B1 KR101989956B1 KR1020150151039A KR20150151039A KR101989956B1 KR 101989956 B1 KR101989956 B1 KR 101989956B1 KR 1020150151039 A KR1020150151039 A KR 1020150151039A KR 20150151039 A KR20150151039 A KR 20150151039A KR 101989956 B1 KR101989956 B1 KR 101989956B1
- Authority
- KR
- South Korea
- Prior art keywords
- size
- generating
- encryption algorithm
- block
- branches
- Prior art date
Links
- 238000000034 method Methods 0.000 title claims abstract description 22
- 230000006870 function Effects 0.000 claims description 21
- 238000010586 diagram Methods 0.000 description 8
- 239000011159 matrix material Substances 0.000 description 4
- 238000004590 computer program Methods 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 238000009792 diffusion process Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000014509 gene expression Effects 0.000 description 1
- 238000003780 insertion Methods 0.000 description 1
- 230000037431 insertion Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000011084 recovery Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
- H04L9/0618—Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
- H04L9/0618—Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation
- H04L9/0625—Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation with splitting of the data block into left and right halves, e.g. Feistel based algorithms, DES, FEAL, IDEA or KASUMI
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
- H04L9/0618—Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation
- H04L9/0631—Substitution permutation network [SPN], i.e. cipher composed of a number of stages or rounds each involving linear and nonlinear transformations, e.g. AES algorithms
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
- H04L9/065—Encryption by serially and continuously modifying data stream elements, e.g. stream cipher systems, RC4, SEAL or A5/3
- H04L9/0656—Pseudorandom key sequence combined element-for-element with data sequence, e.g. one-time-pad [OTP] or Vernam's cipher
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/08—Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
- H04L9/0861—Generation of secret information including derivation or calculation of cryptographic keys or passwords
- H04L9/0869—Generation of secret information including derivation or calculation of cryptographic keys or passwords involving random numbers or seeds
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L2209/00—Additional information or applications relating to cryptographic mechanisms or cryptographic arrangements for secret or secure communication H04L9/00
- H04L2209/16—Obfuscation or hiding, e.g. involving white box
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L2209/00—Additional information or applications relating to cryptographic mechanisms or cryptographic arrangements for secret or secure communication H04L9/00
- H04L2209/24—Key scheduling, i.e. generating round keys or sub-keys for block encryption
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Storage Device Security (AREA)
Abstract
Description
도 2는 본 발명의 일 실시예에 따른 키 테이블 생성부의 상세 구성도
도 3은 연산부에서 이용되는 라운드 함수를 예를 도시한 도면
도 4는 본 발명의 일 실시예에 따라 생성된 블록 암호화 알고리즘의 페이스텔 구조를 나타낸 도면
도 5는 본 발명의 일 실시예에 따른 암호화 방법의 순서도
도 6은 본 발명의 일 실시예에 따른 블록 암호화 알고리즘 생성 절차를 나타낸 순서도
110: 키 테이블 생성부
111: 키 생성부
113: 연산부
130: 암호화부
Claims (15)
- 시드 값으로부터 유도된 임의의 값들을 생성하고, 생성된 상기 임의의 값들을 포함하는 키 테이블을 생성하는 키 테이블 생성부; 및
생성된 상기 키 테이블이 적용된 라운드 함수를 가지는 페이스텔(Feistel) 구조의 블록 암호화 알고리즘을 생성하고, 생성된 상기 블록 암호화 알고리즘을 이용하여 평문 데이터 블록을 암호화하는 암호화부를 포함하고,
상기 키 테이블 생성부는, 암호화를 위한 가용 메모리의 크기에 기초하여 상기 임의의 값들의 크기를 결정하고,
상기 암호화부는, 상기 평문 데이터 블록의 크기 및 상기 임의의 값들의 크기에 기초하여 상기 페이스텔 구조의 브랜치 수를 결정하고, 결정된 상기 브랜치 수를 가지는 페이스텔 구조의 블록 암호화 알고리즘을 생성하는 암호화 장치. - 청구항 1에 있어서,
상기 시드 값은, 비트열로 표현 가능한 초기 입력 값인 암호화 장치. - 청구항 2에 있어서,
상기 시드 값은, 암호키, 카운터 값 및 초기화 벡터 중 하나인 암호화 장치. - 삭제
- 삭제
- 청구항 1에 있어서,
상기 암호화부는, 보안 강도에 기초하여 상기 페이스텔 구조의 라운드 수를 결정하고, 결정된 상기 라운드 수를 가지는 페이스텔 구조의 블록 암호화 알고리즘을 생성하는 암호화 장치. - 시드 값으로부터 유도된 임의의 값들을 생성하는 단계;
생성된 상기 임의의 값들을 포함하는 키 테이블을 생성하는 단계;
생성된 상기 키 테이블이 적용된 라운드 함수를 가지는 페이스텔(Feistel) 구조의 블록 암호화 알고리즘을 생성하는 단계; 및
생성된 상기 블록 암호화 알고리즘을 이용하여 평문 데이터 블록을 암호화하는 단계를 포함하고,
상기 임의의 값들을 생성하는 단계는,
암호화를 위한 가용 메모리의 크기에 기초하여 상기 임의의 값들의 크기를 결정하는 단계; 및
결정된 상기 임의의 값들의 크기를 가지는 임의의 값들을 생성하는 단계를 포함하고,
상기 블록 암호화 알고리즘을 생성하는 단계는, 상기 평문 데이터 블록의 크기 및 상기 임의의 값들의 크기에 기초하여 상기 페이스텔 구조의 브랜치 수를 결정하는 단계; 및
결정된 상기 브랜치 수를 가지는 페이스텔 구조의 블록 암호화 알고리즘을 생성하는 단계를 포함하는 암호화 방법. - 청구항 8에 있어서,
상기 시드 값은, 비트열로 표현 가능한 초기 입력 값인 암호화 방법. - 청구항 9에 있어서,
상기 시드 값은, 암호키, 카운터 값 및 초기화 벡터 중 하나인 암호화 방법. - 삭제
- 삭제
- 청구항 8에 있어서,
상기 블록 암호화 알고리즘을 생성하는 단계는, 보안 강도에 기초하여 상기 페이스텔 구조의 라운드 수를 결정하는 단계; 및
결정된 상기 라운드 수를 가지는 페이스텔 구조의 블록 암호화 알고리즘을 생성하는 단계를 포함하는 암호화 방법. - 하드웨어와 결합되어
시드 값으로부터 유도된 임의의 값들을 생성하되, 암호화를 위한 가용 메모리의 크기에 기초하여 상기 임의의 값들의 크기를 결정하고, 결정된 상기 임의의 값들의 크기를 가지는 임의의 값들을 생성하는 단계;
생성된 상기 임의의 값들을 포함하는 키 테이블을 생성하는 단계;
생성된 상기 키 테이블이 적용된 라운드 함수를 가지는 페이스텔(Feistel) 구조의 블록 암호화 알고리즘을 생성하되, 평문 데이터 블록의 크기 및 상기 임의의 값들의 크기에 기초하여 상기 페이스텔 구조의 브랜치 수를 결정하고, 결정된 상기 브랜치 수를 가지는 페이스텔 구조의 블록 암호화 알고리즘을 생성하는 단계; 및
생성된 상기 블록 암호화 알고리즘을 이용하여 평문 데이터 블록을 암호화하는 단계를 실행시키기 위하여 컴퓨터 판독 가능한 기록매체에 저장된 컴퓨터 프로그램.
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020150151039A KR101989956B1 (ko) | 2015-10-29 | 2015-10-29 | 암호화 장치 및 방법 |
US14/980,751 US10491374B2 (en) | 2015-10-29 | 2015-12-28 | Apparatus and method for encryption |
CN201610108510.XA CN106656467B (zh) | 2015-10-29 | 2016-02-26 | 加密装置及方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020150151039A KR101989956B1 (ko) | 2015-10-29 | 2015-10-29 | 암호화 장치 및 방법 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20170050027A KR20170050027A (ko) | 2017-05-11 |
KR101989956B1 true KR101989956B1 (ko) | 2019-06-17 |
Family
ID=58638344
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020150151039A KR101989956B1 (ko) | 2015-10-29 | 2015-10-29 | 암호화 장치 및 방법 |
Country Status (3)
Country | Link |
---|---|
US (1) | US10491374B2 (ko) |
KR (1) | KR101989956B1 (ko) |
CN (1) | CN106656467B (ko) |
Families Citing this family (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR101989943B1 (ko) * | 2017-04-28 | 2019-06-17 | 삼성에스디에스 주식회사 | 부채널 공격에 안전한 연산 장치 및 방법 |
EP3651142A4 (en) * | 2017-08-10 | 2021-03-24 | Sony Corporation | ENCRYPTION DEVICE AND METHOD AS WELL AS ENCRYPTION DEVICE AND METHOD |
KR102033351B1 (ko) * | 2017-08-22 | 2019-10-17 | 국민대학교산학협력단 | 컴퓨터 실행 가능한 경량 화이트박스 암호화 방법 및 장치 |
EP3493457A1 (en) * | 2017-11-30 | 2019-06-05 | Gemalto Sa | Method for protecting a source of entropy used in countermeasures securing a whitebox cryptographic algorithm |
KR102109902B1 (ko) * | 2018-10-12 | 2020-05-12 | 유비벨록스(주) | 보안성이 향상된 블록 암호화 방법 |
KR102565442B1 (ko) | 2018-10-26 | 2023-08-16 | 삼성에스디에스 주식회사 | 암호 알고리즘 생성 장치 및 방법, 암호화 장치 및 방법 |
KR102565443B1 (ko) * | 2018-10-26 | 2023-08-16 | 삼성에스디에스 주식회사 | 암호 알고리즘 생성 장치 및 방법, 암호화 장치 및 방법 |
WO2021025631A1 (en) * | 2019-08-05 | 2021-02-11 | Securify Bilisim Teknolojileri Ve Guvenligi Egt. Dan. San. Ve Tic. Ltd. Sti. | A method for generating digital signatures |
CN112054896B (zh) * | 2020-08-12 | 2023-10-03 | 深圳市欢太科技有限公司 | 白盒加密方法、装置、终端及存储介质 |
Family Cites Families (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5995915A (en) * | 1997-01-29 | 1999-11-30 | Advanced Micro Devices, Inc. | Method and apparatus for the functional verification of digital electronic systems |
AU2006324920B2 (en) * | 2005-12-14 | 2010-08-12 | Nds Limited | Method and system for usage of block cipher encryption |
US20100080395A1 (en) * | 2006-11-17 | 2010-04-01 | Koninklijke Philips Electronics N.V. | Cryptographic method for a white-box implementation |
US8130946B2 (en) * | 2007-03-20 | 2012-03-06 | Michael De Mare | Iterative symmetric key ciphers with keyed S-boxes using modular exponentiation |
EP2406916A1 (en) | 2009-03-10 | 2012-01-18 | Irdeto Corporate B.V. | White-box cryptographic system with input dependent encodings |
US8948376B2 (en) * | 2010-05-11 | 2015-02-03 | Ca, Inc. | Format-preserving encryption via rotating block encryption |
US9152801B2 (en) * | 2012-06-28 | 2015-10-06 | Steven W. Cooke | Cryptographic system of symmetric-key encryption using large permutation vector keys |
KR102180029B1 (ko) * | 2014-02-03 | 2020-11-17 | 삼성전자 주식회사 | Crt-rsa 암호화 방법 및 장치와 이를 기록한 컴퓨터 판독가능 저장매체 |
US9654279B2 (en) * | 2014-03-20 | 2017-05-16 | Nxp B.V. | Security module for secure function execution on untrusted platform |
KR102376506B1 (ko) * | 2014-10-20 | 2022-03-18 | 삼성전자주식회사 | 암복호화기, 암복호화기를 포함하는 전자 장치 및 암복호화기의 동작 방법 |
-
2015
- 2015-10-29 KR KR1020150151039A patent/KR101989956B1/ko active IP Right Grant
- 2015-12-28 US US14/980,751 patent/US10491374B2/en active Active
-
2016
- 2016-02-26 CN CN201610108510.XA patent/CN106656467B/zh active Active
Non-Patent Citations (1)
Title |
---|
이만영 외 5인, "현대 암호학 및 응용" (2002.11.25.)* |
Also Published As
Publication number | Publication date |
---|---|
CN106656467B (zh) | 2021-01-15 |
KR20170050027A (ko) | 2017-05-11 |
US10491374B2 (en) | 2019-11-26 |
CN106656467A (zh) | 2017-05-10 |
US20170126396A1 (en) | 2017-05-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR101989956B1 (ko) | 암호화 장치 및 방법 | |
KR101924067B1 (ko) | 암호화 장치 및 방법 | |
US8966279B2 (en) | Securing the implementation of a cryptographic process using key expansion | |
US9189425B2 (en) | Protecting look up tables by mixing code and operations | |
CN107438065B (zh) | 数据加密装置及方法、数据解密装置及方法 | |
US8966285B2 (en) | Securing implementation of a cryptographic process having fixed or dynamic keys | |
US8675866B2 (en) | Multiplicative splits to protect cipher keys | |
US20120254625A1 (en) | Protecting states of a cryptographic process using group automorphisms | |
US20120155638A1 (en) | Securing keys of a cipher using properties of the cipher process | |
US8699702B2 (en) | Securing cryptographic process keys using internal structures | |
US10965454B2 (en) | Apparatus and method for public key encryption | |
KR101914453B1 (ko) | 암호화 장치 및 방법 | |
KR102033351B1 (ko) | 컴퓨터 실행 가능한 경량 화이트박스 암호화 방법 및 장치 | |
JP6187624B1 (ja) | 情報処理装置、情報処理方法及びプログラム | |
KR102565443B1 (ko) | 암호 알고리즘 생성 장치 및 방법, 암호화 장치 및 방법 | |
KR20080072345A (ko) | 암호화 장치 및 그 방법 | |
KR20170103321A (ko) | 보안성이 강화된 순서보존 암호화 방법 및 장치 | |
AU2018374489B2 (en) | Method for protecting a source of entropy used in countermeasures securing a whitebox cryptographic algorithm | |
KR102424922B1 (ko) | Dlbn이 3 이상인 조건을 만족하는 확장 에스박스 및 이를 이용한 비트 연산 방법 | |
KR101944741B1 (ko) | 암호화 장치 및 방법 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PA0109 | Patent application |
Patent event code: PA01091R01D Comment text: Patent Application Patent event date: 20151029 |
|
A201 | Request for examination | ||
PA0201 | Request for examination |
Patent event code: PA02012R01D Patent event date: 20160203 Comment text: Request for Examination of Application Patent event code: PA02011R01I Patent event date: 20151029 Comment text: Patent Application |
|
PG1501 | Laying open of application | ||
E902 | Notification of reason for refusal | ||
PE0902 | Notice of grounds for rejection |
Comment text: Notification of reason for refusal Patent event date: 20170522 Patent event code: PE09021S01D |
|
E902 | Notification of reason for refusal | ||
PE0902 | Notice of grounds for rejection |
Comment text: Notification of reason for refusal Patent event date: 20180226 Patent event code: PE09021S01D |
|
E601 | Decision to refuse application | ||
PE0601 | Decision on rejection of patent |
Patent event date: 20181025 Comment text: Decision to Refuse Application Patent event code: PE06012S01D Patent event date: 20180226 Comment text: Notification of reason for refusal Patent event code: PE06011S01I Patent event date: 20170522 Comment text: Notification of reason for refusal Patent event code: PE06011S01I |
|
AMND | Amendment | ||
PX0901 | Re-examination |
Patent event code: PX09011S01I Patent event date: 20181025 Comment text: Decision to Refuse Application |
|
E902 | Notification of reason for refusal | ||
PE0902 | Notice of grounds for rejection |
Comment text: Notification of reason for refusal Patent event date: 20181224 Patent event code: PE09021S01D |
|
AMND | Amendment | ||
PX0701 | Decision of registration after re-examination |
Patent event date: 20190529 Comment text: Decision to Grant Registration Patent event code: PX07013S01D Patent event date: 20190221 Comment text: Amendment to Specification, etc. Patent event code: PX07012R01I Patent event date: 20181122 Comment text: Amendment to Specification, etc. Patent event code: PX07012R01I Patent event date: 20181025 Comment text: Decision to Refuse Application Patent event code: PX07011S01I |
|
X701 | Decision to grant (after re-examination) | ||
GRNT | Written decision to grant | ||
PR0701 | Registration of establishment |
Comment text: Registration of Establishment Patent event date: 20190611 Patent event code: PR07011E01D |
|
PR1002 | Payment of registration fee |
Payment date: 20190611 End annual number: 3 Start annual number: 1 |
|
PG1601 | Publication of registration | ||
PR1001 | Payment of annual fee |
Payment date: 20220526 Start annual number: 4 End annual number: 4 |
|
PR1001 | Payment of annual fee |
Payment date: 20230524 Start annual number: 5 End annual number: 5 |
|
PR1001 | Payment of annual fee |
Payment date: 20240523 Start annual number: 6 End annual number: 6 |