0

0

在Apple M1 Pro上为XAMPP安装Phalcon PHP扩展的指南

碧海醫心

碧海醫心

发布时间:2025-09-02 19:31:17

|

558人浏览过

|

来源于php中文网

原创

在Apple M1 Pro上为XAMPP安装Phalcon PHP扩展的指南

本教程旨在解决在Apple M1 Pro芯片设备上为基于x86_64架构的XAMPP环境安装Phalcon PHP扩展时遇到的架构不兼容问题。核心内容是解释ARM64与x86_64架构间的冲突,并提供下载适用于x86_64架构的Phalcon扩展文件,然后手动配置XAMPP PHP环境的详细步骤,确保扩展能正确加载。

1. 理解M1 Mac上的架构挑战

apple m1芯片采用arm64架构,与传统的intel处理器(x86_64架构)截然不同。当我们在m1 mac上运行xampp这类为x86_64架构编译的应用程序时,macos的rosetta 2技术会自动进行转译,使得这些应用能够正常运行。然而,php扩展(如phalcon)作为动态链接库,其架构必须与加载它的php解释器(以及宿主应用xampp)的架构一致。

常见的问题表现为尝试通过包管理器(如MacPorts或Homebrew)安装Phalcon时,这些工具可能会默认编译出ARM64架构的扩展。当XAMPP中运行的x86_64架构PHP尝试加载一个ARM64架构的.so文件时,就会出现以下错误:

PHP Warning: PHP Startup: Unable to load dynamic library '...' (tried: ... (mach-o file, but is an incompatible architecture (have 'arm64', need 'x86_64')), ...) in Unknown on line 0

这个错误明确指出,PHP解释器需要x86_64架构的扩展,但找到的是ARM64架构的扩展,导致加载失败。

2. 常见安装尝试及其问题分析

在M1 Mac上安装Phalcon时,用户通常会尝试以下几种方法,并可能遇到不同的问题:

  • 使用MacPorts安装: MacPorts可能会为M1芯片原生编译ARM64架构的Phalcon扩展。虽然扩展本身编译成功,但由于XAMPP及其内置的PHP通常以x86_64架构通过Rosetta 2运行,导致架构不匹配。
  • 从GitHub源码编译: 直接克隆Phalcon源码并尝试手动编译(cd build && ./install)可能会遇到各种编译错误,这通常与缺少开发依赖、编译环境配置不当或编译器版本不兼容有关。即使编译成功,也需要确保目标架构是x86_64,而非M1的ARM64。
  • 使用Homebrew安装: Homebrew也可能遇到类似MacPorts的架构问题。此外,Phalcon的Homebrew Tap(phalcon/extension)可能存在公式过时或与当前Homebrew版本不兼容的问题,导致“Invalid formula”或“undefined method cellar”等错误。

3. 解决方案:手动安装x86_64架构的Phalcon扩展

鉴于架构不兼容是核心问题,最直接有效的解决方案是获取一个预编译的、适用于x86_64架构的Phalcon扩展文件,并手动将其配置到XAMPP环境中。

立即学习PHP免费学习笔记(深入)”;

3.1 确定XAMPP的PHP版本和扩展目录

首先,需要确认你的XAMPP正在运行的PHP版本,以及其扩展文件的存放路径。

  1. 检查PHP版本: 在终端中运行XAMPP的PHP:
    /Applications/XAMPP/bin/php -v

    通常会显示类似 PHP 7.3.x 的版本信息。Phalcon 3.4版本通常与PHP 7.3兼容。

  2. 查找扩展目录:
    • 在终端运行:
      /Applications/XAMPP/bin/php -i | grep "extension_dir"
    • 或者直接查看XAMPP的php.ini文件(通常位于/Applications/XAMPP/xamppfiles/etc/php.ini),搜索 extension_dir。
    • 常见的扩展目录路径是 /Applications/XAMPP/xamppfiles/lib/php/extensions/no-debug-non-zts-YYYYMMDD/,其中YYYYMMDD是PHP编译时的API版本。

