我们只要求简单的运行它就行了伟德国际1946,大家只须要简单的启航它就行了

咱俩日常性的内需使用局域网搭建 Web
服务器测试环境,如安插局域网有线安装集团应用等,Mac OS X 自带了 Apache
和 PHP 环境,大家只必要简单的启航它就行了。

咱俩寻常性的急需利用局域网搭建 Web
服务器测试环境,如安顿局域网有线安装公司应用等,Mac OS X 自带了 Apache
和 PHP 环境,我们只须要简单的运营它就行了。

启动 Apache

  • 查看 Apache 版本
    开拓终端,输入 httpd -v 可以查看 Apache 版本新闻。

    $ httpd -v
    Server version: Apache/2.4.16 (Unix)
    Server built:   Aug 22 2015 16:51:57
    $ 
    
  • 启动 Apache
    在极限输入 sudo apachectl start 即可运行 Apache。
    开行后,在浏览器中输入 http://127.0.0.1
    http://localhost
    如若看到 It Works! 页面:

    img_01.png

那么 Apache 就启动成功了,站点的根目录为系统级根目录
`/Library/WebServer/Documents`。

启动后,你可以通过编辑 `/etc/apache2/httpd.conf` 文件来修改 Apache
配置。
  • 停止 Apache:sudo apachectl stop

  • 重启 Apache:sudo apachectl restart

启动 Apache

开创用户级根目录

