찾다
백엔드 개발PHP 튜토리얼PHP 编程的 5个良好习惯_PHP教程

PHP 编程的 5个良好习惯_PHP教程

Jul 21, 2016 pm 03:48 PM
php일반적으로훌륭한낮은특정한개발하다상태능률비교하다~의프로그램 작성

根据具体的情况,一般的开发人员往往比优秀的开发人员的效率低 10%~20%。优秀的开发人员的效率更高,因为他们拥有丰富的经验和良好的编程习惯。不良的编程习惯将会影响到效率。本文通过展示一些良好的编程习惯,帮助您成为更优秀的程序员。

   这些良好的编程习惯不仅能提高效率,还能让您编写出在应用程序的整个生命周期中易于维护的代码。编写出来的代码可能需要大量的维护;应用程序的维护是一笔很大的开支。养成良好的编程习惯能够提高设计质量(比如模块化),从而使代码更加容易理解,因此维护就更加容易,同时也降低维护成本。

不良的编程习惯会造成代码缺陷,使其难以维护和修改,并且很可能在修改时又引入其他缺陷。以下是 5 个良好的编程习惯,能够帮助 PHP 代码避免这些缺陷:

  1. 使用良好的命名。
  2. 分成更小的部分。
  3. 为代码添加注释。
  4. 处理错误条件。
  5. 切忌使用复制粘贴。

下一小节将详细介绍这些习惯。

使用良好的命名

  使用良好的命名是最重要的编程习惯,因为描述性强的名称让代码更加容易阅读和理解。代码是否好理解取决于是否能在未来维护它。即便代码不带有注释,如果它很容易理解,将大大方便日后的更改。这个习惯的目标是让您编写的代码像书本一样容易阅读和理解。

不良习惯:含糊的或无意义的名称

  清单 1 中的代码包含过短的变量名、难以辨认的缩写词,并且方法名不能反映该方法的功能。如果方法名给人的感觉是它应该做这件事情,而实际中它却做另外的事情,这将带来严重的问题,因为它会误导人。


清单 1. 不良习惯:含糊的或无意义的名称

<BR><?php<br><br>function getNBDay($d)<BR>{<BR>switch($d) {<BR>case 5:<BR>case 6:<BR>case 7:<BR>return 1;<BR>default:<BR>return ($d + 1);<BR>}<BR>}<br><br>$day = 5;<br><br>$nextDay = getNBDay($day);<br><br>echo ("Next day is: " . $nextDay . "\n");<br><br>?><BR>

良好习惯:说明性强并且简洁的名称

  清单 2 中的代码体现了良好的编程习惯。新的方法名具有很强的说明性,反映了方法的用途。同样,更改后的变量名也更具说明性。惟一的保持最短的变量是<font face="新宋体">$i</font>,在本清单中,它是一个循环变量。尽管很多人不赞同使用过短的名称,但在循环变量中使用还是可以接受的(甚至有好处),因为它明确表明了代码的功能。


清单 2. 良好习惯:说明性强并且简洁的名称

<BR><?php<br><br>define ('MONDAY', 1);<BR>define ('TUESDAY', 2);<BR>define ('WEDNESDAY', 3);<BR>define ('THURSDAY', 4);<BR>define ('FRIDAY', 5);<BR>define ('SATURDAY', 6);<BR>define ('SUNDAY', 7);<br><br>/*<BR>*<BR>* @param $dayOfWeek<BR>* @return int Day of week, with 1 being Monday and so on.<BR>*/<BR>function findNextBusinessDay($dayOfWeek)<BR>{<BR>$nextBusinessDay = $dayOfWeek;<br><br>switch($dayOfWeek) {<BR>case FRIDAY:<BR>case SATURDAY:<BR>case SUNDAY:<BR>$nextBusinessDay = MONDAY;<BR>break;<BR>default:<BR>$nextBusinessDay += 1;<BR>break;<BR>}<br><br>return $nextBusinessDay;<BR>}<br><br>$day = FRIDAY;<br><br>$nextBusDay = findNextBusinessDay($day);<br><br>echo ("Next day is:" . $nextBusDay . "\n");<br><br>?><BR>

  我们鼓励您将大的条件拆分为一个方法,然后用能够描述该条件的名字命名方法。这个技巧能够提高代码的可读性,并且能够将条件具体化,使之能够被提取甚至重用。如果条件发生变化,更新方法也很容易。因为方法拥有一个有意义的名字,所以它能反映代码的用途,让代码更容易阅读。

 

