”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何使用 PHP 和 PHPDesktop 构建和分发桌面应用程序:分步指南

如何使用 PHP 和 PHPDesktop 构建和分发桌面应用程序:分步指南

发布于2024-08-30
浏览:864

How To Build And Distribute Desktop Apps Using PHP And PHPDesktop: A Step-by-Step Guide

PHP - 尽管它恰好是一种非常强大且有影响力的编程语言 - 却被许多可能不使用它或以前使用过它的程序员低估了。

今天,我想与您分享 PHP 的强大功能以及您可以用它做什么。

瞧!我们走吧?️

在本指南中,我将引导您完成使用 PHPDesktop 创建可执行桌面应用程序的过程,PHPDesktop 是一个允许开发人员将其 PHP Web 应用程序打包成独立桌面可执行文件的工具。我还将深入研究如何编译这些应用程序并通过删除默认的 PHPDesktop 徽标来自定义它们。

第 1 部分:PHPDesktop 简介

什么是 PHP 桌面版?

PHPDesktop 是一个开源项目,使开发人员能够将 PHP 应用程序作为桌面应用程序运行,而无需浏览器或 Web 服务器。它集成了 Chrome 嵌入式框架 (CEF)——它也是开源的,我们的大多数现代浏览器都是基于它构建的——用于渲染应用程序的 HTML/CSS/JavaScript 部分,允许您使用您的 Web 开发技能来创建桌面应用程序。通过使用 PHPDesktop,您可以将 PHP 脚本、HTML 文件和其他资源捆绑到一个可执行文件中,该文件可以在任何 Windows 计算机上分发和运行/安装。

第 2 部分. 设置开发环境

在开始构建桌面应用程序之前,我们首先需要设置开发环境。

如何搭建开发环境