我们也得以创立用户级根目录,更方便管理和操作。

  1. 在用户目录下创办 Sites
    目录,cd; mkdir Sites; touch Sites/.localized,旧的 Mac
    系统中假使该目录已存在,则略过。

  2. cd /etc/apache2/users 检查目录下是不是存在 username.conf
    文件,username 为当前用户名,假使没有则开创三个
    sudo touch username.conf,并修改文件权限
    sudo chmod 644 username.conf

  3. 创办之后,打开 username.conf 文件,sudo vi username.conf
    将下边的安排消息写入文件,username 依旧为如今用户名:

    <Directory "/Users/username/Sites/">
        Options Indexes MultiViews FollowSymLinks
        AllowOverride All
        Order allow,deny
        Allow from all
        Require all granted
    </Directory>
    
  4. 编辑 /etc/apache2/httpd.conf
    文件,找到下列代码,并将日前的笺注符号 # 删除:

    Include /private/etc/apache2/extra/httpd-userdir.conf
    
    LoadModule userdir_module libexec/apache2/mod_userdir.so
    
  5. 编辑 /etc/apache2/extra/httpd-userdir.conf
    文件,找到下列代码,并将前方的注脚符号 # 删除:

    Include /private/etc/apache2/users/*.conf
    
  6. 重启 Apache:sudo apachectl restart

在浏览器中输入
http://127.0.0.1/~username

http://localhost/~username,即可测试用户目录是不是工作。

查看 Apache 版本

启动 PHP

Mac OS X 也默许集成了 PHP 环境,若是测试必要用到 PHP
环境,可以透过陈设手动开启。

  1. 编辑 /etc/apache2/httpd.conf 文件,找到
    LoadModule php5_module libexec/apache2/libphp5.so
    并剔除行前的诠释符号 #
  2. 重启 Apache:sudo apachectl restart
  3. 以后 PHP 应该早就可以干活了,在页面中嵌入 <?php phpinfo(); ?>
    可以查阅 PHP 消息。
  4. 命在终极输入 php --ini 可查看 PHP 配置文件,大家可以将
    /private/etc/php.ini.default 复制一份命名为 /private/etc/php.ini
    并修改配置文件,如,设置 display_errors = On 打开PHP错误呈现。

开辟终端,输入httpd -v可以查看 Apache 版本音信。

安装 MySQL

Mac OS X 没有集成 MySQL,需求协调设置,那些一连补充。

$ httpd -v

开启 HTTPS

假如测试必要 HTTPS 环境,如, iOS 7.1
以上的配备配置有线安装环境就无法不运用 HTTPS,大家可以配备 Apache 开启
HTTPS 服务。

Server version: Apache/2.4.16 (Unix)

创制自签定证书

首先创造一个 ssl 目录用来存放在证书

$ cd /etc/apache2/
$ sudo mkdir ssl
$ cd ssl
  1. 创设主机密钥

    $ sudo ssh-keygen -f local.server.com.key
    Generating public/private rsa key pair.
    Enter passphrase (empty for no passphrase): 
    Enter same passphrase again: 
    Your identification has been saved in local.server.com.key.
    Your public key has been saved in local.server.com.key.pub.
    The key fingerprint is:
    SHA256:bNX90ww2g2GCh38Q/h68JnazkZYtnbkMEb1G5E51QWw root@XuCreamandeiMac.local
    The key's randomart image is:
    +---[RSA 2048]----+
    |         oo.o +o+|
    |        o.o+ B E.|
    |         oo.+ %  |
    |       . ..o.* B.|
    |        S  .= +.+|
    |       .   . X o.|
    |          o & =  |
    |         . = B . |
    |            . o  |
    +----[SHA256]-----+
    $ 
    

    此间会被须求提供二个密码用于主机密钥,可以拔取任何的密码或直接留空。

    也足以行使下边的指令创建密钥:

    $ sudo openssl genrsa -out local.server.com.key 2048
    Generating RSA private key, 2048 bit long modulus
    ....+++
    ....+++
    e is 65537 (0x10001)
    $
    
  2. 创制签署报名

    $ sudo openssl req -new -key local.server.com.key -out local.server.com.csr
    You are about to be asked to enter information that will be incorporated
    into your certificate request.
    What you are about to enter is what is called a Distinguished Name or a DN.
    There are quite a few fields but you can leave some blank
    For some fields there will be a default value,
    If you enter '.', the field will be left blank.
    -----
    Country Name (2 letter code) [AU]:
    State or Province Name (full name) [Some-State]:
    Locality Name (eg, city) []:
    Organization Name (eg, company) [Internet Widgits Pty Ltd]:
    Organizational Unit Name (eg, section) []:
    Common Name (e.g. server FQDN or YOUR name) []:local.server.com
    Email Address []:
    
    Please enter the following 'extra' attributes
    to be sent with your certificate request
    A challenge password []:
    An optional company name []:
    $ 
    

    系统会唤起输入各项消息,由于这是自签定的证件,除了
    Common Name (e.g. server FQDN or YOUR name) []: FQDN( fully
    qualified domain name)必须是劳务器域名或 IP
    外,其余都不根本,可以自由填入或伙同回车,那里当做测试使用
    local.server.com

  3. 创建SSL证书
    在生产条件中,大家必要付出评释申请(CS酷威)文件给证书颁发机构,由证书颁发机构提供SSL证书。

    $ sudo openssl x509 -req -days 365 -in local.server.com.csr -signkey local.server.com.key -out local.server.com.crt
    Signature ok
    subject=/C=AU/ST=Some-State/O=Internet Widgits Pty Ltd/CN=local.server.com
    Getting Private key
    $ 
    

    大家也可以直接通过以下的命令创建证书:

    $ sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout local.server.com.key -out local.server.com.crt
    
  4. 创建NOPASS密钥
    为了布置 Apache,大家须求成立多个 NOPASS 密钥。

    $ sudo openssl rsa -in local.server.com.key -out local.server.com.nopass.key
    

OK,大家看下SSL目录上边的公文,这个文件将在末端被用到:

$ ls -l
-rw-r--r--  1 root  wheel  1180 10 22 13:08 local.server.com.crt
-rw-r--r--  1 root  wheel   993 10 22 11:58 local.server.com.csr
-rw-------  1 root  wheel  1679 10 22 11:44 local.server.com.key
-rw-r--r--  1 root  wheel   408 10 22 11:44 local.server.com.key.pub
-rw-r--r--  1 root  wheel  1679 10 22 13:19 local.server.com.nopass.key

Server built:  Aug 22 2015 16:51:57

配置 SSL

  1. 加载 mod_ssl.so,编辑 /etc/apache2/httpd.conf
    文件,删除下列代码前的笺注符号 #

    LoadModule ssl_module libexec/apache2/mod_ssl.so
    
  2. 包含 httpd-ssl.conf 文件,编辑 /etc/apache2/httpd.conf
    文件,删除下列代码前的诠释符号 #

    Include /private/etc/apache2/extra/httpd-ssl.conf
    
  3. 添加 <VirtualHost>httpd-ssl.conf,编辑
    /etc/apache2/extra/httpd-ssl.conf 文件:
    httpd-ssl.conf 中已经有一条 <VirtualHost>
    记录,大家将其注释掉,新建一条:

    <VirtualHost *:443>
    #General setup for the virtual host
    DocumentRoot "/Library/WebServer/Documents"
    ServerName local.server.com
    
    #SSL Engine Switch:
    SSLEngine on
    
    #Server Certificate:
    SSLCertificateFile "/etc/apache2/ssl/local.server.com.crt"
    
    #Server Private Key:
    SSLCertificateKeyFile "/etc/apache2/ssl/local.server.com.key"
    
    #SSL Engine Options:
    <FilesMatch "\.(cgi|shtml|phtml|php)$">
        SSLOptions +StdEnvVars
    </FilesMatch>
    <Directory "/Library/WebServer/CGI-Executables">
        SSLOptions +StdEnvVars
    </Directory>
    </VirtualHost>
    
  4. 为了可以使用 U奥迪Q7L
    访问服务器,大家须要配置HOST,sudo vi /etc/hosts,添加
    127.0.0.1 local.server.com

  5. 自我批评布置文件相提并论启 Apache
    指令行输入 $ sudo apachectl -t,提示:

    AH00526: Syntax error on line 92 of /private/etc/apache2/extra/httpd-ssl.conf:
    SSLSessionCache: 'shmcb' session cache not supported (known names: ). Maybe you need to load the appropriate socache module (mod_socache_shmcb?).
    

    基于提醒,编辑 /etc/apache2/httpd.conf
    文件,删除下列那些代码前的诠释符号 #

    LoadModule socache_shmcb_module libexec/apache2/mod_socache_shmcb.so
    

    再一次测试,显示 Syntax OK

    $ sudo apachectl -t
    Syntax OK
    

    表明测试通过,重启 Apache:

    $ sudo apachectl restart
    

那儿,就足以采纳 HTTPS 访问当地服务了,在浏览器中输入
https://local.server.com/
检查。

$

启动 Apache

在终极输入sudo apachectl start即可运营 Apache。

起步后,在浏览器中输入http://127.0.0.1http://localhost假使见到It
Works!
页面:

伟德国际1946 1

img_01.png

那么 Apache
就运维成功了,站点的根目录为系统级根目录/Library/WebServer/Documents。

运营后,你可以通过编辑/etc/apache2/httpd.conf文件来修改 Apache 配置。

停止 Apache:sudo apachectl stop

重启 Apache:sudo apachectl restart

开创用户级根目录

咱们也足以创立用户级根目录,更方便管理和操作。

在用户目录下创建Sites目录,cd; mkdir Sites; touch Sites/.localized,旧的
Mac 系统中只要该目录已存在,则略过。

cd
/etc/apache2/users检查目录下是还是不是存在username.conf文件,username为当下用户名,假使没有则开创2个sudo
touch username.conf,并修改文件权限sudo chmod 644 username.conf。

成立之后,打开username.conf文件,sudo vi 
username.conf将上边的配置音讯写入文件,username还是为当前用户名:

Options Indexes MultiViews FollowSymLinks

AllowOverride All

Order allow,deny

Allow from all

Require all granted

编辑/etc/apache2/httpd.conf文件,找到下列代码,并将前方的注明符号#删除:

Include /private/etc/apache2/extra/httpd-userdir.conf

LoadModule userdir_module libexec/apache2/mod_userdir.so

编辑/etc/apache2/extra/httpd-userdir.conf文件,找到下列代码,并将目前的诠释符号#删除:

Include /private/etc/apache2/users/*.conf

重启 Apache:sudo apachectl restart

在浏览器中输入http://127.0.0.1/~usernamehttp://localhost/~username,即可测试用户目录是或不是工作。

启动 PHP

Mac OS X 也暗中同意集成了 PHP 环境,即使测试要求用到 PHP
环境,可以经过配备手动开启。

编辑/etc/apache2/httpd.conf文件,找到LoadModule php5_module
libexec/apache2/libphp5.so并删除行前的笺注符号#。

重启 Apache:sudo apachectl restart。

当今 PHP 应该已经可以干活了,在页面中放到能够查看 PHP 音讯。

命在终极输入php –ini可查看 PHP
配置文件,大家得以将/private/etc/php.ini.default复制一份命名为/private/etc/php.ini并修改配置文件,如,设置display_errors
= On打开PHP错误突显。

安装 MySQL

Mac OS X 没有集成 MySQL,必要协调安装,这么些三番五次补充。

开启 HTTPS

如果测试须求 HTTPS 环境,如, iOS 7.1
以上的装备配备无线安装环境就亟须接纳 HTTPS,大家可以安插 Apache 开启
HTTPS 服务。

始建自签署证书

率先创设二个 ssl 目录用来存放证书

$ cd /etc/apache2/

$ sudo mkdir ssl

$ cd ssl

创办主机密钥

$ sudo ssh-keygen -f local.server.com.key

Generating public/private rsa key pair.

Enter passphrase (empty for no passphrase):

Enter same passphrase again:

Your identification has been saved in local.server.com.key.

Your public key has been saved in local.server.com.key.pub.

The key fingerprint is:

SHA256:bNX90ww2g2GCh38Q/h68JnazkZYtnbkMEb1G5E51QWw
root@XuCreamandeiMac.local

The key’s randomart image is:

+—[RSA 2048]—-+

|        oo.o +o+|

|        o.o+ B E.|

|        oo.+ %  |

|      . ..o.* B.|

|        S  .= +.+|

|      .  . X o.|

|          o & =  |

|        . = B . |

|            . o  |

+—-[SHA256]—–+

$

此间会被须求提供叁个密码用于主机密钥,可以采取任何的密码或直接留空。

也得以应用上边的通令创立密钥:

$ sudo openssl genrsa -out local.server.com.key 2048

Generating RSA private key, 2048 bit long modulus

….+++

….+++

e is 65537 (0x10001)

$

创制签署报名

$ sudo openssl req -new -key local.server.com.key -out
local.server.com.csr

You are about to be asked to enter information that will be incorporated

into your certificate request.

What you are about to enter is what is called a Distinguished Name or a
DN.

There are quite a few fields but you can leave some blank

For some fields there will be a default value,

If you enter ‘.’, the field will be left blank.


Country Name (2 letter code) [AU]:

State or Province Name (full name) [Some-State]:

Locality Name (eg, city) []:

Organization Name (eg, company) [Internet Widgits Pty Ltd]:

Organizational Unit Name (eg, section) []:

Common Name (e.g. server FQDN or YOUR name) []:local.server.com

Email Address []:

Please enter the following ‘extra’ attributes

to be sent with your certificate request

A challenge password []:

An optional company name []:

$

系统会提示输入各项消息,由于这是自签定的评释,除了Common Name (e.g.
server FQDN or YOU帕杰罗 name) []:FQDN( fully qualified domain
name)必须是劳务器域名或 IP
外,其余都不紧要,可以肆意填入或协同回车,那里当做测试使用local.server.com。

创建SSL证书

在生养条件中,我们需要提交注脚申请(CS奥迪Q5)文件给证书颁发机构,由证书颁发机构提供SSL证书。

$ sudo openssl x509 -req -days 365 -in local.server.com.csr -signkey
local.server.com.key -out local.server.com.crt

Signature ok

subject=/C=AU/ST=Some-State/O=Internet Widgits Pty
Ltd/CN=local.server.com

Getting Private key

$

我们也得以直接通过以下的通令制造证书:

$ sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout
local.server.com.key -out local.server.com.crt

创建NOPASS密钥

为了安插 Apache,大家须要创立一个 NOPASS 密钥。

$ sudo openssl rsa -in local.server.com.key -out
local.server.com.nopass.key

OK,大家看下SSL目录上边的文书,那个文件将在前边被用到:

$ ls -l

-rw-r–r–  1 root  wheel  1180 10 22 13:08 local.server.com.crt

-rw-r–r–  1 root  wheel  993 10 22 11:58 local.server.com.csr

-rw——-  1 root  wheel  1679 10 22 11:44 local.server.com.key

-rw-r–r–  1 root  wheel  408 10 22 11:44 local.server.com.key.pub

-rw-r–r–  1 root  wheel  1679 10 22 13:19 local.server.com.nopass.key

配置 SSL

加载mod_ssl.so,编辑/etc/apache2/httpd.conf文件,删除下列代码前的诠释符号#:

LoadModule ssl_module libexec/apache2/mod_ssl.so

含有httpd-ssl.conf文件,编辑/etc/apache2/httpd.conf文件,删除下列代码前的注释符号#:

Include /private/etc/apache2/extra/httpd-ssl.conf

添加到httpd-ssl.conf,编辑/etc/apache2/extra/httpd-ssl.conf文件:

httpd-ssl.conf中一度有一条记下,大家将其注释掉,新建一条:

#General setup for the virtual host

DocumentRoot “/Library/WebServer/Documents”

ServerName local.server.com

#SSL Engine Switch:

SSLEngine on

#Server Certificate:

SSLCertificateFile “/etc/apache2/ssl/local.server.com.crt”

#Server Private Key:

SSLCertificateKeyFile “/etc/apache2/ssl/local.server.com.key”

#SSL Engine Options:

SSLOptions +StdEnvVars

SSLOptions +StdEnvVars

为了可以运用 UWranglerL 访问服务器,大家须求配备HOST,sudo vi
/etc/hosts,添加127.0.0.1      local.server.com

反省安顿文件比量齐观启 Apache

命令行输入$ sudo apachectl -t,提醒:

AH00526: Syntax error on line 92 of
/private/etc/apache2/extra/httpd-ssl.conf:

SSLSessionCache: ‘shmcb’ session cache not supported (known names: ).
Maybe you need to load the appropriate socache module
(mod_socache_shmcb?).

基于提醒,编辑/etc/apache2/httpd.conf文件,删除下列这个代码前的笺注符号#

LoadModule socache_shmcb_module libexec/apache2/mod_socache_shmcb.so

再也测试,突显Syntax OK:

$ sudo apachectl -t

Syntax OK

证实测试通过,重启 Apache:

$ sudo apachectl restart

此刻,就足以利用 HTTPS
访问当地服务了,在浏览器中输入https://local.server.com/检查。

小编:小白不是总

链接:http://www.jianshu.com/p/d006a34a343f

來源:简书

作品权归小编全数。商业转发请联系小编得到授权,非商业转发请申明出处。