本节书摘来自异步社区《php和mysql web开发从新手到高手(第5版)》一书中的第1章,第1.2节,作者【澳】kevin yank,更多章节内容可以访问云栖社区“异步社区”公众号查看
php和mysql web开发从新手到高手(第5版)
在本节中,我们将介绍如何开始在windows xp、windows vista或windows 7操作平台上运行一个安装了php和mysql的web服务器。如果你使用的不是windows操作系统,那么就可以略过本节。
获取web服务器并在windows上运行它的最简单方式,是使用叫作xampp for windows的一个免费软件包。这个安装包程序内置了apache、php、mysql。让我们来看一下它的安装过程。
在本书之前的版本中,我建议你分别安装apache、php和mysql,并且对于每个软件都使用官方的安装包。我认为,对于初学者来说,这是很好的做法,因为这让你能够很好地体会这些软件是如何配合工作的。
遗憾的是,这意味着很多读者最初的几个小时要花在“php落地”上,并且按照详细的安装说明,在一个漫长的过程中跌跌撞撞地前进。更糟糕的是,有时候某一个软件包的一些细小的变化,就意味着这些说明的细节部分变得过时了。
如今,我坚信学习php和mysql的最好的方式是直接开始使用它们。安装的过程越快速越省力就越好。这就是为什么在本书的这个版本中我要求你使用xampp。此外,既然有很多的机会去了解这些软件,那又何必给计算机安装一堆独立且不相关、而又很难删除的软件呢?
尽管如此,如果你是喜欢坚持自己动手的人,或者你是一位技术高手,又或者如果你只是想学完本书并看看专业人士是如何做的,那么,我在附录a中给出了每一个单独软件包的详细安装说明。如果你是上述的某一类读者,建议你按照附录a而不是本节的介绍去做。
1.从apache friends站点下载xampp for windows的最新版本(需要向下滚动以找到下载链接)1。找到推荐的安装版本(在编写本书的时候,xampp for windows 1.7.7的大小为81mb),然后,双击该文件以启动安装程序,如图1.1所示。
根据你所使用的windows版本和具体的系统配置,xampp安装程序可能会显示如图1.2所示的警告信息。
尽管这条消息乍看上去有点令人担心,但是请放心,这没什么大不了的。它只是建议你不要像安装大多数的程序那样,把xampp安装到c:program files,因为那样将会导致文件许可问题的产生。程序默认的安装位置是c:xampp。
2.安装程序将会为你提示指定安装xampp的位置。默认的位置是c:xampp,如图1.3所示。这是一个理想的选择,但如果你很想将它安装到其他的地方(例如,另一个驱动器上),那么继续并指定你喜欢的位置。只要避免安装到通常的c:program files(或类似的)位置就可以了,因为windows会限制访问该文件夹下的文件,而xampp需要得到访问许可。
3.安装程序将提示你设置一些选项。默认的选择如图1.4所示,这可能也是你目前想要的选项。如果你想保持桌面整洁,就不要选中“create a xampp desktop icon”复选框。如果你想要apache和mysql服务器一直运行(而不是在你进行开发的时候还必须手动启动它们),可以选中“install apache as service”和“install mysql as service”复选框。在后续的介绍中,我们将假设你没有选中这两个复选框。
4.一旦完成了安装,安装程序将会提示你启动xampp control panel。单击no,因为我们要向你展示如何以常规的方式启动它。一旦完成了安装,安装程序就会退出。
5.此时,我建议你关闭并重新启动计算机(即便xampp安装程序并不要求这么做)。在我的测试中,如果没有重启系统,下面的步骤将会失效,并且xampp支持论坛上的帖子也支持重启计算机的做法2。
一旦安装完成并且系统重启后,就可以启动xampp control panel了。你可以在start menu下找到all programs > apache friends > xampp > xampp control panel。你的windows系统工具栏上将会出现一个橘黄色的图标(尽管默认情况下它会过几秒之后才出现),并且会打开如图1.5所示的xampp control panel application。
单击modules列表下apache和mysql后面的start按钮,将会启动xampp内建的apache和mysql服务器。一个绿色的状态指示标志将会出现在列表中的每个服务器的后面。
根据你的windows的版本和配置,你可能会接收到针对每个服务器的windows防火墙警告,如图1.6所示。当服务器试图开始监听来自外部的浏览器请求的时候,会发生这种情况。
如果你想要确保只有自己才能够访问开发服务器,那么单击cancel按钮。你仍然可以使用自己的计算机上运行的浏览器来连接到web服务器。然而,在某些情况下,从网络中的另外一台计算机访问服务器可能会更方便(例如,为了展示你所构建的令人惊讶的web站点,通过同事的计算机来访问它)。基于这一目的,我建议你选择“private networks, such as my home or work network”选项,并且单击“allow access”按钮。
如果你的apache或mysql服务器无法启动,原因可能有很多种。最常见的原因是,你的计算机上已经有一个web服务器(它可能是apache或者是microsoft internet information services的另一个副本),或mysql服务器正在运行。
检查一下你的start菜单以及windows control panel的uninstall a program部分,看看是否能够找到apache http server或mysql的另一个安装版本,以便关闭或卸载它。还有另一个和xampp类似的程序,叫作wampserver,如果你安装了它,也将会导致这样的问题产生。
如果你认为自己的系统上可能有microsoft的web服务器(internet information services,iis)在运行,可以尝试按照microsoft的说明来关闭它。
还是不行?xampp for windows faq 中的建议可能会有所帮助,如果你在运行skype的话(因为它可能在某些网络配置下干扰到web服务器),这些建议特别有用。
当你完成了xampp control panel的操作,单击exit按钮来关闭它。此外,你也可以直接关闭窗口,这样做将会在window系统任务栏上保留xampp图标(如果你已经将它配置为保留可见的话)。当你需要的时候,单击该图标将会立即再次启动xampp control panel。
当你退出xampp control panel的时候,apache和mysql服务器还将继续在你的系统上运行。如果你完成了一天的编程,我建议你针对每一个服务器单击stop按钮来关闭它们,然后再退出xampp control panel。运行不必要的服务器,将会导致你晚上玩facebook的游戏都会变慢,这是毫无意义的事情。
在xampp中设置mysql root密码
一旦为自己的windows计算机安装了合适的服务器,就需要在xampp中为mysql设置一个root密码。
mysql只允许授权的用户浏览和操作存储在其数据库中的信息,因此,你需要告知mysql,谁是经过授权的用户而谁不是。当初次安装mysql的时候,它配置了一个名为“root”的用户,该用户能够访问mysql并且执行大多数的任务,而不需要输入密码。因此,你的首要任务应该是为该root用户分配一个密码,以使未经授权的用户无法操作你的数据库。
意识到能够从同一网络中的任何计算机访问mysql(就像一个web服务器一样)是很重要的。如果你在连接到互联网上的一台计算机上工作,那么,根据你所采取的安全性措施,世界上的任何人都可能连接到你的mysql服务器。那么,显然选择一个难以猜测到的密码是很有必要的。
该页面将会列出xampp可以识别的关于你的当前服务器配置的所有安全问题。其中,你应该会看到“the mysql admin user root has no password”。向下滚动表格,并且单击给出的链接以修正所列出的问题。
单击该链接所产生的表单的最前面的部分,将会提示你设置一个mysql root密码。继续并且设置一个你能够记住的密码。将phpmyadmin authentification选项设置为cookie,如果你认为自己可能会忘记密码的话,使用该选项可以将密码保存到一个文件中(但是请注意,使用你的计算机的某个人,也可能找到你保存密码的位置)。单击password changing按钮以更改密码,然后,使用xampp control panel停止并重新启动mysql服务器。
注意,不要忘了这个密码。如果忘记的话,再修改会很麻烦。不过,我将在第10章中介绍如何做到这点。可以在下面记下你的mysql root密码,以备不时之需:
xampp的安全页面还会警告你,网络上的任何人都能够访问web页面。尽管从技术上讲确实如此,但如果同事或家人访问正在开发的web站点时遇到错误,我一点也不担心。此外,大多数家庭或办公室的网络配置都会阻止网络以外的人访问你的计算机上运行的web服务器。
这就是说,如果你想要按照xampp的建议去设置浏览你的web服务器上的页面所必须的用户名和密码的话,那就设置吧。