第1步:下载PHPDesktop

  1. 访问 PHPDesktop GitHub 页面 (https://github.com/cztomczak/phpdesktop)。

  2. 选择适合您需求的版本,因为 PHPDesktop 有多种变体,包括 PHP 5.4、5.6 和 7.x。对于现代应用程序,您应该选择最新版本。

  3. 下载您首选版本的 ZIP 文件并将其解压到计算机上的目录中。

第 2 步:准备您的 PHP 应用程序

假设您已经有一个 PHP Web 应用程序/文件,请将您的应用程序文件(复制并粘贴它们 [我的意思是项目])放入提取的 PHPDesktop 文件夹的 www 目录中。这个 www 目录是 PHPDesktop 为您的应用程序提供服务的根目录,类似于您以前使用过的任何 Web 服务器上的 public_html 或 www 文件夹。

第 3 步:配置 PHPDesktop

要配置PHPDesktop,您需要编辑位于PHPDesktop文件根目录的settings.json文件。该文件允许您指定桌面应用程序的各种设置,例如窗口标题、尺寸、图标等。

(顺便说一句,如果您自己做这件事有困难,您想要为您的应用程序提供扩展功能,例如生成产品密钥,或者您希望我处理您的网络项目,您可以随时通过评论与我联系这篇文章谢谢。您也可以在我的“给我买杯咖啡”页面上找到有关我的更多详细信息。

因此,设置文件如下所示。让我们继续我们的旅程吧。 ?

基本配置:

json
{
“应用”: {
“主窗口”:{
"title": "我的桌面应用程序",
"icon": "app_icon.ico",
“默认大小”:{
“宽度”:800,
“高度”:600
},
“最小尺寸”:{
“宽度”:600,
“高度”:400
}
},
"php_interpreter": "php\\php.exe",
“app_mode”:true,
"start_url": "http://127.0.0.1:54007/"
}
}

- title: The title of your application window.

  • icon: The path to your application's icon. Replace app_icon.ico with your custom icon file and ensure its a dot ico image too.
  • default_size: The default size of your application window.
  • minimum_size: The minimum size of the application window.
  • php_interpreter: The path to the PHP executable.
  • start_url: The URL to load when the application starts. For local development, this is typically the local server address.

第 4 步:测试您的应用程序

配置 PHPDesktop 后,您可以运行 phpdesktop-chrome.exe(或等效的可执行文件,具体取决于您的 PHPDesktop 版本)来测试您的应用程序。如果一切设置正确,您的 PHP 应用程序应该在独立窗口中加载。

第 3 部分:编译应用程序

现在您的应用程序正在 PHPDesktop 中运行,下一步是将其编译为独立的可执行文件。这会将您的 PHP 脚本、HTML 文件和其他资产打包到一个文件中,该文件可以分发和运行,而不需要最终用户安装 PHP、DBMS 或任何其他依赖项。

第1步:准备Application/PHPDesktop目录

编译之前,请确保您的 PHPDesktop/application 目录已正确组织。此时,您的目录应如下所示:

/phpdesktop/

├── /www/ # 你的 PHP 应用程序文件

├── php/ # PHP解释器目录

├── settings.json # PHPDesktop配置文件

└── phpdesktop-chrome.exe # PHPDesktop 可执行文件

确保所有必需的文件都已就位,并且您已彻底测试了应用程序。

第 2 步:使用 Inno Setup 或您选择的任何其他编译器来创建用于分发的安装程序。

虽然这不是绝对必要的,但为您的应用程序创建安装程序可以增强用户体验。 Inno Setup 是 Windows 程序的免费安装程序。创建安装程序的方法如下:

  1. 从 (https://jrsoftware.org/isinfo.php) 下载并安装 Inno Setup。

  2. 创建一个新脚本并将其配置为包含 PHPDesktop 目录。

  3. 根据您的要求指定输出可执行文件的名称、安装目录和其​​他设置。

  4. 编译脚本生成安装程序。

此步骤是可选的,但如果您想为用户提供专业的安装体验,建议您执行此步骤。

第 3 步:压缩和分发

如果您不想创建安装程序,只需将整个 PHPDesktop 目录压缩为 ZIP 文件并分发即可。确保包含 phpdesktop-chrome.exe 文件,因为这是您的用户将运行来启动您的应用程序的可执行文件。

第 4 部分:自定义应用程序

完成所有操作后,您仍然发现徽标没有改变吗?

每个开发人员想要的常见自定义之一是能够删除或替换应用程序启动时出现的 PHPDesktop 徽标。我将使用本节来指导您完成该过程。

第 1 步:删除或替换 PHPDesktop 徽标

要自定义或删除 PHPDesktop 徽标,您将需要像 Resource Hacker 这样的资源编辑器。

具体操作方法如下。

  1. 下载资源黑客:

    • 访问(http://www.angusj.com/resourcehacker/)并下载并安装Resource Hacker
  2. 打开 PHPDesktop 可执行文件:

    • 启动 Resource Hacker 并打开 phpdesktop-chrome.exe。
  3. 导航至徽标资源:

    • 在 Resource Hacker 中,导航到树视图中的“位图”部分。您可以在这里找到徽标文件,通常命名为 101、102 等。
    • 右键单击徽标并选择“替换资源”。
  4. 替换或删除徽标:

    • 要替换徽标,请单击“使用新位图打开文件”,选择您的自定义徽标,然后替换它。
    • 要删除徽标,您可以删除资源或将其替换为空白图像。
  5. 保存更改:

    • 进行更改后,保存修改后的可执行文件。您可能希望将其另存为不同的文件以保留原始文件的备份。
  6. 测试应用程序:

    • 运行修改后的可执行文件以确保徽标已成功替换或删除。

第 2 步:更新应用程序图标

如果您想进一步自定义您的应用程序,您可以更新 PHPDesktop 使用的图标。这涉及替换 settings.json 文件中引用的“app_icon.ico”文件并确保可执行文件使用新图标。

  • 创建或查找新图标:

    • 使用图标编辑器或在线工具为您的应用程序设计自定义图标。
    • 将图标另存为.ico格式。
  • 替换图标:

    • 将 PHPDesktop 目录中现有的 app_icon.ico 文件替换为您的自定义图标。
    • 如果您使用不同的名称保存了 settings.json 文件以引用新图标。
  • 重建可执行文件:

    • 如果您进行了重大更改,请考虑使用 Resource Hacker 将新图标嵌入到可执行文件本身中。
  1. 分布和最终考虑因素

编译并自定义您的应用程序后,就可以将其分发给您的客户/用户了。现在,我想给你我自己的两个奈拉策略来帮助你进行分配,它们是:

  • 测试:在不同的Windows环境下测试您的应用程序以确保兼容性。
  • 文档:提供有关如何安装和使用应用程序的清晰说明。
  • 许可:如果您使用第三方源代码或库,那么包含他们的许可证或协议也很重要。
  • 提供支持:创建一个支持系统渠道,为可能对您的应用程序有问题的客户提供帮助。

Oya,这是我对你们的祝福??

我想相信,通过阅读到目前为止,您已经发现我的内容非常有价值,并且有兴趣尝试一下。然而,作为处理此类项目的专家,我肯定可以在最后期限内无缝地交付给您,让您大吃一惊。因此,您可以快速向我发送您想要实现的目标的详细信息,我们可以共同努力将您的想法变为现实。

订阅我的个人资料 ooo ?

下一个

  1. 技术的商业方面:技术和钱在哪里。

  2. 如何使用 PHPBROWSERBOX 构建桌面应用程序

如果你想念我,那你萨比

我无法解释我在 dev.to 上有多爱你们?

我还有一个关于此的视频教程,只需 20 美元,另一个视频教程您可以学习如何创建用于分发的激活码,只需 50 美元。

我也喝咖啡。当你等待我的下一篇文章时请给我一杯咖啡。

https://buymeacoffee.com/olatunji

等待我的下一篇文章。

版本声明 本文转载于:https://dev.to/dev_olatunji/how-to-build-and-distribute-desktop-apps-using-php-and-phpdesktop-a-step-by-step-guide-1g80?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • Python 变得强大:轻松编程的初学者指南
    Python 变得强大:轻松编程的初学者指南
    Python 是一门强大的编程语言,语法简单,应用广泛。安装 Python 后,可以学习其基本语法,包括变量赋值、数据类型和流程控制。实战案例中,我们通过蒙特卡罗模拟计算圆周率,展示了 Python 在数值计算中的能力。此外,Python 拥有丰富的库,涵盖机器学习、数据分析和网络开发等领域,体现了...
    编程 发布于2024-11-06
  • 如何在没有 jQuery 的情况下监听动态创建的元素的事件?
    如何在没有 jQuery 的情况下监听动态创建的元素的事件?
    在没有 jQuery 的情况下监听动态创建的元素的事件使用外部页面时,向动态生成的元素添加事件监听器可能具有挑战性。在这种情况下,委派事件处理至关重要。一种方法是使用 event.target 属性来检查单击或触发的元素是否属于所需类型。这是一个示例:document.querySelector('...
    编程 发布于2024-11-06
  • 利用 Snipbyte 的高级考勤管理系统优化劳动力效率
    利用 Snipbyte 的高级考勤管理系统优化劳动力效率
    在当今的商业环境中,有效管理员工出勤、轮班和工资单可以决定组织的成功或失败。准确的考勤跟踪不仅可以确保运营顺利进行,还有助于提高生产力。在 Snipbyte,我们专注于提供一流的基于网络的解决方案来增强业务流程,包括我们的高级考勤管理系统。 为什么选择Snipbyte的考勤管理系统? 我们的考勤管理...
    编程 发布于2024-11-06
  • Laravel Auth 路由教程
    Laravel Auth 路由教程
    Laravel auth routes is one of the essential features of the Laravel framework. Using middlewares you can implement different authentication strategies...
    编程 发布于2024-11-06
  • 如何有效地跳转到大型文本文件中的特定行?
    如何有效地跳转到大型文本文件中的特定行?
    优化大型文本文件中的跳行:另一种方法处理具有不同长度行的大量文本文件时,通常效率很低顺序读取每一行以达到特定的行号。问题中提供的代码示例说明了这种方法,需要对整个文件进行可能缓慢的迭代。然而,还有一种替代方法可以通过利用计算出的偏移列表来优化跳线。基于偏移的跳线要克服这一挑战,需要一种更有效的方法涉...
    编程 发布于2024-11-06
  • 如何在 JavaScript 中检索 HTML 元素的 CSS 属性值?
    如何在 JavaScript 中检索 HTML 元素的 CSS 属性值?
    在 JavaScript 中获取 HTML 元素的 CSS 属性值在 Web 开发中,动态操作 CSS 属性可以增强用户体验和界面。使用 JavaScript,访问这些属性非常简单。在您的场景中,CSS 文件链接到 HTML 页面,您需要检索类名为“的 div 的特定属性(例如颜色)”布局。”以下是...
    编程 发布于2024-11-06
  • PLSQL 中的 DBMS_OUTPUT.PUT_LINE
    PLSQL 中的 DBMS_OUTPUT.PUT_LINE
    在 Oracle PL/SQL 中,打印输出的方法是使用 DBMS_OUTPUT.PUT_LINE 过程。该过程将文本写入控制台或输出缓冲区,如果启用了 DBMS_OUTPUT,则可以在执行后查看文本。使用方法如下: 首先,在 SQL 环境(如 SQL*Plus 或 Oracle SQL Devel...
    编程 发布于2024-11-06
  • 利用 Python 实现自动化:用代码简化日常任务
    利用 Python 实现自动化:用代码简化日常任务
    介绍 Python 已成为从 Web 开发到数据科学等各种应用程序的首选语言。 Python 真正大放异彩的领域之一是自动化。无论您是希望自动化平凡的任务、简化工作流程,还是创建强大的脚本来节省时间和精力,Python 的简单性和多功能性都使其成为完成这项工作的完美工具。 ...
    编程 发布于2024-11-06
  • 如何在 Python 中传递参数来应用 Pandas 系列的函数?
    如何在 Python 中传递参数来应用 Pandas 系列的函数?
    Python Pandas 中向 Series Apply 函数传递参数pandas 库提供了 'apply()' 方法将函数应用于 Series 的每个元素。然而,旧版本的 pandas 不允许向函数传递额外的参数。旧版本 Pandas 的解决方案:在旧版本中处理此限制pandas...
    编程 发布于2024-11-06
  • 如何使用 Java 8 Lambda 按多个字段有效地对集合进行排序?
    如何使用 Java 8 Lambda 按多个字段有效地对集合进行排序?
    使用 Java 8 Lambda 对具有多个字段的集合进行排序提供的排序代码似乎不完整,可能不会产生预期的排序顺序。让我们深入研究使用 Java 8 lambda 的更高效、更全面的方法。使用 Java 8 lambda 的Java 8 通过提供直观的 lambda 表达式来简化列表排序,这些表达式...
    编程 发布于2024-11-06
  • 开发人员如何使用 JavaScript 在 HTML 页面之间安全地交换数据?
    开发人员如何使用 JavaScript 在 HTML 页面之间安全地交换数据?
    在 JavaScript 中维护 HTML 页面之间的数据完整性在网页之间传输数据时,使用查询参数的传统方法(例如“http://localhost/ project/index.html?status=exist") 可能会在 URL 中暴露敏感信息。为了解决这个问题,开发人员寻求安全交...
    编程 发布于2024-11-06
  • 夹住! VS 代码扩展
    夹住! VS 代码扩展
    今天我发布了我的第一个 VS Code 扩展 - Clamp it!此扩展可以轻松为您的 CSS 代码生成固定尺寸。 我之所以这么做是因为想要提高工作效率。我当前的流程包括访问在线钳位生成器网站,输入所需的尺寸,然后将其复制粘贴到我的代码中。 我在 ChatGPT 的帮助下做到了。 90% 的代码是...
    编程 发布于2024-11-06
  • 掌握 Java 封装:带有示例的综合指南
    掌握 Java 封装:带有示例的综合指南
    Java 封装详细指南 封装是 Java 中的四个基本 OOP(面向对象编程)原则之一,其他原则包括继承、多态性和抽象。封装是指将数据(属性)和操作该数据(行为)的方法捆绑到单个单元或类中。除了捆绑之外,封装还涉及限制对对象的某些组件的直接访问,这通常是通过访问修饰符.来实现的 在...
    编程 发布于2024-11-06
  • 将本地存储 API 与 JavaScript 和 React JS 结合使用
    将本地存储 API 与 JavaScript 和 React JS 结合使用
    JavaScript এবং React এ Local Storage API ব্যবহার সম্পর্কে বিস্তারিত আলোচনা করতে পারবেন? JavaScript এবং React এ Local Storage API ব্যবহার খুব ...
    编程 发布于2024-11-06
  • SAML、OAuth 与 OpenID Connect
    SAML、OAuth 与 OpenID Connect
    这篇文章最初发布在我的博客上。使用以下链接查看原始来源: SAML、OAuth 与 OpenID Connect ...
    编程 发布于2024-11-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3