>백엔드 개발 >PHP 튜토리얼 >PHP 7에서 피해야 할 10가지 함정

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

不言
不言원래의
2018-04-13 16:10:271198검색

이 기사에서는 PHP 7에서 피해야 할 10가지 함정을 공유합니다. 특정 참조 값이 있습니다. 필요한 친구가 참조할 수 있습니다.

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

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

2. 쓸모없는 코드를 작성하지 마세요mysql_ 函数的提示了。因为 PHP 7 从核心上完全移除了它们,这意味着请你移步至更好的 mysqli_ 类函数,或者更灵活的 PDO 层。

2. 不要写无用的代码

这看上去是个无脑建议,但是随着 PHP7 速度的提升掩盖了一些问题使它显得日趋重要。不要仅仅因切到 PHP7 让网站速度变得快点,你就沾沾自喜了。

想理解速度的重要性和如何做的更好,去看看我们这篇文章 初学者加速优化指南。

作为开发者,应该确保按需加载脚本,可能时再组合,编写高效的数据库查询语句,如果可能的话 使用缓存 等等。

3. 不要在文件末尾使用 PHP 闭合标签

如果你随便看看,就会发现大部分 WordPress 核心代码文件结尾都省略了 PHP 闭合标签。事实上,Zend 框架尤为明显地 禁止了闭合标签。它并非 PHP 所必须,在文件结尾处省略它,可确保结尾无额外空白。

4. 如非必须不要引用传参

我个人非常不喜欢引用传参。我当然知道在某些场合下它很有用,但是多数场合下,它会使得代码难以理解,难以遵循,难以预测结果。

人们认为引用可以使它们的代码更快,不过正如 可敬的 PHP 程序员 的这篇文章所指出的,事实并非如此。

PHP 内置的 shuffle() 或者 sort() 函数,就是糟糕的引用传参案例。 它修改了原数组而不是返回一个打乱的或者排好序的数组,这是完全违背了我们意愿的。

5. 不要在循环里使用查询

在循环中使用数据库查询时最糟糕的。他会给系统带来不必要的压力,并且很有可能,你可以在循环外使用查询而更快的得到相同的结果。当我碰到必须这样用的场景时,我通常会通过分成两个查询来构造一个数组的方式来解决。然后循环数组而无需循环查询。

由于 WordPress 的运行方式,这样做可能会有些例外。 get_post_meta() 将从数据库获取一个元数据,如果您正在循环访问特定文章的元数据,则可以在循环中使用它。这是因为当你第一次使用它的时候,WordPress 实际上取得了所有的元数据并缓存了起来。 之后的调用实际上是调用缓存数据而不是调用数据库。

解决这些问题的最好办法是阅读函数文档并且使用一些类似 查询监听器 的东西。

6. 不要在 SQL 查询中使用 *

好吧,这更像是一个 MySQL 的问题,但我们更倾向于在代码中编写 SQL 语句,所以我说这是个公平的游戏。不管什么情况下,如果你能避免使用通配符,那就不要使用,尤其是当你的数据库有很多字段的时候。

明确指定你需要的字段,并且只检索这些字段。这有助于节省内存,保护数据,并且能让事情变得更加清晰明白。

在 SQL 方面,尽可能的了解你可用的函数并测试速度。 当计算平均数,求和以及计算相似的数字的时候,使用 SQL 内置函数而不是 PHP 的函数。 如果你不确定一个查询的速度快慢,测试一下它并和其他做法进行比较,选出最好的那一种。

7. 不要信任用户的输入

信任用户输入并不明智。对于用户输入,总是需要过滤,杀毒,转义,校验以及使用回退。 用户输入存在三个问题:我们开发者不可能考虑到所有可能性,经常出错,存心的恶意输入。

一个经过深思熟虑的系统可以防止所有的这些问题。 在使用数据库时,确保使用内置的函数,如 filter_var()

이는 어리석은 제안처럼 보일 수 있지만 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를 효과적으로 활용하기 위해서는 자바스크립트를 배워야 합니다.

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

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

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

관련 권장 사항:

Redis를 올바르게 사용하기 위한 10가지 팁

PHP_PHP 프로그래밍을 위한 10가지 고급 팁

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

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