首页
/ Libcli 技术文档

Libcli 技术文档

2024-12-14 00:03:02作者:幸俭卉

1. 安装指南

要编译并安装 Libcli 库,请按照以下步骤操作:

$ make
$ make install

请注意,从版本 1.10.5 开始,您可以在编译时选择使用 select()poll() 函数。默认情况下,使用的是传统的 select() 函数。如果您想使用 poll() 系统调用,请在编译时添加 CFLAGS=-DLIBCLI_USE_POLL 参数。

安装过程中,libcli.so 库将被安装到 /usr/local/lib 目录。如果您希望更改安装位置,可以编辑 Makefile 文件。

2. 项目使用说明

该项目包含一个名为 clitest 的测试应用程序。运行该应用程序后,您可以通过 telnet 连接到端口 8000。

默认情况下,系统启用了一个用户名和密码组合:

用户名:fred
密码:nerk

输入 help 或按 ? 键可获得帮助信息。

Libcli 支持使用箭头键进行命令行编辑。向上和向下箭头键可以在命令历史中循环切换,而向左和向右箭头键可用于编辑当前命令行。

Libcli 还能够计算出输入命令的最短方法。例如,如果定义了命令 show users | grep foobar,您可以输入 sh us | g foobar 来执行该命令。

在命令行输入 sh? 可获得以 sh 开头的命令列表。

每个 libcli 程序中预定义了一些命令:

  • help
  • quit
  • exit
  • logout
  • history

3. 项目 API 使用文档

在使用您自己的代码之前,请确保在 C 代码中包含 #include <libcli.h>,并在链接时添加 -lcli 参数。

以下是项目中一些重要的 API 函数:

  • cli_init(): 初始化 libcli 所需的内部数据结构。
  • cli_set_banner(banner): 设置欢迎横幅。
  • cli_allow_user(username, password): 添加用户名和密码组合。
  • cli_set_auth_callback(callback): 设置认证回调函数。
  • cli_register_command(parent, command, callback, privilege, mode, help): 注册命令。
  • cli_unregister_command(command): 注销命令。
  • cli_set_context(cli, context): 设置用户定义的上下文。
  • cli_get_context(cli): 获取用户定义的上下文。
  • cli_loop(cli, sock): 与用户在给定套接字上交互。
  • cli_done(): 释放数据结构。

4. 项目安装方式

项目安装方式已在“安装指南”部分进行了说明。您可以通过以下命令进行安装:

$ make
$ make install

请根据您的需要修改 Makefile 文件中的安装路径。

热门项目推荐
相关项目推荐

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
266
55
国产编程语言蓝皮书国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区
65
17
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
196
45
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
53
44
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
268
69
qwerty-learnerqwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
333
27
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
896
0
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
419
108
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
144
24
HarmonyOS-Cangjie-CasesHarmonyOS-Cangjie-Cases
参考 HarmonyOS-Cases/Cases,提供仓颉开发鸿蒙 NEXT 应用的案例集
Cangjie
58
4