折騰了好久的macos+apache+php+phpmyadmin 終於成功了!


剛開始才接觸php才發現macos還是比較強大了,macbook不僅是時尚達品還很實用哦。

--------------他山之石--------------------------

http://dancewithnet.com/2010/05/09/run-apache-php-mysql-in-mac-os-x/#php

啟動Apache

有兩種方法:

  1. 打開“系統設置偏好(System Preferences)” -> “共享(Sharing)” -> “Web共享(Web Sharing)”。注意,從Mac OS X從10.8開始取消了 “Web共享(Web Sharing)”。
  2. 打開“終端(terminal)”,然后(注意,sudo需要的密碼就是系統的root帳號密碼)
    1. 運行“sudo apachectl start”,再輸入帳號密碼,這樣Apache就運行了。
    2. 運行“sudo apachectl -v”,你會看到Mac OS X的Apache版本信息,如10.8.1中:
      Server version: Apache/2.2.22 (Unix)
      Server built:   Jun 20 2012 13:57:09
      

如此在瀏覽器中輸入“http://localhost”,就可以看到一個內容為“It works!”的頁面,其位於“/Library(資源庫)/WebServer/Documents/”下,這就是Apache的默認根目錄。

運行PHP

  1. 在終端中運行“sudo vi /etc/apache2/httpd.conf”,打開Apache的配置文件。(如果不習慣操作終端和vi,可以設置在Finder中顯示所有系統隱藏文件,記得設置完畢后需要重啟Finder,然后就可以找到對應文件,隨心所欲編輯了,需要注意的是某些文件的修改還是需要開啟root帳號,但整體上還是在終端上使用sudo來臨時獲取root權限比較安全。)
  2. 找到“#LoadModule php5_module libexec/apache2/libphp5.so”,把前面的#號去掉,保存(在命令行輸入:w)並退出vi(在命令行輸入:q)。
  3. 運行“sudo cp /etc/php.ini.default /etc/php.ini”,這樣就可以運行sudo vi /etc/php.ini來編輯php.ini配置各種功能了。比如:
    ;通過下面兩項來調整PHP提交文件的最大值,如phpMyAdmin中導入數據的最大值
    upload_max_filesize = 2M
    post_max_size = 8M
    ;通過display_errors來控制是否顯示PHP程序的報錯信息,這在調試PHP程序時非常有用
    display_errors = Off
    
  4. 運行“sudo apachectl restart”,重啟Apache,這樣PHP就可以用了。
  5. 運行“sudo cp /Library/WebServer/Documents/index.html.en /Library/WebServer/Documents/info.php”,即在Apache的根目錄下復制index.html.en文件並重命名為info.php。
  6. 在終端中運行“sudo vi /Library/WebServer/Document/info.php”,這樣就可以在vi中編輯info.php文件了。在“It’s works!”后面加上“<?php phpinfo(); ?>”,然后保存之。如此就可以在http://localhost/info.php中看到有關PHP的信息,比如10.8中內置PHP版本號是5.3.13。
  7. 對於不熟悉vi這種編輯器的人來說,實在是太惱火了。我決定下個eclipse。vi有兩種模式,命令模式和文本編輯模式。esc鍵就是回到命令模式,冒號:i就是插入模式。可以改寫文檔。:w就是保存,:q退出。

安裝MySQL

Mac OS X沒有內置MySQL,所以需要自己手動安裝,目前MySQL的最穩定版本是5.5。MySQL提供了Mac OS X下的安裝說明。

  1. 下載MySQL 5.5。選擇合適版本,如這里選擇了mysql-5.5.27-osx10.6-x86_64.dmg。
  2. 運行dmg,會發現里面有4個文件。首先點擊安裝mysql-5.5.27-osx10.6-x86_64.pkg,這是MySQL主安裝包。一般情況下,安裝文件會自動把MySQL安裝到/usr/local下的同名文件夾下。如運行“mysql-5.5.27-osx10.6-x86_64.dmg”會把MySQL安裝到“/usr/local/mysql-5.5.27-osx10.6-x86_64” 中,一路默認安裝完畢。(注意,從10.8開始Mac OS X的權限更加嚴格,直接點擊會提示“mysql-5.5.27-osx10.6-x86_64.pkg can’t be opened because it is from an unidentified developer. Your security preferences allow installation of only apps from the Mac App Store and identified developers.”阻止了安裝,你可以使用雙指單擊該安裝文件,在彈出菜單中選擇“用…打開(open with)”,再選擇“安裝(Installer)”就可以接着安裝了。)
  3. 安裝第2個文件MySQLStartupItem.pkg,MySQL就會自動在開機時啟動了。(注意,10.8的安裝方法同上。)
  4. 安裝第3個文件MySQL.prefPane,就會在“系統設置偏好”中看到“MySQL”的ICON,通過它就可以控制MySQL是否開啟,以 及開機時是否自動運行。到這里MySQL就基本安裝完畢了。(注意,10.8中用雙指單擊該安裝文件,在彈出的菜單中選擇“用…打開(open with)”,然后選擇“系統偏好(System Perference)”就可以接着安裝了。)
  5. 通過運行“sudo vi /etc/bashrc”,在bash配置文件中加入mysqlstartmysqlmysqladmin的別名(注意:修改完畢之后需要退出“終端(Terminal)”之后重新進入,這些命令才會生效):
    #mysql
    alias mysqlstart='sudo /Library/StartupItems/MySQLCOM/MySQLCOM restart'
    alias mysql='/usr/local/mysql/bin/mysql'
    alias mysqladmin='/usr/local/mysql/bin/mysqladmin'
    

    這樣就可以在終端中比較簡單地通過命令進行相應的操作。由於開始安裝MySQLStartupItem.pkg到“/Library/StartupItems/MySQLCOM/”來控制MySQL的運行、自動運行、停止、關閉之類。在MySQL沒有啟動時,直接運行mysqlmysqladmin命令會提示“Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)”,所以我們可以通過控制面板或者直接運行mysqlstart命令來啟動MySQL,之后再運行mysqlmysqladmin命令就正常了。比如安裝完畢后MySQL的root默認密碼為空,如果要設置密碼可以在終端運行“mysqladmin -u root password "mysqlpassword"”來設置,其中mysqlpassword即root的密碼。更多相關內容可以參考B.5.4.1. How to Reset the Root Password。

