자주 사용되는 문자열 관련 함수들 중에서 addslashes() 함수부터 알아보겠습니다.
addslashes() 함수의 역할은
어떤 문자열을 데이타베이스의 필드값으로 저장하기 전에 사용되는 함수로
만일, 그 문자열에 특수 문자, 예를 들어 작은 따옴표('), 쌍 따옴표("), 역슬래시(\) 문자가 포함되어 있다면 그러한 문자앞에 역슬래시(\)를 붙이는 역할을 합니다.
그렇게, 특수 문자에 역슬래시가 붙어서 데이타베이스의 필드값으로 저장되면 그 특수 문자가 순수한 하나의 문자로 인식되어 저장됩니다.(약간 난해하죠..^^)
만일, 데이타베이스에 저장하기 전에 addslashes() 함수를 사용하지 않으면
데이타베이스의 필드값에 저장되는 문자열 가운데 특수 문자가 포함될 경우 그 문자가 하나의 일반적인 문자가 아닌 특수 문자로 인식되어 오류를 일으키거나 잘못된 결과를 초래할 수 있습니다.
따라서, addslashes() 함수는 실제로 PHP 로 DB 연동하여 코딩할 때 중요하게 쓰이는 함수입니다.
그리고, stripslashes() 함수는 addslashes() 함수와 짝을 이루어 사용되는 것으로 역할은 addslashes() 함수의 반대입니다.
즉, stripslashes() 함수는 addslashes() 함수에 의해 어떤 특수 문자 앞에 역슬래시(\) 문자가 붙어 있는 문자열에서 다시 그 역슬래시 문자를 떼어내는 역할을 합니다.
그럼, 위 두 함수를 사용한 간단한 예제를 보겠습니다.
(물론, 위 두 함수는 아래 예제와 같은 단순한 용도로 사용되지는 않구요, 데이타베이스의 필드값에 문자열을 저장하고 추출할 때 사용됩니다.)
<?
$string = "안녕...'미즐'";
$added_string = addslashes($string);
echo("$added_string <br>");
$stripped_string = stripslashes($added_string);
echo("$stripped_string");
?>
위 코드를 실행하면 위에서 설명해드린대로 다음과 같은 결과가 출력되겠죠.
안녕...\'미즐\' -> addslashes() 함수 처리 후
안녕...'미즐' -> stripslashes() 함수 처리 후
이해가 좀 되시나요?
이제 또 다른 문자열 함수로 strcmp() 함수에 대해 알아보겠습니다.
strcmp() 함수는 두 개의 문자열을 비교한 후 만일 두 문자열이 일치하면 0 을 반환하고 일치하지 않으면 0 이 아닌 값을 반환하는 역할을 합니다.
그럼, strmcmp() 함수를 사용한 간단한 예제를 보겠습니다.
<?
$string_1 = "apple";
$string_2 = "apple";
$string_3 = "orange";
if(!strcmp($string_1, $string_2)) {
echo("두 문자열이 일치합니다.");
} else {
echo("두 문자열이 일치하지 않습니다.");
}
echo("<br>");
if(!strcmp($string_1, $string_3)) {
echo("두 문자열이 일치합니다.");
} else {
echo("두 문자열이 일치하지 않습니다.");
}
?>
위 코드의 실행과정을 살펴보면 먼저, $string_1 변수값과 $string_2 변수값을 비교하는 조건문이 실행되는데 두 변수값에 저장된 문자열은 일치하기 때문에 strcmp() 함수의 반환값으로 0 이 생성됩니다.
따라서, strcmp() 함수 앞에 붙어있는 느낌표 표시(!) 즉, 부정(not) 을 의미하는 연산자에 의해 0 값이 1 값으로 바꾸어지게 되며, 결국 if 조건문은 참(true) 값을 가질 때 수행되는 코드를 실행하게 됩니다.
그리고, 두 번째로 $string_1 변수값과 $string_3 변수값을 비교하는 조건문이 실행되는데 두 변수값에 저장된 문자열은 일치하지 않기 때문에 strcmp() 함수의 반환값으로 0 이 아닌값이 생성됩니다.
따라서, if() 의 값은 strcmp() 함수 앞에 붙어있는 not 연산자(!) 에 의해 0 이 아닌값이 0 으로 바뀌며, 결국 if 조건문은 거짓(false) 값을 가질 때 수행되는 코드(else 절의 코드)를 실행하게 됩니다.
그래서, 출력 결과는 각각 순서대로 다음과 같이 나오겠죠.
두 문자열이 일치합니다.
두 문자열이 일치하지 않습니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 19528 |
JavaScript
그누보드4 에 Daum 우편번호 찾기 API 연동 하기.
|
| 6810 | |
| 6807 | |
| 6801 | |
| 6798 | |
| 6791 | |
| 24615 | |
| 24612 | |
| 6788 | |
| 30933 | |
| 6784 | |
| 6783 | |
| 27834 | |
| 19527 | |
| 19526 | |
| 19524 |
MySQL
MYSQL 기본 명령어들 모음
1
|
| 19521 | |
| 6777 | |
| 6770 | |
| 19519 |
웹서버
FTP 프로세스 죽이기
1
|
| 27823 | |
| 6766 | |
| 24604 | |
| 6760 | |
| 6757 | |
| 30925 | |
| 19518 | |
| 30924 |
CSS
CSS slider 테스트1
|
| 30923 |
CSS
수평메뉴1
|
| 6746 |
개발자
스페이스 vs 탭
10
|
| 19516 |
node.js
Node.js 서버의 기본적인 내용 정리
1
|
| 30922 |
기타
dpi 환산표(?)
|
| 19515 | |
| 30921 | |
| 6732 |
개발자
미수금은 적립금인가요..
13
|
| 27803 | |
| 19508 |
PHP
숫자를 한글로 변환
2
|
| 19507 | |
| 24599 | |
| 19504 |
PHP
썸네일 클래스입니다
2
|
| 19501 | |
| 19498 |
MySQL
자주쓰는 MYSQL
2
|
| 19497 | |
| 19496 |
PHP
두지점의 위도,경도간 거리계산
|
| 19495 | |
| 19493 |
MySQL
무한 로딩 중인 쿼리 죽이기
1
|
| 19492 |
기타
파폭 ssh, ftp
|
| 19491 |
MySQL
mysql 기본 사용법
|
| 19490 | |
| 19489 | |
| 6721 |
개발자
암울한 웹의 미래
10
|
| 6720 |
개발자
혁신적이거나 싸지거나
|
| 19488 |
jQuery
제이쿼리를 이용하여 노드 선택
|
| 19487 |
jQuery
append를 이용하여 엘리먼트 추가하기
|
| 19486 | |
| 19485 |
JavaScript
000000.1원팁 ^^ 자스로 아이프레임 target 제어
|
| 30919 | |
| 19484 | |
| 30913 | |
| 30910 | |
| 19483 |
JavaScript
레이어를 이용한 셀렉트 박스
|
| 19482 |
JavaScript
유투브 동영상 노출 시 자동 실행 또는 자동 종료 소스입니다.
|
| 19478 |
jQuery
페이스북 글 가져오기 쉬운방법.
3
|
| 30908 | |
| 19477 | |
| 31683 | |
| 19475 | |
| 19473 | |
| 19471 | |
| 19470 | |
| 19469 | |
| 19468 |
JavaScript
아이폰5s 소개페이지같은 사이트 만들기(?)
|
| 19467 |
PHP
달력 출력하기
|
| 19466 | |
| 19464 |
JavaScript
[1원짜리팁]새창 띄우기 소스
1
|
| 19462 | |
| 19461 | |
| 19460 |
JavaScript
아이프로그램 닫기
|
| 19459 |
JavaScript
자바스크립트 공백 제거
|
| 31680 | |
| 19458 | |
| 19457 | |
| 31676 | |
| 31674 | |
| 31671 | |
| 31670 | |
| 31669 | |
| 31664 | |
| 31663 | |
| 31662 | |
| 31658 | |
| 31657 | |
| 19456 |
PHP
GPS정보 모바일에서 사용하기
|
| 19455 | |
| 31655 | |
| 31653 | |
| 31649 | |
| 31646 | |
| 27800 | |
| 19454 |
JavaScript
메뉴 네비 레이어 서서히 없어지는거
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기