OPENWRT 教程第二章 Openwrt Luci 初探(WEB)

 

那么,到底什么是Luci呢?先直观的感受一下,打开web浏览器的网关地址,然后出现了一个web登录界面,这个就是Openwrt Luci的应用。

 

 

 

概述:

OpenWRT的web采取的是luci框架, 在luci的官方网站说明了luci是一个MVC架构的框架,是一个单用户框架,
公用的模块放置在*/luci/controller/下面,
各个用户的模块放置在*/luci/controller/下面对应的文件夹里面,
比如admin登录,最终的页面只显示/luci/controller/admin下面的菜单。这样既有效的管理了不同管理员的权限。

 

基础知识:

Luci = lua + uci
lua : 脚本语言
uci :(Unified Configuration Interface)是Openwrt的配置框架

 

 

Openwrt 的 web 服务器: uhttpd

uhttpd:是一个轻量级的web服务器,由于其可以和Openwrt的配置框架UCI结合到一起,因此默认被用于OpenWrt的Web管理接口LuCI。我们都知道,网站都是被部署在一台台服务器,PC等设备上的,我们的设备访问网站时,先是通过网络访问到部署这个网站的服务器,然后服务器的web服务再返回页面给我们;也就是说如果服务器没有web服务,我们是访问不了网页的哦。

说明:
1) lua单行注释使用“--”,类似于C语言的“//”,多行注释时,“--[[”类似C语言中的“/*”,“]]--”类似C语言中的“*/”

 

一:luci的目录

contoller:逻辑控制文件(主要是注册页面)

model :业务上的处理

view : 存放 html 文件

controller在luci框架中的作用是逻辑上的组织,编码时主要分为2块

1 模块的注册 :

module("luci.controller.admin.system", package.seeall)		//在luci/controller/admin/下注册一个system模块

2 节点的注册 :表示添加一个新的模块入口

local fs = require "nixio.fs"
entry({"admin", "system"}, alias("admin", "system", "system"), _("System"), 30).index = true
entry({"admin", "system", "system"}, cbi("admin_system/system"), _("System"), 1)
entry({"admin", "system", "clock_status"}, call("action_clock_status"))
entry({"admin", "system", "admin"}, cbi("admin_system/admin"), _("Administration"), 2)
entry({"admin", "system", "reboot"}, call("action_reboot"), _("Reboot"), 90)

  


 
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenWrt 中,ubus 是一种进程间通信系统,它允许应用程序之间进行简单的、安全的通信。它基于 Unix 套接字和 JSON-RPC 协议,并且是 OpenWrt 的一个重要组成部分,因为它提供了许多 OpenWrt 的核心功能。 在本教程中,我们将介绍如何使用 ubus 在 OpenWrt 中进行进程间通信。 ## 安装 ubus 首先,我们需要在 OpenWrt 中安装 ubus。可以通过以下命令来安装: ``` opkg update opkg install ubus ``` ## 使用 ubus ### ubus 命令行工具 ubus 命令行工具提供了一个简单的方式来与 ubus 服务进行交互。以下是一些常用的 ubus 命令: - `ubus call`:调用一个 ubus 方法。 - `ubus list`:列出所有可用的 ubus 方法。 - `ubus monitor`:监听 ubus 事件。 例如,要列出所有可用的 ubus 方法,可以运行以下命令: ``` ubus list ``` 你将看到一份所有可用的 ubus 方法的列表。 ### ubus 库 如果你希望在应用程序中使用 ubus,可以使用 ubus 库。ubus 库是一个 C 库,允许应用程序通过编程方式调用 ubus 方法。 要使用 ubus 库,需要包含 `libubus.h` 头文件,并链接 `libubus` 库。以下是一个简单的例子: ```c #include <libubus.h> int main() { struct ubus_context *ctx = ubus_connect(NULL); if (!ctx) { printf("Failed to connect to ubus\n"); return 1; } struct blob_buf buf; blob_buf_init(&buf, 0); blobmsg_add_string(&buf, "message", "Hello, world!"); struct ubus_request req; ubus_request_init(ctx, &req, "example_method", &buf.head); if (ubus_invoke(ctx, &req)) { printf("Failed to invoke ubus method\n"); return 1; } return 0; } ``` 在这个例子中,我们连接到 ubus 服务,并调用了一个名为 `example_method` 的 ubus 方法,传递了一个包含 `message` 字段的 blob 对象。当 ubus 方法被调用时,它会收到这个包含消息的 blob 对象,并且可以进行相应的操作。 ### ubus 事件 除了调用 ubus 方法之外,ubus 还支持事件。应用程序可以向 ubus 注册事件,并在事件发生时接收通知。以下是一个简单的例子: ```c #include <libubus.h> static void event_handler(struct ubus_context *ctx, struct ubus_event_handler *ev, const char *type, struct blob_attr *msg) { printf("Received event: %s\n", type); } int main() { struct ubus_context *ctx = ubus_connect(NULL); if (!ctx) { printf("Failed to connect to ubus\n"); return 1; } struct ubus_event_handler handler = { .cb = event_handler, }; ubus_register_event_handler(ctx, &handler, "example_event"); while (1) { ubus_handle_event(ctx); } return 0; } ``` 在这个例子中,我们向 ubus 注册了一个名为 `example_event` 的事件,并在事件发生时打印出了事件的类型。 ## 总结 在本教程中,我们介绍了 OpenWrt 中的 ubus 进程间通信系统,并且演示了如何使用 ubus 命令行工具和 ubus 库进行进程间通信。此外,我们还展示了如何使用 ubus 事件来接收通知。ubus 是 OpenWrt 的一个重要组成部分,可以让应用程序之间进行简单的、安全的通信。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值