>백엔드 개발 >PHP 튜토리얼 >좋은 PHP 인터뷰 질문과 답변

좋은 PHP 인터뷰 질문과 답변

WBOY
WBOY원래의
2016-07-25 08:53:461130검색
  1. strrev($str)
  2. {
  3. $len=strlen($str);
  4. $newstr = '';
  5. for( $i=$len;$i>=0;$i--)
  6. {
  7. $newstr .= $str{$i};
  8. }
  9. return $newstr;
  10. }
코드 복사

15. 중국어 문자열을 문자 깨짐 없이 가로채는 방법.

정답: mb_substr()

16. PHP를 사용하여 "Zhang San"이라는 이름의 모든 콘텐츠를 찾아 인쇄하는 간단한 쿼리를 작성합니다.

  1. 테이블 이름 사용자
  2. 이름 전화 내용 날짜
  3. 장산 13333663366 대학 졸업 2006-10-11
  4. 장산 13612312331 학부 졸업 2006 -10-15
  5. Zhang Si 021-55665566 기술중등학교 졸업 2006-10-15
  6. 답변: 사용자로부터 이름, 전화번호, 내용, 날짜를 선택하세요. 여기서 이름='Zhang San'
코드 복사

17. 다음 클래스를 사용하고 그 의미를 설명하는 방법은 무엇입니까?

  1. 수업 테스트
  2. {
  3. get_test($num)
  4. {
  5. $num=md5(md5($num). "en");
  6. return $num;
  7. }
  8. }
코드 복사

답변: 사용법: $get_test = 새로운 테스트(); $result = $get_test->get_test(2);

$num 변수는 두 번 md5ed되어 반환되며 두 번째 md5의 매개 변수는 첫 번째 md5($num) 뒤에 en

으로 추가됩니다.

18. 파일 확장자를 얻는 데 5가지 이상의 방법을 사용하세요

필수: dir/upload.image.jpg, .jpg 또는 jpg 찾기,

답변: 파일 확장자를 얻으려면 5가지 이상의 방법을 사용하십시오.

  1. 1)

  2. get_ext1($file_name)
  3. {
  4. return strrchr($file_name, '. ');
  5. }
  6. 2)
  7. get_ext2($file_name)
  8. {
  9. return substr($file_name, strrpos($file_name, '.'));
  10. }
  11. 3)
  12. get_ext3($file_name)
  13. {
  14. return array_pop(explode('.', $file_name));
  15. }

  16. 4)

  17. get_ext4($file_name)
  18. {
  19. $p = pathinfo($file_name);
  20. return $p['extension'];
  21. }
  22. 5)
  23. get_ext5( $file_name)
  24. {
  25. return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), '.')));
  26. }

코드 복사

19. 세션 생존 시간 수정 방법

이 라이브러리를 사용하면 다양한 형식의 그래픽 파일을 처리하고 표시할 수 있습니다. 이 라이브러리의 또 다른 일반적인 용도는 그래픽 파일을 만드는 것입니다. gd 이외의 다른 옵션은 imagemagick이지만 이 함수 라이브러리는 PHP에 내장되어 있지 않으며 시스템 관리자가 서버에 설치해야 합니다. 답변: 실제로 세션은 세션 수명을 설정하는 session_set_cookie_params() 함수도 제공합니다. session_start() 함수가 호출되기 전에 함수를 호출해야 합니다.

  1. // 하루 동안 저장
  2. $lifetime = 24 * 3600
  3. session_set_cookie_params($lifetime); 🎜> session_start();
  4. $_session["admin"] = true;
  5. ?>
코드 복사
20. 다음 함수를 구현합니다. 문자열 "open_door"는 "opendoor"로 변환되고 "make_by_id"는 "makebyid"로 변환됩니다. 30. 개발 과정에서 페이지 로딩 속도를 높이기 위해 어떤 방법을 사용하는지 예를 들어주세요. 에이. 정적 HTML 생성 비. XML 생성 기음. 데이터베이스를 사용하지 않는 경우 데이터베이스를 사용하여 변수 매개변수를 텍스트로 저장하지 마십시오. 디. zend로 가속화 답변:

  1. 기능 테스트($str){
  2. $arr1=explode('_', $str);
  3. //$arr2=array_walk($arr1,ucwords( ));

  4. $str = implode(' ',$arr1);

  5. return ucwords($str);
  6. }
  7. $aa='open_door';
  8. 에코 테스트($aa);
  9. ?>

코드 복사

21. PHP 환경 변수를 사용하여 웹페이지 주소의 내용을 가져오는 방법은 무엇입니까? IP 주소를 얻는 방법?

답변: $_servsr['request_uri']

$_server['remote_addr']

22. 2007-2-5 ~ 2007-3-6의 날짜 차이 등 두 날짜의 차이를 찾아보세요

정답: (strtotime('2007-3-6')-strtotime('2007-2-5'))/3600*24

23. 테이블에는 a, b, c 세 개의 열이 있으며 SQL 문을 사용하여 구현할 수 있습니다. a 열이 b 열보다 크면 a 열을 선택하고, b 열이 더 크면 b 열을 선택합니다. c열보다 b열을 선택하고, 그렇지 않으면 c열을 선택합니다.