3.2 下载适用于x86_64架构的Phalcon扩展

由于MacPorts提供了预编译的包,我们可以利用其归档来获取正确架构的扩展。

Explainpaper
Explainpaper

阅读学术论文的更好方法,你的学术论文阅读助手。

下载
  1. 访问MacPorts包归档: 前往MacPorts的包归档页面,查找对应PHP版本和Phalcon版本的x86_64架构包。例如,对于PHP 7.3和Phalcon 3.4,可以访问: https://www.php.cn/link/0334bbbe24552d27a5c4c2dcc41570c3
  2. 下载x86_64版本: 在该页面中找到与你的macOS版本(例如darwin_20对应macOS Big Sur及更高版本)和x86_64架构匹配的.tbz2文件。例如:php73-phalcon3-3.4.5_0.darwin_20.x86_64.tbz2。
  3. 解压文件: 下载后,使用以下命令解压:
    tar -xvjf php73-phalcon3-3.4.5_0.darwin_20.x86_64.tbz2

    解压后,你会在./opt/local/lib/php73/extensions/no-debug-non-zts-20180731/路径下找到phalcon.so文件。

3.3 部署Phalcon扩展到XAMPP

  1. 复制phalcon.so: 将解压得到的phalcon.so文件复制到XAMPP的PHP扩展目录。假设你的扩展目录是 /Applications/XAMPP/xamppfiles/lib/php/extensions/no-debug-non-zts-20180731/:

    cp ./opt/local/lib/php73/extensions/no-debug-non-zts-20180731/phalcon.so /Applications/XAMPP/xamppfiles/lib/php/extensions/no-debug-non-zts-20180731/

    请根据你实际的PHP版本和扩展目录路径进行调整。

  2. 配置php.ini:

    • 打开XAMPP的php.ini文件,通常位于 /Applications/XAMPP/xamppfiles/etc/php.ini。
    • 在文件末尾或适当位置添加以下行来加载Phalcon扩展:
      ; Enable Phalcon extension
      extension=phalcon.so
    • 确保extension_dir指令指向了你复制phalcon.so的正确目录。

3.4 重启XAMPP并验证安装

  1. 重启XAMPP服务: 打开XAMPP控制面板,停止并重新启动Apache服务。
  2. 验证Phalcon:
    • 在终端运行:
      /Applications/XAMPP/bin/php -m | grep phalcon

      如果输出中包含 phalcon,则表示扩展已成功加载。

    • 创建 info.php 文件在XAMPP的web根目录(通常是/Applications/XAMPP/xamppfiles/htdocs/),内容如下:
    • 浏览器中访问 http://localhost/info.php,搜索“phalcon”。如果看到Phalcon的配置信息,则表示安装成功。

4. 注意事项与总结

  • 架构匹配至关重要: 始终确保你安装的PHP扩展的架构(x86_64或ARM64)与加载它的PHP解释器的架构一致。在M1 Mac上使用XAMPP时,通常意味着需要x86_64架构的扩展。
  • PHP版本兼容性: Phalcon扩展版本必须与你的PHP版本兼容。本教程以Phalcon 3.4和PHP 7.3为例。
  • extension_dir路径: 仔细核对php.ini中的extension_dir路径,它必须指向phalcon.so文件所在的目录。
  • Rosetta 2: 如果你是在M1 Mac上使用Homebrew安装原生的ARM64 PHP,那么你需要为该PHP安装ARM64架构的Phalcon扩展。本教程主要针对XAMPP(通过Rosetta 2运行x86_64 PHP)的情况。
  • 权限问题: 确保phalcon.so文件和XAMPP的扩展目录具有正确的读取权限,以便PHP能够访问。

通过遵循上述步骤,并特别关注架构兼容性,你可以在Apple M1 Pro设备上的XAMPP环境中成功安装并启用Phalcon PHP扩展。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1766

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1183

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1081

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1396

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1228

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1439

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

27

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号