深入解析OpenWrt中的LuciAPI文档及szloogson模块构建
作者:于浮浅 | 来源:互联网 | 2024-12-03 12:06
OpenWrt是一款高度可定制的嵌入式Linux发行版,广泛应用于无线路由器等领域,拥有超过百个预装软件包。本文详细探讨如何在OpenWrt上通过Luci构建自定义模块,以扩展其功能。
OpenWrt 是一款强大的嵌入式 Linux 平台,特别适用于无线路由器等设备,支持多种硬件架构,并提供了一个丰富的软件库。开发人员可以通过添加新的软件包来扩展其功能,从而满足特定的应用需求。 ### 准备工作 在 OpenWrt 中添加新软件包非常简便,只需遵循其约定即可轻松完成。新增的软件包既可以是来自互联网的开源软件,也可以是自定义开发的软件。具体步骤包括在 `package` 目录下创建一个新的子目录,并在此目录中编写 Makefile 文件以与 OpenWrt 集成。此外,还可以创建一个 `patches` 目录用于存放对源代码的修改补丁。 本文介绍的模块是基于 Luci 的,因此我们在 `package/feeds/luci` 目录下创建了一个名为 `szloogson` 的新目录。 ### 模块 Makefile 编写 在 `szloogson` 目录中创建一个 `Makefile` 文件,该文件的内容如下所示: ```makefile # Copyright (C) 2010-2014 Davied Huang Wich # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # include $(TOPDIR)/rules.mk PKG_NAME:=luci-app-szloogson PKG_VERSION:=1.0 PKG_RELEASE:=1 PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME) include $(INCLUDE_DIR)/package.mk define Package/luci-app-szloogson SECTION:=luci CATEGORY:=LuCI SUBMENU:=3. Applications TITLE:=shenzhou loogson for LuCI PKGARCH:=all endef # 描述信息 define Package/luci-app-szloogson/description This package provides LuCI configuration pages for shenzhou loogson. endef # 编译前准备 define Build/Prepare mkdir -p $(PKG_BUILD_DIR) $(CP) ./src/* $(PKG_BUILD_DIR)/ endef # 编译配置(如果需要) define Build/Configure endef # 编译过程 define Build/Compile $(MAKE) -C $(PKG_BUILD_DIR) \ CC="$(TARGET_CC)" \ CROSS_COMPILE="$(TARGET_CROSS)" \ ARCH="$(ARCH)" endef # 安装过程 define Package/luci-app-szloogson/install # 安装 Shell 脚本 $(INSTALL_DIR) $(1)/etc/init.d $(INSTALL_BIN) ./files/loogson.init $(1)/etc/init.d/loogson # 安装配置文件 $(INSTALL_DIR) $(1)/etc/config $(INSTALL_CONF) ./files/loogson.config $(1)/etc/config/loogson # 安装可执行文件 $(INSTALL_DIR) $(1)/usr/sbin $(INSTALL_BIN) $(PKG_BUILD_DIR)/gsc3280_led $(1)/usr/sbin/gsc3280_led # 安装 LuCI 文件 mkdir -p $(1)/usr/lib/lua/luci/controller/admin $(INSTALL_DIR) $(1)/usr/lib/lua/luci/controller $(INSTALL_DATA) ./src/luci/controller/admin/loogson.lua $(1)/usr/lib/lua/luci/controller/admin/loogson.lua mkdir -p $(1)/usr/lib/lua/luci/model/cbi/admin_loogson $(INSTALL_DIR) $(1)/usr/lib/lua/luci/model/cbi $(INSTALL_DATA) ./src/luci/model/cbi/admin_loogson/* $(1)/usr/lib/lua/luci/model/cbi/admin_loogson/ endef $(eval $(call BuildPackage,luci-app-szloogson)) ``` #### 关键点解释 - **第8行**:`$(TOPDIR)/rules.mk` 文件通常位于 Makefile 的开头,用于定义一些基本的包信息。 - **第17行**:`include $(INCLUDE_DIR)/package.mk` 文件在定义完包的基本信息后引入,用于定义用户态软件包的编译规则。 - **第19行**:`define Package/luci-app-szloogson` 定义了包的基本信息,如包名、分类、子菜单位置、标题等。 - **第27行**:`define Package/luci-app-szloogson/description` 提供了包的详细描述。 - **第31行**:`define Build/Prepare` 定义了编译前的准备工作,如创建必要的目录并复制源代码。 - **第36行**:`define Build/Configure` 用于配置编译环境,对于自定义开发的包通常不需要此步骤。 - **第39行**:`define Build/Compile` 定义了编译过程,指定了交叉编译器和目标架构。 - **第46行**:`define Package/luci-app-szloogson/install` 定义了安装过程,包括将编译后的文件复制到指定位置。 ### 内核模块包定义 除了用户态软件包外,OpenWrt 还支持内核模块的开发。内核模块可以动态加载到内核中,从而提供额外的功能。内核模块的定义与用户态软件包类似,但使用 `KernelPackage` 开头,并且需要指定 `SUBMENU` 和 `DEFAULT` 等参数。 #### 关键参数 - **SUBMENU**:定义内核模块在 `make menuconfig` 中的子菜单位置。 - **DEFAULT**:指定内核模块是否直接编入内核 (`y`) 或生成为模块 (`m`)。 - **AUTOLOAD**:定义内核模块在系统启动时自动加载的优先级和模块名。 ### 自动运行脚本 如果需要在系统启动时自动运行某些程序,可以在 `/etc/init.d` 目录下添加相应的脚本文件,并设置 `START` 和 `STOP` 参数以控制启动和停止的优先级。 通过以上步骤,您可以成功地在 OpenWrt 上构建和部署自定义的 Luci 模块,进一步扩展其功能。
推荐阅读
本文为Flutter系列教程的一部分,专注于讲解如何在Flutter应用中实现自动关闭的对话框和提示。通过具体的代码示例,帮助开发者掌握SnackBar、BottomSheet和Dialog的使用方法。 ...
[详细]
蜡笔小新 2024-12-03 13:40:43
本文详细介绍了RPM包构建过程中Spec文件的结构和各部分的作用,包括包描述、准备阶段、构建过程、安装步骤、清理操作以及文件列表等关键环节。同时,提供了关于RPM宏命令、打包目录结构及常见标签的深入解析。 ...
[详细]
蜡笔小新 2024-12-02 17:57:52
设计模式笔记12:迭代器模式(Iterator Pattern) ...
[详细]
蜡笔小新 2024-12-02 12:56:10
本文将介绍如何使用Spring Boot集成Swagger来创建和展示API文档。通过访问http://localhost:8080/swagger-ui.html,用户可以直接查看到应用的API文档界面,这一功能极大地简化了API文档的编写和维护。 ...
[详细]
蜡笔小新 2024-11-30 13:21:40
一、database-sync简介database-sync作为一种开源辅助工具,用于数据库之间的表同步,更确切的说法是复制,可以从一个数据库复制表到另一个数据库该工具支持的功能如 ...
[详细]
蜡笔小新 2024-12-02 18:31:18
本指南详细介绍了如何在最新的 Go 语言环境及 IntelliJ IDEA 中配置 Iris V12 框架,适合初学者和有经验的开发者。文章提供了详细的步骤说明和示例代码,帮助读者快速搭建开发环境。 ...
[详细]
蜡笔小新 2024-12-02 13:02:05
本文探讨了如何利用自定义URI方案和注册表编辑,在Windows操作系统中实现从Web浏览器启动本地应用程序的方法,同时强调了这一过程中的安全考虑。 ...
[详细]
蜡笔小新 2024-12-02 09:09:42
尽管配置文件的重要性不言而喻,但其管理和安全性问题却常被忽视。本文将详细讨论配置文件的不同管理策略及其优缺点。 ...
[详细]
蜡笔小新 2024-12-01 19:35:41
本文详细探讨了UML用例图中的两种重要关系——包含关系和扩展关系,通过具体示例解析这两种关系的应用场景及其实现方式。 ...
[详细]
蜡笔小新 2024-12-01 16:45:09
本文深入探讨了Kubernetes中Pod的基础概念及其分类,旨在帮助读者更好地理解和利用这一核心组件。通过详细的解析,我们将了解Pod如何作为最小的部署单元在Kubernetes集群中工作。 ...
[详细]
蜡笔小新 2024-12-01 03:44:45
本文详细介绍了 Android 开发中显式 Intent 和隐式 Intent 的区别及应用场景,包括如何通过显式 Intent 在同一应用内切换 Activity,以及如何利用隐式 Intent 实现跨应用的功能调用。 ...
[详细]
蜡笔小新 2024-11-30 15:15:39
0.JobScheduler执行代码mJobScheduler(JobScheduler)getSystemService(Context.JOB_SCHEDULER_SERVICE); ...
[详细]
蜡笔小新 2024-11-29 17:51:29
哈喽^_^一般我们在编写网页爬虫的时候经常会使用到Fiddler这个工具来分析http包,而且通常并不是分析一个包就够了的,所以为了把更多的时间放在分析http包上,自动化生成 ...
[详细]
蜡笔小新 2024-11-28 13:39:49
本文综述了图神经网络(Graph Neural Networks, GNN)的发展,从传统的数据存储模型转向图和动态模型,探讨了模型中的显性和隐性结构,并详细介绍了GNN的关键组件及其应用。 ...
[详细]
蜡笔小新 2024-11-28 13:27:43
本文旨在为初学者提供一个详细的指南,从零开始学习如何使用 ASP.NET MVC5 和 Entity Framework 6 (EF6) 搭建项目。通过逐步指导,帮助读者理解 MVC 架构的核心概念,并掌握基本的操作方法。 ...
[详细]
蜡笔小新 2024-11-27 20:41:31