답변: a>b인 경우를 선택한 다음 a else b가 끝나는 경우를 선택하고, b>c이면 b else c가 끝나는 경우 테스트에서

24. 프로젝트에서 SQL문의 실행 효율성을 최적화하는 방법을 간략하게 설명해주세요. 어떤 측면에서 SQL문의 성능을 분석하나요?

정답: (1) 가장 효율적인 테이블 이름 순서를 선택하세요

(2) where 절의 연결 순서

(3) select 절에 '*' 사용을 피하세요

(4) have 절을 where 절로 교체

(5) 내부 기능을 통한 SQL 효율성 향상

(6) 인덱스 열에 계산을 사용하지 마세요.

(7) 그룹화하기 전에 불필요한 레코드를 필터링하여 그룹별 명령문의 효율성을 향상시킵니다.

25.mysql_fetch_row()와 mysql_fetch_array()의 차이점은 무엇인가요?

mysql_fetch_row()는 0부터 시작하는 배열에 데이터베이스 열을 저장합니다. 첫 번째 열은 배열 인덱스 0에, 두 번째 열은 인덱스 1에 있는 식으로 진행됩니다. mysql_fetch_assoc()은 연관 배열에 데이터베이스 열을 저장합니다. 예를 들어, 내 데이터베이스 쿼리는 "first_name", "last_name" 및 "email"의 세 필드를 반환합니다. 배열은 "first_name", "last_name" 및 "email"입니다. mysql_fetch_array()는 mysql_fetch_row()와 mysql_fetch_assoc()의 값을 모두 반환할 수 있습니다.

26.다음 코드는 어떤 용도로 사용되나요? 설명해주세요. $date='08/26/2003';print ereg_replace("([0-9] )/([0-9] )/([0-9] )","\2/\1/\3" ,$날짜);

날짜를 mm/dd/yyyy 형식에서 dd/mm/yyyy 형식으로 변환합니다. 내 좋은 친구는 이 정규식을 다음과 같은 명령문으로 분해할 수 있다고 말했습니다. 이렇게 간단한 표현식의 경우 순전히 설명의 편의를 위해 분해할 필요가 없습니다.

// 하나 이상의 0-9에 해당하고 그 뒤에 슬래시가 옵니다. $regexpression = "([0-9] )/";// 하나 이상의 0-9에 해당하고 그 뒤에 다른 슬래시가 옵니다. .= "([0-9] )/";// 다시 하나 이상의 0-9$regexpression에 해당합니다.= "([0-9] )" \2/\1/\ 3이 사용됩니다. 첫 번째 괄호는 월에 해당합니다.

27.gd 라이브러리는 어떤 용도로 사용되나요?

답변: 이 라이브러리를 사용하면 다양한 형식의 그래픽 파일을 처리하고 표시할 수 있습니다. 또 다른 일반적인 용도는 그래픽 파일을 만드는 것입니다. gd 외에 또 다른 옵션은 imagemagick이지만 이 라이브러리는 PHP에 내장되어 있지 않으며 시스템 관리자가 서버에 설치해야 합니다

28. 개발 과정에서 페이지 로딩 속도를 높이기 위해 어떤 방법을 사용하는지 예를 들어주세요. 답변: 필요할 때만 서버 리소스를 열고, 제때에 서버 리소스를 닫고, 데이터베이스에 인덱스를 추가하면 페이지에서 별도의 서버에 정적 파일, 그림 및 기타 대용량 파일을 생성할 수 있습니다. 코드 최적화 도구 사용

29. SQL 인젝션 취약점을 방지하기 위해 일반적으로 __addslashes___ 함수를 사용합니다.

30. PHP에서 값 전달, 참조 전달, 주소 전달의 차이점은 무엇인가요? 답변: 값을 전달하는 것은 실제 매개변수의 값을 행 매개변수에 할당하는 것입니다. 그러면 행 매개변수를 수정해도 실제 매개변수의 값에는 영향을 미치지 않습니다

주소 전달은 값을 전달하는 특별한 방법이지만 전달하는 것은 일반적인 int가 아닌 주소입니다. 주소를 전달한 후 실제 매개변수와 행 매개변수는 동일한 객체를 가리킵니다.

31. 자바스크립트를 통해 창이 차단되었는지 확인하는 방법 답변: open()의 반환 값을 가져옵니다. null이면 차단됩니다.

33. 트래픽이 많은 웹사이트의 경우 트래픽 문제를 해결하기 위해 어떤 방법을 사용하시나요

A: 먼저 서버 하드웨어가 현재 트래픽을 지원할 만큼 충분한지 확인하세요.

둘째, 데이터베이스 액세스를 최적화합니다.

셋째, 외부 핫링크는 금지됩니다.

넷째, 대용량 파일의 다운로드를 제어합니다.

다섯째, 다른 호스트를 사용하여 주요 트래픽을 전환하세요

여섯째, 트래픽 분석 및 통계 소프트웨어를 활용하세요

위 내용은 PHP 면접 질문과 관련 답변을 공유한 내용으로, 모든 분들께 도움이 되기를 바랍니다.



성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.