PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认

2020-01-06 23:34:07

参考地址 PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认

    由于我当前使用的 Mac 电脑的 PHP 版本比较低(7.1.19),许多新特性和功能不支持,现准备将其升级成最新版(7.3.2),具体步骤如下。

1,通过 brew 安装 php

在终端输执行如下命令,不需要指定安装 php 版本,它会自动升级到最新版本,同时 brew 会自动 update

1
brew install php


2,启用新版本的 php

(1)安装后我们在终端执行 php -version 会发现版本还是老的:

原文:PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认


(2)首先我们执行如下命令打开 .bash_profile

1
sudo vim ~/.bash_profile


(3)按下 i 键启用编辑模式,并在末尾增加如下两行内容。

1
2
PATH="$(brew --prefix php)/bin:$PATH"
export PYTHON_ENV=development


(4)然后按下 esc 退出编辑模式。 接着组合按下 shift + : 开启命令,然后输入 wq 回车,保存退出。

(5)最后我们在终端中执行如下命令即可 :

1
source ~/.bash_profile


(6)再次在终端执行 php -version 会发现已经使用更新版本的 php 了:

原文:PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认


3,重新安装 Apache

(1)经过上面操作后,由于我之前使用的是系统自带的 Apache,当创建一个 php 页面输出 phpinfo() 信息会发现,php 版本还是使用老的:

原文:PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认


(2)这是由于系统自带的 Apache 与 Homebrew 一起使用会有问题,因为 Apple 在此版本中删除了一些必需的脚本。首先我们依次执行下面命令关闭内置的 Apache

1
2
sudo apachectl stop
sudo launchctl unload -w /System/Library/LaunchDaemons/org.apache.httpd.plist 2>/dev/null


(3)接着使用 Brew 安装新的 Apache 版本:

1
brew install httpd


(4)执行如下命令启动新 Apache 服务器:

1
sudo brew services start httpd


(5)新 Apache 服务器默认端口是 8080,我们使用浏览器访问 http://localhost:8080 测试下效果:

原文:PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认


(6)接着我们要给 Apache 增加 php 模块支持,在终端中执行如下命令编辑 httpd.conf  文件:

1
sudo vim /usr/local/etc/httpd/httpd.conf


(7)按下 i 键进入编辑模式,增加如下几行配置:

1
2
3
4
LoadModule php7_module /usr/local/opt/php/lib/httpd/modules/libphp7.so
<FilesMatch \.php$>
        SetHandler application/x-httpd-php
</FilesMatch>


(8)接着找到如下节点:

1
2
3
<IfModule dir_module>
    DirectoryIndex index.html
</IfModule>


将其改成如下内容:

1
2
3
<IfModule dir_module>
    DirectoryIndex index.html index.htm index.php
</IfModule>


(9)最后按下 esc 退出编辑模式。 接着组合按下 shift + : 开启命令,然后输入 wq 回车,保存退出。

(10)在 /usr/local/var/www 下放置创建一个 php 页面输出 phpinfo() 信息会发现,已经是使用新版的 php 了:

原文:PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认


4,修改 Apache 网站根目录

    默认网站根目录是 /usr/local/var/www,如果想切换到自定义的目录下,比如:/Users/hanggg/wwwroot。可以通过如下操作来实现。

(1)使用 vim 命令编辑 httpd.conf 文件,找到 DocumentRoot 和 Directory 替换成 /Users/hangge/wwwroot

原文:PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认


(2)保存退出后,执行如下命令重启 Apache 服务器即可。

1
sudo brew services restart httpd


5,修改 Apache 服务器端口

(1)默认服务器端口是 8080,如果想要改成 80。同样是修改 httpd.conf 文件。

原文:PHP - 将macOS系统下的PHP升级成最新版本(7.3),并设为默认

(2)保存退出后,执行如下命令重启 Apache 服务器即可。

1
sudo brew services restart httpd


  • 2019-12-05 17:13:40

    JS模板工具lodash.template的简单用法

    lodash是从underscore分支的一个项目,之前我写了一篇JS模板工具underscore.template的简单用法,lodash跟underscore很相似,这也简单介绍一下lodash的template方法。 先把underscore的文章中用过的代码贴过来,把underscore的js文件换成lodash的js,其他一字不改,然后我们试试:

  • 2019-12-06 10:47:29

    date-fns日期工具的使用方法详解

    isToday() 判断传入日期是否为今天 isYesterday() 判断传入日期是否为昨天 isTomorrow() 判断传入日期是否为 format() 日期格式化 addDays() 获得当前日期之后的日期 addHours() 获得当前时间n小时之后的时间点 addMinutes() 获得当前时间n分钟之后的时间 addMonths() 获得当前月之后n个月的月份 subDays() 获得当前时间之前n天的时间 subHours() 获得当前时间之前n小时的时间 subMinutes() 获得当前时间之前n分钟的时间 subMonths() 获得当前时间之前n个月的时间 differenceInYears() 获得两个时间相差的年份 differenceInWeeks() 获得两个时间相差的周数 differenceInDays() 获得两个时间相差的天数 differenceInHours() 获得两个时间相差的小时数 differenceInMinutes() 获得两个时间相差的分钟数

  • 2019-12-06 10:49:39

    npm 查看源 换源

    npm,cnpm,查看源,切换源,npm config set registry https://registry.npmjs.org

  • 2019-12-06 11:01:31

    npm发布包流程详解 有demo

    npm发布包步骤,以及踩过的坑(见红颜色标准): 1.注册npm账号,并完成Email认证(否则最后一步提交会报Email错误) 2.npm添加用户或登陆:npm adduser 或 npm login

  • 2019-12-06 13:16:18

    vue mixins组件复用的几种方式

    最近在做项目的时候,研究了mixins,此功能有妙处。用的时候有这样一个场景,页面的风格不同,但是执行的方法,和需要的数据非常的相似。我们是否要写两种组件呢?还是保留一个并且然后另个一并兼容另一个呢? 不管以上那种方式都不是很合理,因为组件写成2个,不仅麻烦而且维护麻烦;第二种虽然做了兼容但是页面逻辑造成混乱,必然不清晰;有没有好的方法,有那就是用vue的混合插件mixins。混合在Vue是为了提出相似的数据和功能,使代码易懂,简单、清晰。

  • 2019-12-06 13:26:30

    vue的mixins混入合并规则

    混入minxins:分发vue组件中可复用功能的灵活方式。混入对象可以包含任意组件选项。组件使用混入对象时,所有混入对象的选项将混入该组件本身的选项。

  • 2019-12-06 16:50:34

    Intellij idea 如何关闭无用的提示

    Linux:Settings —> Editor —> Inspections —> General —> Duplicated Code Mac:Preferences --> Editor —> Inspections —> General —> Duplicated Code fragment 将对应的勾去掉。

  • 2019-12-09 15:36:56

    神秘的 shadow-dom 浅析,shadow-root

    顾名思义, shadow-dom,直译的话就是 影子dom ?我觉得可以理解为潜藏在黑暗中的 DOM 结构,也就是我们无法直接控制操纵的 DOM 结构。前端同学经常用开发者工具的话,查看 DOM 结构的时候,肯定看到过下面这样的结构: