热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

深入解析OpenWrt中的LuciAPI文档及szloogson模块构建

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 模块,进一步扩展其功能。
推荐阅读
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文介绍了如何在C#中启动一个应用程序,并通过枚举窗口来获取其主窗口句柄。当使用Process类启动程序时,我们通常只能获得进程的句柄,而主窗口句柄可能为0。因此,我们需要使用API函数和回调机制来准确获取主窗口句柄。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 本题通过将每个矩形视为一个节点,根据其相对位置构建拓扑图,并利用深度优先搜索(DFS)或状态压缩动态规划(DP)求解最小涂色次数。本文详细解析了该问题的建模思路与算法实现。 ... [详细]
  • 本文详细探讨了C语言中指针的概念,特别是指针在变量和数组中的应用。通过实例讲解,帮助读者更好地掌握指针的使用方法。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
author-avatar
于浮浅
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有