分成更小的部分

  专心解决一个问题之后再继续编程,这样会让您更轻松。在解决一个紧急的问题时,如果继续编程,会使函数越来越长。从长远来说,这并不是一个问题,但您要记得回过头来将它重构为更小的部分。

  重构是个不错的主意,但您应该养成编写更短、功能更集中的代码。短的方法能够在一个窗口中一次看完,并且容易理解。如果方法过长,不能在一个窗口中一次看完,那么它就变得不容易理解,因为您不能快速地从头到尾了解它的整个思路。

  构建方法时,您应该养成这样的习惯,让每个方法只完成一件事情。这个习惯很好,因为:首先,如果方法只完成一件事情,那么它就更容易被重用;其次,这样的方法容易测试;第三,这样的方法便于理解和更改。

不良习惯:过长的方法(完成很多件事情)

  清单 3 展示了一个很长的函数,其中存在很多问题。它完成很多件事情,因此不够紧凑。它也不便于阅读、调试和测试。它要做的事情包括遍历一个文件、构建一个列表、为每个对象赋值、执行计算等等。


清单 3. 不良习惯:过长的函数

<BR><?php<br><br>function writeRssFeed($user)<BR>{<BR>// Get the DB connection information<br><br><BR>// look up the user's preferences...<BR>$link = mysql_connect('mysql_host', 'mysql_user', 'mysql_password')<BR>OR die(mysql_error());<br><br>// Query<BR>$perfsQuery = sprintf("SELECT max_stories FROM user_perfs WHERE user= '%s'",<BR>mysql_real_escape_string($user));<br><br>$result = mysql_query($query, $link);<br><br>$max_stories = 25; // default it to 25;<br><br>if ($row = mysql_fetch_assoc($result)) {<BR>$max_stories = $row['max_stories'];<BR>}<br><br>// go get my data<BR>$perfsQuery = sprintf("SELECT * FROM stories WHERE post_date = '%s'",<BR>mysql_real_escape_string());<br><br>$result = mysql_query($query, $link);<br><br><BR>$feed = "<rss version=\"2.0\">" .<BR>"<channel>" .<BR>"<title>My Great Feed</title>" .<BR>"<link>http://www.example.com/feed.xml</link>" .<BR>"<description>The best feed in the world</description>" .<BR>"<language>en-us</language>" .<BR>"<pubDate>Tue, 20 Oct 2008 10:00:00 GMT</pubDate>" .<BR>"<lastBuildDate>Tue, 20 Oct 2008 10:00:00 GMT</lastBuildDate>" .<BR>"<docs>http://www.example.com/rss</docs>" .<BR>"<generator>MyFeed Generator</generator>" .<BR>"<managingEditor>editor@example.com</managingEditor>" .<BR>"<webMaster>webmaster@example.com</webMaster>" .<BR>"<ttl>5</ttl>";<br><br>// build the feed...<BR>while ($row = mysql_fetch_assoc($result)) {<BR>$title = $row['title'];<BR>$link = $row['link'];<BR>$description = $row['description'];<BR>$date = $row['date'];<BR>$guid = $row['guid'];<br><br>$feed .= "<item>";<BR>$feed .= "<title>" . $title . "</title>";<BR>$feed .= "<link>" . $link . "</link>";<BR>$feed .= "<description> " . $description . "</description>";<BR>$feed .= "<pubDate>" . $date . "</pubDate>";<BR>$feed .= "<guid>" . $guid . "</guid>";<BR>$feed .= "</item>";<BR>}<br><br>$feed .= "</rss";<br><br>// write the feed out to the <SPAN style="TEXT-DECORATION: underline"><STRONG><SPAN style="COLOR: #07519a">server</SPAN></STRONG></SPAN>...<BR>echo($feed);<br><br>}<br><br>?><BR>

  如果多编写几个这样的方法,维护就成了真正的难题了。

良好习惯:易管理、功能专一的方法

  清单 4 将原来的方法改写为更加紧凑、易读的方法。在这个示例中,将一个很长的方法分解为几个短方法,并且让每个短方法负责一件事情。这样的代码对将来的重用和测试都是大有裨益的。


清单 4. 良好习惯:易管理、功能专一的方法

<BR><?php<br><br>function createRssHeader()<BR>{<BR>return "<rss version=\"2.0\">" .<BR>"<channel>" .<BR>"<title>My Great Feed</title>" .<BR>"<link>http://www.example.com/feed.xml</link>" .<BR>"<description>The best feed in the world</description>" .<BR>"<language>en-us</language>" .<BR>"<pubDate>Tue, 20 Oct 2008 10:00:00 GMT</pubDate>" .<BR>"<lastBuildDate>Tue, 20 Oct 2008 10:00:00 GMT</lastBuildDate>" .<BR>"<docs>http://www.example.com/rss</docs>" .<BR>"<generator>MyFeed Generator</generator>" .<BR>"<managingEditor>editor@example.com</managingEditor>" .<BR>"<webMaster>webmaster@example.com</webMaster>" .<BR>"<ttl>5</ttl>";<BR>}<br><br>function createRssFooter()<BR>{<BR>return "</channel></rss>";<BR>}<br><br>function createRssItem($title, $link, $desc, $date, $guid)<BR>{<BR>$item .= "<item>";<BR>$item .= "<title>" . $title . "</title>";<BR>$item .= "<link>" . $link . "</link>";<BR>$item .= "<description> " . $description . "</description>";<BR>$item .= "<pubDate>" . $date . "</pubDate>";<BR>$item .= "<guid>" . $guid . "</guid>";<BR>$item .= "</item>";<BR>return $item;<BR>}<br><br>function getUserMaxStories($db_link, $default)<BR>{<BR>$perfsQuery = sprintf("SELECT max_stories FROM user_perfs WHERE user= '%s'",<BR>mysql_real_escape_string($user));<br><br>$result = mysql_query($perfsQuery, $db_link);<br><br>$max_stories = $default;<br><br>if ($row = mysql_fetch_assoc($result)) {<BR>$max_stories = $row['max_stories'];<BR>}<br><br>return $max_stories;<BR>}<br><br>function writeRssFeed($user)<BR>{<BR>// Get the DB connection information<BR>$settings = parse_ini_file("rss_server.ini");<br><br>// look up the user's preferences...<BR>$link = mysql_connect($settings['db_host'], $settings['user'],<BR>$settings['password']) OR die(mysql_error());<br><br>$max_stories = getUserMaxStories($link, 25);<br><br>// go get my data<BR>$newsQuery = sprintf("SELECT * FROM stories WHERE post_date = '%s'",<BR>mysql_real_escape_string(time()));<br><br>$result = mysql_query($newsQuery, $link);<br><br>$feed = createRssHeader();<br><br>$i = 0;<BR>// build the feed...<BR>while ($row = mysql_fetch_assoc($result)) {<BR>if ($i < $max_stories) {<BR>$title = $row['title'];<BR>$link = $row['link'];<BR>$description = $row['description'];<BR>$date = $row['date'];<BR>$guid = $row['guid'];<br><br>$feed .= createRssItem($title, $link, $description, $date, $guid);<br><br>$i++;<BR>} else {<BR>break;<BR>}<BR>}<br><br>mysql_close($link);<br><br>$feed .= createRssFooter();<br><br>// write the feed out to the server...<BR>echo($feed);<BR>}<BR>?><BR>

 

  将长方法拆分为短方法也是有限制的,过度拆分将适得其反。因此,不要滥用这个良好的习惯。将代码分成大量的片段就像没有拆分长代码一样,都会造成阅读困难。

 

为代码添加注释

  要为代码添加良好的注释有时似乎和编写代码一样难。要了解应该为哪些内容添加注释并不容易,因为我们常常倾向于注释代码当前做的事情。注释代码的目的是不错的主意。在函数的不是很明显的头部代码块中,告诉读者方法的输入和输出,以及方法的最初目标。

  注释代码当前做什么是很常见的,但这是不必要的。如果代码很复杂,不得不注释它当前在做什么,这将暗示您应该重写代码,让它更容易理解。学会使用良好的名称和更短的方法,在不提供注释说明其用途的情况下提高代码的可读性。

不良习惯:函数注释过多或不足

  清单 5 中的注释仅告诉读者代码在做什么 — 它正在通过一个循环进行迭代或添加一个数字。但它忽略了它为什么做当前的工作。这使维护该代码的人员不知道是否可以安全地更改代码(不引入新缺陷)。


清单 5. 不良习惯:函数注释过多或不足

<BR><?php<br><br>class ResultMessage<BR>{<BR>private $severity;<BR>private $message;<br><br>public function __construct($sev, $msg)<BR>{<BR>$this->severity = $sev;<BR>$this->message = $msg;<BR>}<br><br>public function getSeverity()<BR>{<BR>return $this->severity;<BR>}<br><br>public function setSeverity($severity)<BR>{<BR>$this->severity = $severity;<BR>}<br><br>public function getMessage()<BR>{<BR>return $this->message;<BR>}<br><br>public function setMessage($msg)<BR>{<BR>$this->message = $msg;<BR>}<BR>}<br><br>function cntMsgs($messages)<BR>{<BR>$n = 0;<BR>/* iterate through the messages... */<BR>foreach($messages as $m) {<BR>if ($m->getSeverity() == 'Error') {<BR>$n++; // add one to the result;<BR>}<BR>}<BR>return $n;<BR>}<br><br>$messages = array(new ResultMessage("Error", "This is an error!"),<BR>new ResultMessage("Warning", "This is a warning!"),<BR>new ResultMessage("Error", "This is another error!"));<br><br>$errs = cntMsgs($messages);<br><br>echo("There are " . $errs . " errors in the result.\n");<br><br>?><BR>

良好习惯:带注释的函数和类

  清单 6 中的注释告诉读者类和方法的目的。该注释解释了为什么代码在做当前的工作,这对未来维护代码十分有用。可能需要根据条件变更而修改代码,如果能够轻松了解代码的目的,则修改起来很容易。


清单 6. 良好习惯:带注释的函数和类

<BR><?php<BR>/**<BR>* The ResultMessage class holds a message that can be returned<BR>* as a result of a process. The message has a severity and<BR>* message.<BR>*<BR>* @author nagood<BR>*<BR>*/<BR>class ResultMessage<BR>{<BR>private $severity;<BR>private $message;<br><br>/**<BR>* Constructor for the ResultMessage that allows you to assign<BR>* severity and message.<BR>* @param $sev See {@link getSeverity()}<BR>* @param $msg<BR>* @return unknown_type<BR>*/<BR>public function __construct($sev, $msg)<BR>{<BR>$this->severity = $sev;<BR>$this->message = $msg;<BR>}<br><br>/**<BR>* Returns the severity of the message. Should be one<BR>* "Information", "Warning", or "Error".<BR>* @return string Message severity<BR>*/<BR>public function getSeverity()<BR>{<BR>return $this->severity;<BR>}<br><br>/**<BR>* Sets the severity of the message<BR>* @param $severity<BR>* @return void<BR>*/<BR>public function setSeverity($severity)<BR>{<BR>$this->severity = $severity;<BR>}<br><br>public function getMessage()<BR>{<BR>return $this->message;<BR>}<br><br>public function setMessage($msg)<BR>{<BR>$this->message = $msg;<BR>}<BR>}<br><br><BR>/*<BR>* Counts the messages with the given severity in the array<BR>* of messages.<BR>*<BR>* @param $messages An array of ResultMessage<BR>* @return int Count of messages with a severity of "Error"<BR>*/<BR>function countErrors($messages)<BR>{<BR>$matchingCount = 0;<BR>foreach($messages as $m) {<BR>if ($m->getSeverity() == "Error") {<BR>$matchingCount++;<BR>}<BR>}<BR>return $matchingCount;<BR>}<br><br>$messages = array(new ResultMessage("Error", "This is an error!"),<BR>new ResultMessage("Warning", "This is a warning!"),<BR>new ResultMessage("Error", "This is another error!"));<br><br>$errs = countErrors($messages);<br><br>echo("There are " . $errs . " errors in the result.\n");<br><br>?><BR>

 

处理错误

 根据大众的经验,如果要编写健壮的应用程序,错误处理要遵循 80/20 规则:80% 的代码用于处理异常和验证,20% 的代码用于完成实际工作。在编写程序的基本逻辑(happy-path)代码时经常这样做。这意味着编写适用于基本条件的代码,即所有的数据都是可用的,所有的条件符合预期。这样的代码在应用程序的生命周期中可能很脆弱。另一个极端是,甚至需要花大量时间为从未遇到过的条件编写代码。

  这一习惯要求您编写足够的错误处理代码,而不是编写对付所有错误的代码,以致代码迟迟不能完成。

不良习惯:根本没有错误处理代码

  清单 7 中的代码演示了两个不良习惯。第一,没有检查输入的参数,即使知道处于某些状态的参数会造成方法出现异常。第二,代码调用一个可能抛出异常的方法,但没有处理该异常。当发生问题时,代码的作者或维护该代码的人员只能猜测问题的根源。


清单 7. 不良习惯:不处理错误条件

<BR><?php<br><br>// Get the actual name of the<BR>function convertDayOfWeekToName($day)<BR>{<BR>$dayNames = array(<BR>"Sunday",<BR>"Monday",<BR>"Tuesday",<BR>"Wednesday",<BR>"Thursday",<BR>"Friday",<BR>"Saturday");<BR>return $dayNames[$day];<BR>}<br><br>echo("The name of the 0 day is: " . convertDayOfWeekToName(0) . "\n");<BR>echo("The name of the 10 day is: " . convertDayOfWeekToName(10) . "\n");<BR>echo("The name of the 'orange' day is: " . convertDayOfWeekToName('orange') . "\n");<br><br>?><BR>

 

良好习惯:处理异常

  清单 8 展示了以有意义的方式抛出和处理异常。额外的错误处理不仅使代码更加健壮,它还提高代码的可读性,使代码更容易理解。处理异常的方式很好地说明了原作者在编写方法时的意图。


清单 8. 良好习惯:处理异常

<BR><?php<br><br>/**<BR>* This is the exception thrown if the day of the week is invalid.<BR>* @author nagood<BR>*<BR>*/<BR>class InvalidDayOfWeekException extends Exception { }<br><br>class InvalidDayFormatException extends Exception { }<br><br>/**<BR>* Gets the name of the day given the day in the week. Will<BR>* return an error if the value supplied is out of range.<BR>*<BR>* @param $day<BR>* @return unknown_type<BR>*/<BR>function convertDayOfWeekToName($day)<BR>{<BR>if (! is_numeric($day)) {<BR>throw new InvalidDayFormatException('The value \'' . $day . '\' is an ' .<BR>'invalid format for a day of week.');<BR>}<br><br>if (($day > 6) || ($day < 0)) {<BR>throw new InvalidDayOfWeekException('The day number \'' . $day . '\' is an ' .<BR>'invalid day of the week. Expecting 0-6.');<BR>}<br><br>$dayNames = array(<BR>"Sunday",<BR>"Monday",<BR>"Tuesday",<BR>"Wednesday",<BR>"Thursday",<BR>"Friday",<BR>"Saturday");<BR>return $dayNames[$day];<BR>}<br><br>echo("The name of the 0 day is: " . convertDayOfWeekToName(0) . "\n");<br><br>try {<BR>echo("The name of the 10 day is: " . convertDayOfWeekToName(10) . "\n");<BR>} catch (InvalidDayOfWeekException $e) {<BR>echo ("Encountered error while trying to convert value: " . $e->getMessage() . "\n");<BR>}<br><br>try {<BR>echo("The name of the 'orange' day is: " . convertDayOfWeekToName('orange') . "\n");<BR>} catch (InvalidDayFormatException $e) {<BR>echo ("Encountered error while trying to convert value: " . $e->getMessage() . "\n");<BR>}<br><br>?><BR>

 

虽然检查参数是一种确认 — 如果您要求参数处于某种状态,这将对使用方法的人很有帮助 — 但是您应该检查它们并抛出有意义的异常:

  • 处理异常要尽量与出现的问题紧密相关。
  • 专门处理每个异常。

 

切忌使用复制粘贴

  您可以从其他地方将代码复制粘贴到自己的代码编辑器,但这样做有利也有弊。好的一面是,从一个示例或模板中复制代码能够避免很多错误。不好的一面是,这容易带来大量的类似编程方式。

  一定要注意,不要将代码从应用程序的一部分复制粘贴到另一部分。如果您采用这种方式,请停止这个不良的习惯,然后考虑将这段代码重写为可重用的。一般而言,将代码放置到一个地方便于日后的维护,因为这样只需在一个地方更改代码。

不良习惯:类似的代码段

  清单 9 给出了几个几乎一样的方法,只是其中的值不同而已。有一些工具可以帮助找到复制粘贴过来的代码(参见参考资料)。


清单 9. 不良习惯:类似的代码段

<BR><?php<BR>/**<BR>* Counts the number of messages found in the array of<BR>* ResultMessage with the getSeverity() value of "Error"<BR>*<BR>* @param $messages An array of ResultMessage<BR>* @return unknown_type<BR>*/<BR>function countErrors($messages)<BR>{<BR>$matchingCount = 0;<BR>foreach($messages as $m) {<BR>if ($m->getSeverity() == "Error") {<BR>$matchingCount++;<BR>}<BR>}<BR>return $matchingCount;<BR>}<br><br>/**<BR>* Counts the number of messages found in the array of<BR>* ResultMessage with the getSeverity() value of "Warning"<BR>*<BR>* @param $messages An array of ResultMessage<BR>* @return unknown_type<BR>*/<BR>function countWarnings($messages)<BR>{<BR>$matchingCount = 0;<BR>foreach($messages as $m) {<BR>if ($m->getSeverity() == "Warning") {<BR>$matchingCount++;<BR>}<BR>}<BR>return $matchingCount;<BR>}<br><br>/**<BR>* Counts the number of messages found in the array of<BR>* ResultMessage with the getSeverity() value of "Information"<BR>*<BR>* @param $messages An array of ResultMessage<BR>* @return unknown_type<BR>*/<BR>function countInformation($messages)<BR>{<BR>$matchingCount = 0;<BR>foreach($messages as $m) {<BR>if ($m->getSeverity() == "Information") {<BR>$matchingCount++;<BR>}<BR>}<BR>return $matchingCount;<BR>}<br><br>$messages = array(new ResultMessage("Error", "This is an error!"),<BR>new ResultMessage("Warning", "This is a warning!"),<BR>new ResultMessage("Error", "This is another error!"));<br><br>$errs = countErrors($messages);<br><br>echo("There are " . $errs . " errors in the result.\n");<BR>?><BR>

 

良好习惯:带参数的可重用函数

  清单 10 展示了修改后的代码,它将复制的代码放到一个方法中。另一个方法也进行了更改,它现在将任务委托给新的方法。构建通用的方法需要花时间设计,并且这样做使您能停下来思考,而不是本能地使用复制粘贴。但有必要进行更改时,对通用的方法投入的时间将得到回报。


清单 10. 良好习惯:带参数的可重用函数

<BR><?php<BR>/*<BR>* Counts the messages with the given severity in the array<BR>* of messages.<BR>*<BR>* @param $messages An array of ResultMessage<BR>* @return int Count of messages matching $withSeverity<BR>*/<BR>function countMessages($messages, $withSeverity)<BR>{<BR>$matchingCount = 0;<BR>foreach($messages as $m) {<BR>if ($m->getSeverity() == $withSeverity) {<BR>$matchingCount++;<BR>}<BR>}<BR>return $matchingCount;<BR>}<br><br>/**<BR>* Counts the number of messages found in the array of<BR>* ResultMessage with the getSeverity() value of "Error"<BR>*<BR>* @param $messages An array of ResultMessage<BR>* @return unknown_type<BR>*/<BR>function countErrors($messages)<BR>{<BR>return countMessages($messages, "Errors");<BR>}<br><br>/**<BR>* Counts the number of messages found in the array of<BR>* ResultMessage with the getSeverity() value of "Warning"<BR>*<BR>* @param $messages An array of ResultMessage<BR>* @return unknown_type<BR>*/<BR>function countWarnings($messages)<BR>{<BR>return countMessages($messages, "Warning");<BR>}<br><br>/**<BR>* Counts the number of messages found in the array of<BR>* ResultMessage with the getSeverity() value of "Warning"<BR>*<BR>* @param $messages An array of ResultMessage<BR>* @return unknown_type<BR>*/<BR>function countInformation($messages)<BR>{<BR>return countMessages($messages, "Information");<BR>}<br><br>$messages = array(new ResultMessage("Error", "This is an error!"),<BR>new ResultMessage("Warning", "This is a warning!"),<BR>new ResultMessage("Error", "This is another error!"));<br><br>$errs = countErrors($messages);<br><br>echo("There are " . $errs . " errors in the result.\n");<br><br>?><BR>

 

结束语

  如果您在编写 PHP 代码的过程中养成本文讨论的良好习惯,您将能够构建易读、易理解、易维护的代码。使用这种方式构建的易维护代码将降低调试、修复和扩展代码所面临的风险。

  使用良好的名称和更短的方法能够提高代码的可读性。注释代码的目的有利于代码理解和扩展。适当地处理错误会使代码更加健壮。最后,停止使用复制粘贴,保持代码干净,提高可重用性。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/319782.htmlTechArticle根据具体的情况,一般的开发人员往往比优秀的开发人员的效率低 10%~20%。优秀的开发人员的效率更高,因为他们拥有丰富的经验和良好的...
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
세션 고정 공격을 어떻게 방지 할 수 있습니까?세션 고정 공격을 어떻게 방지 할 수 있습니까?Apr 28, 2025 am 12:25 AM

세션 고정 공격을 방지하는 효과적인 방법은 다음과 같습니다. 1. 사용자 로그인 한 후 세션 ID 재생; 2. 보안 세션 ID 생성 알고리즘을 사용하십시오. 3. 세션 시간 초과 메커니즘을 구현하십시오. 4. HTTPS를 사용한 세션 데이터를 암호화합니다. 이러한 조치는 세션 고정 공격에 직면 할 때 응용 프로그램이 파괴 할 수 없도록 할 수 있습니다.

세션리스 인증을 어떻게 구현합니까?세션리스 인증을 어떻게 구현합니까?Apr 28, 2025 am 12:24 AM

서버 측 세션 스토리지가없는 토큰에 저장되는 토큰 기반 인증 시스템 인 JSONWEBTOKENS (JWT)를 사용하여 세션없는 인증 구현을 수행 할 수 있습니다. 1) JWT를 사용하여 토큰을 생성하고 검증하십시오. 2) HTTPS가 토큰이 가로 채지 못하도록하는 데 사용되도록, 3) 클라이언트 측의 토큰을 안전하게 저장, 4) 변조 방지를 방지하기 위해 서버 측의 토큰을 확인하기 위해 단기 접근 메커니즘 및 장기 상쾌한 토큰을 구현하십시오.

PHP 세션과 관련된 일반적인 보안 위험은 무엇입니까?PHP 세션과 관련된 일반적인 보안 위험은 무엇입니까?Apr 28, 2025 am 12:24 AM

PHP 세션의 보안 위험에는 주로 세션 납치, 세션 고정, 세션 예측 및 세션 중독이 포함됩니다. 1. HTTPS를 사용하고 쿠키를 보호하여 세션 납치를 방지 할 수 있습니다. 2. 사용자가 로그인하기 전에 세션 ID를 재생하여 세션 고정을 피할 수 있습니다. 3. 세션 예측은 세션 ID의 무작위성과 예측 불가능 성을 보장해야합니다. 4. 세션 중독 데이터를 확인하고 필터링하여 세션 중독을 방지 할 수 있습니다.

PHP 세션을 어떻게 파괴합니까?PHP 세션을 어떻게 파괴합니까?Apr 28, 2025 am 12:16 AM

PHP 세션을 파괴하려면 먼저 세션을 시작한 다음 데이터를 지우고 세션 파일을 파괴해야합니다. 1. 세션을 시작하려면 세션 _start ()를 사용하십시오. 2. Session_Unset ()을 사용하여 세션 데이터를 지우십시오. 3. 마지막으로 Session_Destroy ()를 사용하여 세션 파일을 파괴하여 데이터 보안 및 리소스 릴리스를 보장하십시오.

PHP의 기본 세션 저장 경로를 어떻게 변경할 수 있습니까?PHP의 기본 세션 저장 경로를 어떻게 변경할 수 있습니까?Apr 28, 2025 am 12:12 AM

PHP의 기본 세션 저장 경로를 변경하는 방법은 무엇입니까? 다음 단계를 통해 달성 할 수 있습니다. session_save_path를 사용하십시오 ( '/var/www/sessions'); session_start (); PHP 스크립트에서 세션 저장 경로를 설정합니다. php.ini 파일에서 세션을 설정하여 세션 저장 경로를 전 세계적으로 변경하려면 세션을 설정하십시오. memcached 또는 redis를 사용하여 ini_set ( 'session.save_handler', 'memcached')과 같은 세션 데이터를 저장합니다. ini_set (

PHP 세션에 저장된 데이터를 어떻게 수정합니까?PHP 세션에 저장된 데이터를 어떻게 수정합니까?Apr 27, 2025 am 12:23 AM

tomodifyDatainAphPessess, startSessionstession_start (), 그런 다음 $ _sessionToset, modify, orremovevariables.

PHP 세션에 배열을 저장하는 예를 제시하십시오.PHP 세션에 배열을 저장하는 예를 제시하십시오.Apr 27, 2025 am 12:20 AM

배열은 PHP 세션에 저장할 수 있습니다. 1. 세션을 시작하고 session_start ()를 사용하십시오. 2. 배열을 만들고 $ _session에 저장하십시오. 3. $ _session을 통해 배열을 검색하십시오. 4. 세션 데이터를 최적화하여 성능을 향상시킵니다.

Garbage Collection은 PHP 세션에 어떻게 효과가 있습니까?Garbage Collection은 PHP 세션에 어떻게 효과가 있습니까?Apr 27, 2025 am 12:19 AM

PHP 세션 쓰레기 수집은 만료 된 세션 데이터를 정리하기위한 확률 메커니즘을 통해 트리거됩니다. 1) 구성 파일에서 트리거 확률 및 세션 수명주기를 설정합니다. 2) CRON 작업을 사용하여 고재 응용 프로그램을 최적화 할 수 있습니다. 3) 데이터 손실을 피하기 위해 쓰레기 수집 빈도 및 성능의 균형을 맞춰야합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음