注意:Mac OS X的升級或其他原因可能會導致MySQL啟動或開機自動運行時,在MySQL操作面板上會提示“Warning:The /usr/local/mysql/data directory is not owned by the 'mysql' or '_mysql' ”,這應該是某種情況下導致/usr/local/mysql/data的宿主發生了改變,只需要運行“sudo chown -R mysql /usr/local/mysql/data”即可。

另外,使用PHP連接MySQL可能會報錯“Can’t connect to local MySQL server through socket ‘/var/mysql/mysql.sock’”,或使用localhost無法連接MySQL而需要127.0.0.1,原因是連接時php默認去找/var/mysql/mysql.sock了,但MAC版的MYSQL改動了文件位置,放在/tmp下了。處理辦法是按如下修改php.ini:

mysql.default_socket = /tmp/mysql.sock

使用phpMyAdmin

phpMyAdmin是用PHP開發的管理MySQL的程序,非常的流行和實用。能夠使用phpMyAdmin管理MySQL是檢驗前面幾步效果的非常有效方式。

  1. 下載phpMyAdmin。選擇合適的版本,比如這里選擇phpMyAdmin-3.5.22-all-languages.tar.bz2這個版本。
  2. 把“下載(downloads)”中phpMyAdmin-3.5.22-all-languages.tar.bz2文件解壓到“ /Library/WebServer/Documents/”中,並改名為phpmyadmin。
    sudo tar -xf ~/Downloads/phpMyAdmin-3.5.2.2-all-languages.tar.bz2 -C
                 /Library/WebServer/Documents/
    sudo mv /Library/WebServer/Documents/phpMyAdmin-3.5.2.2-all-languages
                /Library/WebServer/Documents/phpmyadmin
    
    
  3. 復制“/Library/WebServer/Documents/phpmyadmin/”中的config.sample.inc.php,並命名為config.inc.php
  4. 編輯config.inc.php,修改如下:
    用於Cookie加密,隨意的長字符串
    $cfg['blowfish_secret'] = 'a8b7c6d';
    
    當phpMyAdmin中出現“#2002 無法登錄 MySQL 服務器(#2002 Cannot log in to the MySQL server)”時, 請把localhost改成127.0.0.1就ok了, 這是因為MySQL守護程序做了IP綁定(bind-address =127.0.0.1)造成的
    $cfg['Servers'][$i]['host'] = 'localhost';
    
    把false改成true,這樣就可以訪問無密碼的MySQL了, 即使MySQL設置了密碼也可以這樣設置,然后登錄phpMyAdmin時輸入密碼
    $cfg['Servers'][$i]['AllowNoPassword'] = false;
    
  5. 這樣就可以通過http://localhost/phpmyadmin訪問phpMyAdmin了。此時會看到一個 提示“無法加載 mcrypt 擴展,請檢查您的 PHP 配置。(The mcrypt extension is missing. Please check your PHP configuration.)”,這會涉及到下一節安裝MCrypt擴展了。
  6. 登錄名:root 密碼: (空)


關於錯誤處理:

解決 .#2002 無法登錄 MySQL 服務器

將config.sample.inc.php復制成config.inc.php

出現這個錯誤,表示沒有連接到數據庫。修改config.inc.php文件,
 
將$cfg['Servers'][$i]['host'] = 'localhost'; 
改為$cfg['Servers'][$i]['host'] = '127.0.0.1';

--------------------------------------------------

或者修改 php.ini : mysql.default_socket = /tmp/mysql.sock

 

#1045 無法登錄 MySQL 服務器Access denied for user ‘root’@'localhost’ (using password: YES)

問題原因:這有可能是由於前面設置mysql密碼沒有成功,所以導致了我們使用設置的mysql root密碼無法登陸服務器。

解決方法:這時可以嘗試使用mysql 默認的root賬號的空密碼登陸數據庫。

如果使用空密碼登陸時又出現:空密碼登錄被禁止 (參見 允許空密碼) 的錯誤。則要修改/phpmyadmin/config.inc.php 文件,找到下面兩行

$cfg['Servers'][$i]['nopassword'] = false;
$cfg['Servers'][$i]['AllowNoPassword'] = false;

將兩個false改為true,同時設置 $cfg['Servers'][$i]['password'] = ''通過這樣設置配置文件后phpmyadmin 就會允許以空密碼方式登錄mysql數據庫了。

若重新以空密碼方式登錄phpmyadmin有時仍無法登陸,請清除cookie或關閉原來的phpmyadmin 登錄窗口,重新使用空密碼登錄。

若這時候仍然顯示空密碼登陸被禁止,試試隨便輸入幾個字符當作密碼看是否能夠登陸成功。

登陸mysql服務器之后盡快將mysql密碼在phpmyadmin中修改過來。




免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM