>  기사  >  백엔드 개발  >  PHP에서 피해야 할 10가지 함정

PHP에서 피해야 할 10가지 함정

烟雨青岚
烟雨青岚앞으로
2020-07-15 12:54:082163검색

PHP에서 피해야 할 10가지 함정

1. mysql_ 클래스 함수를 사용하지 마세요

마지막으로, 더 이상 mysql_ 함수를 사용하지 말라는 메시지를 볼 필요가 없습니다. PHP 7에서는 이를 코어에서 완전히 제거하므로 이는 더 나은 mysqli_ 클래스 기능이나 더 유연한 PDO 계층으로 이동하는 것을 의미합니다.

2. 쓸데없는 코드를 작성하지 마세요

어리석은 제안처럼 보일 수도 있지만, PHP7의 속도가 증가함에 따라 일부 문제가 가려지고 점점 더 중요해집니다. PHP7로 전환하면 사이트가 더 빨라진다고 해서 안주하지 마세요.

속도의 중요성과 이를 더 잘 수행하는 방법을 이해하려면 가속 최적화에 대한 초보자 가이드 기사를 확인하세요.

개발자는 요청 시 스크립트가 로드되고, 가능하면 결합되고, 효율적인 데이터베이스 쿼리를 작성하고, 가능하면 캐싱을 사용하는 등의 작업을 수행해야 합니다.

3. 파일 끝에 PHP 닫는 태그를 사용하지 마세요

조금만 살펴보면 대부분의 WordPress 핵심 코드 파일 끝에는 PHP 닫는 태그가 생략되어 있습니다. 실제로 Zend Framework는 특히 닫는 태그를 비활성화합니다. PHP에서는 필요하지 않습니다. 파일 끝에서 생략하면 끝에 추가 공백이 발생하지 않습니다.

4. 꼭 필요한 경우가 아니면 매개변수를 인용하지 마세요

저는 개인적으로 매개변수 인용을 별로 좋아하지 않습니다. 물론 어떤 상황에서는 유용할 수 있다는 것을 알고 있지만 대부분의 경우 코드를 이해하기 어렵고, 따라가기 어렵고, 결과를 예측하기도 어렵습니다.

사람들은 참조가 코드를 더 빠르게 만든다고 생각하지만 The Respectable PHP Programmer의 이 기사에서 지적하듯이 그것은 사실이 아닙니다.

PHP에 내장된 shuffle() 또는 sort() 함수는 참조에 의한 매개변수 전달의 나쁜 예입니다. 섞이거나 정렬된 배열을 반환하는 대신 원래 배열을 수정합니다. 이는 우리가 원하는 것과 완전히 반대입니다.

5. 루프에 쿼리를 사용하지 마세요.

가장 나쁜 것은 데이터베이스 쿼리를 루프에 사용하는 것입니다. 이는 시스템에 불필요한 스트레스를 가할 것이며, 루프 외부에서 쿼리를 사용하면 동일한 결과를 더 빨리 얻을 수 있을 것입니다. 이런 식으로 사용해야 하는 상황이 발생하면 보통 두 개의 쿼리로 나누어 배열을 구성하는 방식으로 해결합니다. 그런 다음 쿼리를 반복하지 않고 배열을 반복합니다.

WordPress 작동 방식으로 인해 이에 대한 몇 가지 예외가 있을 수 있습니다. get_post_meta()는 데이터베이스에서 메타데이터를 가져오며, 특정 게시물에 대한 메타데이터를 반복하는 경우 루프에서 사용할 수 있습니다. WordPress를 처음 사용할 때 실제로 모든 메타데이터를 가져와 캐시하기 때문입니다. 후속 호출은 실제로 데이터베이스를 호출하는 대신 캐시된 데이터를 호출합니다.

이러한 문제를 해결하는 가장 좋은 방법은 함수 문서를 읽고 쿼리 리스너와 같은 것을 사용하는 것입니다.

6. SQL 쿼리에 *를 사용하지 마세요

글쎄요, 이것은 MySQL에 관한 질문에 가깝지만 우리는 SQL 문을 코드로 작성하는 경향이 있으므로 이것이 공정한 게임이라고 생각합니다. 어쨌든 와일드카드 사용을 피할 수 있다면 와일드카드를 사용하지 마십시오. 특히 데이터베이스에 필드가 많은 경우에는 더욱 그렇습니다.

필요한 필드를 명시적으로 지정하고 해당 필드만 검색하세요. 이렇게 하면 메모리를 절약하고 데이터를 보호하며 상황을 더 명확하게 만드는 데 도움이 됩니다.

