메뉴 건너뛰기

프로그래밍


웹앱 등에서 활용할만 한 팁을 정리해 봅니다.


자바스크립트에서 CryptoJS 라이브러리를 이용해 데이터를 암호화를 하고 PHP에서 복호화 하는 예제입니다.

(This is the way how to encrypt data with Javascript and decrypt it with PHP)


- 자바스크립트에서 암호화 하는 방법 (Encrypt data with Javascript)

var key = CryptoJS.enc.Hex.parse("1234567811111111abcdefabcd123123");
var iv =  CryptoJS.enc.Hex.parse("abcd1231231234567811111111abcdef");	

function Encrypt(value) {		
	var encrypted = CryptoJS.AES.encrypt(value, key, {iv:iv,mode: CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7});
	encrypted = encrypted.ciphertext.toString(CryptoJS.enc.Base64);
	return encodeURIComponent(encrypted);	
}


- PHP에서 복호화 하는 방법 (Decrypt data with Javascript)


우선 아래와 같이 클래스를 만듭니다. (First, make a class for decryption)

class AESCrypt
{	
 var $skey;
 var $iv;
    		  	  					
 function setKey($KEY, $IV)
 {
  $this->skey = $KEY;	
  $this->iv = $IV;	
 }

 function decrypt ($value)        
 {            	        
  $value = base64_decode($value);
  $output = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $this->skey, $value, MCRYPT_MODE_CBC, $this->iv) ;					    
  $valueLen = strlen($output) ;

  if ( $valueLen % 16 > 0 )
   $output = "";
  
  $padSize = ord ($output{$valueLen - 1}) ;
  if ( ($padSize < 1) or ($padSize > 16) )
   $output = "";                // Check padding.                
					
  for ($i = 0; $i < $padSize; $i++)
  {
   if ( ord ($output{$valueLen - $i - 1}) != $padSize )
    $output = "";
  }

  $output = substr ($output, 0, $valueLen - $padSize);					    
					    					    					
  return $this->filter($output);        
 }    

 function filter($par)
 {
     $par = htmlspecialchars($par);
     $par = strip_tags($par);
     $par = mysql_real_escape_string($par);
     $par = str_replace("'","\"",$par);
     $par = str_replace("`","\"",$par);
     $par = $par.trim();

     return $par;
   }
}


그리고 아래와 같이 사용합니다. (Decrypt data with PHP)

$mcrypt = new AESCrypt();
$key = attemptpack("1234567811111111abcdefabcd123123");
$iv =  attemptpack("abcd1231231234567811111111abcdef");
$mcrypt->setKey($key,$iv);
// Decryption
$mydata = $mcrypt->decrypt($_GET['data']);

function attemptpack($s) {                
  $p=pack("H*", $s);                
  return $p;
}





profile
  • profile
    아, 감사합니다! 말씀하신 내용 채워 넣었습니다^^
제목 날짜
[TIP] PYTHON 에서 "UnicodeDecodeError: 'cp949' codec can't decode byte 0xe2 in position 6987: illegal multibyte sequence" 오류 날때... 4 2016.02.20
[TIP] JQuery와 PHP로 이미지 파일을 업로드 하는 간단한 소스 (How to upload image file on PHP server by using JQuery) 2015.04.03
[TIP] R에서 페이스북 페이지 정보 크롤링 하기 2 2017.02.11
[TIP] PYTHON 에서 "UnicodeDecodeError: 'cp949' codec can't decode byte 0xe2 in position 6987: illegal multibyte sequence" 오류 날때... 4 2016.02.20
[TIP] JQuery와 PHP로 이미지 파일을 업로드 하는 간단한 소스 (How to upload image file on PHP server by using JQuery) 2015.04.03
[TIP] R에서 페이스북 페이지 정보 크롤링 하기 2 2017.02.11
[TIP] TensorFlow를 윈도우에서 사용하기 (A way to use TensorFlow on Windows) 3 2016.04.16
[TIP] 파이선에서 구글 스프레드시트 사용하기 5 2016.03.27
[TIP] php로 기상청에서 제공하는 기상정보 API 호출하기 2017.01.17
[TIP] 인터넷으로 문자메시지 (SMS) 보내기 2008.03.23
[TIP] 네이버 영화 정보와 전문가 평점 얻어오기 2017.02.10
[TIP] Docker상의 Syntaxnet 결과 포맷을 수정하기 2016.08.07
[TIP] 자바스크립트와 PHP코드간에 암호화 통신하기 (Encrypt with Javascript, Decrypt with PHP) 2 2017.03.16
[펌] 클래스 맴버함수를 콜백함수로 사용하기 2006.08.25
[TIP] 홈페이지 자동 클릭하기 소스 2009.10.25
[MFC]GIF Animation Control 2003.08.05
[TIP] VFW 에서 영상 압축을 위한 코덱을 코드상에서 선택하여 실시간 저장하는 방법입니다. 2010.02.04
[TIP] C# 에서 Win32 DLL 을 사용하기 위한 방법 2009.07.16
[TIP] 파이선으로 TED에서 가장많이 사용된 단어들 줄세우기 2016.04.03
[TIP] Visual Studio App Wizard 만들기 관련 2009.12.17
[TIP] MySQL - NaviCat 사용시 에러 확인방법 2010.02.23
가상키보드 후킹 포커스 문제... 1 2010.12.10
[TIP] 설치된 코덱 리스트 얻어오기 2010.02.18
태그 목록
위로