SQL 측면에서 사용 가능한 기능에 대해 최대한 많이 배우고 속도를 테스트하세요. 평균, 합, 유사수 계산 시에는 PHP 함수 대신 SQL 내장 함수를 사용하세요. 쿼리가 얼마나 빠른지 확실하지 않은 경우 테스트하고 다른 접근 방식과 비교하여 가장 좋은 쿼리를 선택하세요.

7. 사용자 입력을 믿지 마세요

사용자 입력을 신뢰하는 것은 현명하지 않습니다. 사용자 입력의 경우 항상 필터링, 삭제, 이스케이프, 유효성 검사 및 대체 사용이 필요합니다. 사용자 입력에는 세 가지 문제가 있습니다. 우리 개발자가 모든 가능성을 고려하는 것은 불가능하며, 빈번한 실수와 의도적인 악의적인 입력입니다.

잘 고안된 시스템은 이러한 모든 문제를 예방할 수 있습니다. 데이터베이스를 사용할 때는 filter_var()와 같은 내장 함수를 사용하여 유효성을 확인하고 이스케이프하는 등 가능한 모든 작업을 수행하세요.

WordPress에는 도움이 되는 다양한 기능이 있습니다. 사용자 데이터 유효성 검사, 이스케이프 및 삭제에 대해 자세히 알아보려면 이 문서를 살펴보세요.

8. 똑똑해지지 마세요

당신의 목표는 당신의 소망을 명확하게 표현하는 우아한 코드를 작성하는 것입니다. 변수 이름 단축, 다단계 삼항 논리 연산 및 기타 트릭을 사용하여 각 페이지의 로딩 시간을 0.01초 절약할 수 있지만, 귀하와 귀하의 팀이 골치 아픈 일과 유지 관리의 어려움을 초래하는 결과에 비하면 손실을 볼 가치는 없습니다.

변수 이름을 적절하게 지정하고 코드를 간결하고 명확하게 문서화하세요. 많은 인라인 코드 주석을 사용하는 것보다 표준화된 객체 지향 코딩 스타일을 사용하고 이를 문서화하는 것이 더 좋습니다.

9. 바퀴를 재발명하지 마세요.

PHP는 한동안 존재해왔고 웹사이트 개발은 훨씬 더 오래되었습니다. 당신이 한 일은 이전에 다른 사람이 한 일입니다. Github, Composer, Packagist는 모두 여러분의 멘토입니다.

로거부터 컬러 프로세서까지, 분석기부터 단위 테스트 프레임워크까지, Mailchimp API부터 Twitter Bootstrap까지 모든 것이 단 한 번의 버튼 클릭(또는 명령 실행)이면 가능하므로 사용하세요!

10. 다른 언어를 무시하지 마세요

PHP 사용자라면 이제 최소한 HTML, CSS, Javascript 및 MySQL을 아는 것이 표준입니다. 이러한 언어들을 잘 다룰 수 있게 되면, 이제 Javascript를 다시 배울 때입니다. 자바스크립트는 jQuery가 아닙니다. jQuery를 효과적으로 사용하려면 Javascript를 배워야 합니다.

PHP에서 객체 지향적인 모든 것을 배우는 것도 추천합니다. 이는 생명의 은인이며 코드를 몇 배나 향상시킬 것입니다. 또한 C# 및 Java와 같은 언어에 대한 문을 열 수 있으므로 해당 언어에 대한 경험이 있으면 객체 지향 프로그래밍(OOP)을 더 쉽게 이해할 수 있습니다.

패키지 관리, 빌드 스크립트, Coffeescript, LESS, SASS, YAML, 템플릿 엔진 및 기타 유용한 도구를 학습하여 지식을 확장하세요. 또한 다른 프레임워크, 특히 Laravel을 살펴보는 것을 진심으로 권장합니다.

이러한 작업에 능숙하다면 Ruby, Ruby on Rails 및 Android, iPhone, Windows Phone용 앱 개발을 고려해 보세요. 이것이 당신의 안전 지대와 직업 요구 사항을 벗어나기 때문에 무의미하다고 생각할 수도 있지만, 이것이 바로 핵심입니다. 모든 언어에는 유용한 교육학적 지식과 무해한 추가 지식이 있습니다. 모든 최고의 PHP 개발자는 다른 프로그래밍 언어를 알고 있습니다. 이는 우연이 아닙니다!

읽어주신 모든 분들께 감사드리며, 많은 혜택 받으시길 바랍니다.

이 기사는 https://www.cnblogs.com/summerblue/p/8778819.html

추천 튜토리얼: "php tutorial"

에 재인쇄되었습니다.

위 내용은 PHP에서 피해야 할 10가지 함정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제