当前位置: 首页 > news >正文

网络打印机的搜索与连接(一)

介绍

        网络打印机就是可以通过网络连接上的打印机,这类打印机分2种:自身具有互联网接入功能可以分配IP的打印机我们称为网络打印机、另外一种就是被某台电脑连接上去后通过共享的方式共享到网络里面的我们称为共享打印机。现在还有一种可以通过互联网连接的网络打印机,本篇文章暂时先不讲。下面将详细讲解上述2类打印机的搜索、连接。

网络打印机的搜索

        网络打印机可以通过2种协议搜索到

  • snmp协议:此协议适用于查询单个IP的网络打印机搜索。此协议会发送一个标准的snmp协议内容给目标ip地址(协议内容:".1.3.6.1.2.1.1.1.0"),如果该ip是某个网络打印机那么就会进行应答(回答内容:SNMPv2-MIB::sysDescr.0 = STRING: HP ETHERNET MULTI-ENVIRONMENT,SN:VNH3626885,FN:3K90LKC,SVCID:34305,PID:HP LaserJet MFP M227fdn)。 代码如下:
// 初始化SNMP库。
init_snmp("snmp_printer");struct snmp_session session;
struct snmp_session* sess_handle = nullptr;
struct snmp_pdu* pdu = nullptr;
struct snmp_pdu* response = nullptr;
struct variable_list* variables = nullptr;
oid id_oid[MAX_OID_LEN];
size_t id_len = MAX_OID_LEN;
int status;// 初始化会话
snmp_sess_init(&session);
session.peername = _strdup(peername);// 设置社区字符串
session.community = (u_char*)_strdup("public");
session.community_len = strlen((const char*)session.community);// 设置SNMP版本
session.version = SNMP_VERSION_2c;
session.timeout = 1000;
session.retries = 1;// 打开SNMP会话
sess_handle = snmp_open(&session);
if (!sess_handle) 
{snmp_perror("snmp_open");return;
}// 创建 PDU
pdu = snmp_pdu_create(SNMP_MSG_GET);
if (pdu == nullptr)
{return;
}read_objid(".1.3.6.1.2.1.1.1.0", id_oid, &id_len);
snmp_add_null_var(pdu, id_oid, id_len);// 发送 PDU
status = snmp_synch_response(sess_handle, pdu, &response);// 检查是否成功
if (status == STAT_SUCCESS && response->errstat == SNMP_ERR_NOERROR)
{// 处理变量列表for (variables = response->variables; variables; variables = variables->next_variable){snprint_variable(szPrinterInfo, nBuffSize, variables->name, variables->name_length, variables);}KLOG_INFO << "QueryPrinter SnmpGet: " << szPrinterInfo;
}
else 
{// 如果失败,则打印错误if (status == STAT_SUCCESS)fprintf(stderr, "Error in packet\nReason: %s\n",snmp_errstring(response->errstat));else if (status == STAT_TIMEOUT)fprintf(stderr, "Timeout: No response from %s.\n",session.peername);elsesnmp_sess_perror("snmpdemoapp", sess_handle);
}// 释放响应
if (response && pdu) {snmp_free_pdu(response);
}// 关闭会话
snmp_close(sess_handle);// 清理SNMP库。
snmp_shutdown("snmp_printer");
  • mDNS多播DNS协议来解析网络上设备的主机名到IP地址,而无需中央DNS服务器的网络服务协议。通过向固定IP和和固定端口5353发送不同的协议来接收应答这样的方式搜索打印机
    static int mdns_query_send(int sock, mdns_record_type_t type, const char* name, size_t length, void* buffer,size_t capacity, uint16_t query_id) 
{if (capacity < (17 + length))return -1;uint16_t rclass = MDNS_CLASS_IN | MDNS_UNICAST_RESPONSE;struct sockaddr_storage addr_storage;struct sockaddr* saddr = (struct sockaddr*)&addr_storage;socklen_t saddrlen = sizeof(addr_storage);if (getsockname(sock, saddr, &saddrlen) == 0) {if ((saddr->sa_family == AF_INET) &&(ntohs(((struct sockaddr_in*)saddr)->sin_port) == MDNS_PORT))rclass &= ~MDNS_UNICAST_RESPONSE;else if ((saddr->sa_family == AF_INET6) &&(ntohs(((struct sockaddr_in6*)saddr)->sin6_port) == MDNS_PORT))rclass &= ~MDNS_UNICAST_RESPONSE;}uint16_t* data = (uint16_t*)buffer;// Query ID*data++ = htons(query_id);// Flags*data++ = 0;// Questions*data++ = htons(1);// No answer, authority or additional RRs*data++ = 0;*data++ = 0;*data++ = 0;// Fill in question// Name stringdata = (uint16_t*)mdns_string_make(data, capacity - 17, name, length);if (!data)return -1;// Record type*data++ = htons(type);//! Optional unicast response based on local port, class IN*data++ = htons(rclass);ptrdiff_t tosend = (char*)data - (char*)buffer;if (mdns_multicast_send(sock, buffer, (size_t)tosend))return -1;return query_id;}static size_tmdns_query_recv(int sock, void* buffer, size_t capacity, mdns_record_callback_fn callback,void* user_data, int only_query_id) {struct sockaddr_in6 addr;struct sockaddr* saddr = (struct sockaddr*)&addr;socklen_t addrlen = sizeof(addr);memset(&addr, 0, sizeof(addr));int ret = recvfrom(sock, (char*)buffer, (mdns_size_t)capacity, 0, saddr, &addrlen);if (ret <= 0)return 0;size_t data_size = (size_t)ret;uint16_t* data = (uint16_t*)buffer;uint16_t query_id = ntohs(*data++);uint16_t flags = ntohs(*data++);uint16_t questions = ntohs(*data++);uint16_t answer_rrs = ntohs(*data++);uint16_t authority_rrs = ntohs(*data++);uint16_t additional_rrs = ntohs(*data++);(void)sizeof(flags);if ((only_query_id > 0) && (query_id != only_query_id))return 0;  // Not a reply to the wanted one-shot queryif (questions > 1)return 0;// Skip questions partint i;for (i = 0; i < questions; ++i) {size_t ofs = (size_t)((char*)data - (char*)buffer);if (!mdns_string_skip(buffer, data_size, &ofs))return 0;data = (uint16_t*)((char*)buffer + ofs);uint16_t rtype = ntohs(*data++);uint16_t rclass = ntohs(*data++);(void)sizeof(rtype);(void)sizeof(rclass);}size_t records = 0;size_t offset = MDNS_POINTER_DIFF(data, buffer);records += mdns_records_parse(sock, saddr, addrlen, buffer, data_size, &offset,MDNS_ENTRYTYPE_ANSWER, query_id, answer_rrs, callback, user_data);records +=mdns_records_parse(sock, saddr, addrlen, buffer, data_size, &offset,MDNS_ENTRYTYPE_AUTHORITY, query_id, authority_rrs, callback, user_data);records += mdns_records_parse(sock, saddr, addrlen, buffer, data_size, &offset,MDNS_ENTRYTYPE_ADDITIONAL, query_id, additional_rrs, callback,user_data);return records;}

共享打印机的搜索

        共享打印机的搜索其实是根据windows的远程登录原理来实现,首先利用Guest帐号登录远程系统,然后再遍历设备获取打印机。 代码如下:

void CSharedPrinter::SearchSharedPrinter(const char* szIpAddress, const char* szUser, const char* szPassword, bool bDefaultLogin, bool bNotifyUI)
{m_strSharedUser = szUser;m_strSharedPass = szPassword;std::wstring strIpAddress = cf::string::SysMultiByteToWide(szIpAddress, CP_ACP);std::wstring strUser = cf::string::SysMultiByteToWide(szUser, CP_ACP);std::wstring strPassword = cf::string::SysMultiByteToWide(szPassword, CP_ACP);wchar_t remote[MAX_PATH] = { 0 };_snwprintf_s(remote, MAX_PATH, L"\\\\%s\\IPC$", strIpAddress.c_str());USE_INFO_2 useInfo;ZeroMemory(&useInfo, sizeof(useInfo));useInfo.ui2_local = nullptr;useInfo.ui2_remote = remote;useInfo.ui2_username = (LPWSTR)strUser.c_str();useInfo.ui2_password = (LPWSTR)strPassword.c_str();useInfo.ui2_domainname = (LPWSTR)L"";useInfo.ui2_asg_type = USE_WILDCARD;int nRetry = 0;
LOGIN:// 建立连接nRetry++;DWORD dwResult;NET_API_STATUS nStatus = NetUseAdd(NULL, 2, (LPBYTE)&useInfo, &dwResult);if (nStatus != NERR_Success){if (bNotifyUI){if (OnLoginError(nStatus, szIpAddress, szUser, szPassword, bDefaultLogin)){// 修复重复,重试一次if (nRetry < 2 && !m_bStopAddressSearch){goto LOGIN;}}}return;}if (bNotifyUI){PrinterConnect data;data.nAction = 2;data.emPrinterType = PrinterType::share;data.nLoginResult = 1;KReportInfoC::reportPrinterConnect(data);}LPBYTE pBuf = nullptr;DWORD entriesRead = 0;DWORD totalEntries = 0;DWORD resumeHandle = 0;wchar_t remote2[MAX_PATH] = { 0 };_snwprintf_s(remote2, MAX_PATH, L"\\\\%s", strIpAddress.c_str());nStatus = NetShareEnum(remote2, 1, &pBuf, MAX_PREFERRED_LENGTH, &entriesRead, &totalEntries, &resumeHandle);if (nStatus == ERROR_SUCCESS || nStatus == ERROR_MORE_DATA){PSHARE_INFO_1 pShareInfo = reinterpret_cast<PSHARE_INFO_1>(pBuf);for (DWORD i = 0; i < entriesRead; i++){if (STYPE_PRINTQ == pShareInfo[i].shi1_type){auto strName = cf::string::SysWideToMultiByte(pShareInfo[i].shi1_netname, CP_UTF8);NetworkPrinter stPrinterInfo;strcpy_s(stPrinterInfo.szName, strName.c_str());strcpy_s(stPrinterInfo.szIPV4, szIpAddress);stPrinterInfo.bPrinter = true;NotifySearchResult(szIpAddress, stPrinterInfo, PRINTER_TYPE::PRINTER_SHARED, false);}}m_LoginInfo[szIpAddress] = std::make_pair(szUser,szPassword);}NetUseDel(nullptr, remote, USE_NOFORCE);if (pBuf != nullptr){NetApiBufferFree(pBuf);}
}

        

相关文章:

网络打印机的搜索与连接(一)

介绍 网络打印机就是可以通过网络连接上的打印机&#xff0c;这类打印机分2种&#xff1a;自身具有互联网接入功能可以分配IP的打印机我们称为网络打印机、另外一种就是被某台电脑连接上去后通过共享的方式共享到网络里面的我们称为共享打印机。现在还有一种可以通过互联网连接…...

LangChain + llamaFactory + Qwen2-7b-VL 构建本地RAG问答系统

单纯仅靠LLM会产生误导性的 “幻觉”&#xff0c;训练数据会过时&#xff0c;处理特定知识时效率不高&#xff0c;缺乏专业领域的深度洞察&#xff0c;同时在推理能力上也有所欠缺。 正是在这样的背景下&#xff0c;检索增强生成技术&#xff08;Retrieval-Augmented Generati…...

【自然语言处理(NLP)】介绍、发展史

文章目录 介绍发展史1. 规则驱动时期&#xff08;20世纪50年代-80年代&#xff09;技术特点标志性成果 2. 统计方法兴起&#xff08;1990年代-2000年代&#xff09;技术特点标志性成果 3. 神经网络复兴&#xff08;2010年代初至今&#xff09;技术特点标志性成果 4. 集成与应用…...

1.CSS的三大特性

css有三个非常重要的三个特性&#xff1a;层叠性、继承性、优先级 1.1 层叠性 想通选择器给设置想听的样式&#xff0c;此时一个样式就会覆盖&#xff08;层叠&#xff09;另一个冲突的样式。层叠性主要是解决样式冲突的问题。 <!DOCTYPE html> <html lang"en&…...

【分布式日志篇】从工具选型到实战部署:全面解析日志采集与管理路径

网罗开发 &#xff08;小红书、快手、视频号同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企业从事人工智能项目研发管理工作&#xff0c;平时热衷于分享各种编程领域的软硬技能知识以及前沿技术&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…...

基于springcloud汽车信息分析与可视化系统

基于Spring Cloud的汽车信息分析与可视化系统是一款旨在整合、分析汽车相关数据并以直观可视化方式呈现的应用系统。 一、系统架构 该系统基于先进的Spring Cloud架构构建&#xff0c;充分利用其分布式、微服务特性&#xff0c;确保系统具备高可用性、可扩展性和灵活性。Spri…...

TOGAF之架构标准规范-信息系统架构 | 数据架构

TOGAF是工业级的企业架构标准规范&#xff0c;信息系统架构阶段是由数据架构阶段以及应用架构阶段构成&#xff0c;本文主要描述信息系统架构阶段中的数据架构阶段。 如上所示&#xff0c;信息系统架构&#xff08;Information Systems Architectures&#xff09;在TOGAF标准规…...

Databend x 沉浸式翻译 | 基于 Databend Cloud 构建高效低成本的业务数据分析体系

「沉浸式翻译」是一个非常流行的双语对照网页翻译扩展工具&#xff0c;用户可以用它来即时翻译外文网页、PDF 文档、ePub 电子书、字幕等。它不仅可以实现原文加译文实时双语对照显示&#xff0c;还支持 Google、OpenAI、DeepL、微软、Gemini、Claude 等数十家翻译平台服务的自…...

cuda的并行运算介绍

cuda是如何使用GPU并行运算的&#xff1a; 以一个函数为例&#xff1a; duplicateWithKeys << <(P 255) / 256, 256 >> > (P,geomState.means2D,geomState.depths,geomState.point_offsets,binningState.point_list_keys_unsorted,binningState.point_list_…...

「全网最细 + 实战源码案例」设计模式——抽象工厂模式

核心思想 抽象工厂模式是一种创建型设计模式&#xff0c;它提供一个接口&#xff0c;用于创建一系列相关或互相依赖的对象&#xff0c;而无需指定它们的具体类。抽象工厂模式解决了产品族的问题&#xff0c;可以管理和创建一组相关的产品。 结构 1. 抽象工厂 定义创建一些列…...

领域驱动设计(DDD)四 订单管理系统实践步骤

以下是基于 领域驱动设计&#xff08;DDD&#xff09; 的订单管理系统实践步骤&#xff0c;系统功能主要包括订单的创建、更新、查询和状态管理&#xff0c;采用 Spring Boot 框架进行实现。 1. 需求分析 订单管理系统的基本功能&#xff1a; 订单创建&#xff1a;用户下单创…...

leetcode 面试经典 150 题:简化路径

链接简化路径题序号71题型字符串解法栈难度中等熟练度✅✅✅ 题目 给你一个字符串 path &#xff0c;表示指向某一文件或目录的 Unix 风格 绝对路径 &#xff08;以 ‘/’ 开头&#xff09;&#xff0c;请你将其转化为 更加简洁的规范路径。 在 Unix 风格的文件系统中规则如下…...

基于 STM32 的智能农业温室控制系统设计

1. 引言 随着农业现代化的发展&#xff0c;智能农业温室控制系统对于提高农作物产量和质量具有重要意义。该系统能够实时监测温室内的环境参数&#xff0c;如温度、湿度、光照强度和土壤湿度等&#xff0c;并根据这些参数自动调节温室设备&#xff0c;如通风扇、加热器、加湿器…...

【Spring Boot】掌握 Spring 事务:隔离级别与传播机制解读与应用

前言 &#x1f31f;&#x1f31f;本期讲解关于spring 事务传播机制介绍~~~ &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 &#x1f525; 你的点赞就是小编不断更新的最大动力 &#x1f386;那么废话…...

【Postgres_Python】使用python脚本将多个PG数据库合并为一个PG数据库

需要合并的多个PG数据库表个数和结构一致&#xff0c;这里提供一种思路&#xff0c;选择sql语句insert插入的方式进行&#xff0c;即将其他PG数据库的每个表内容插入到一个PG数据库中完成数据库合并 示例代码说明&#xff1a; 选择一个数据库导出表结构为.sql文件&#xff08…...

Tailwind CSS v4.0 发布

Holy shit its actually done &#xff01; 1 月 22 日&#xff0c;Tailwind CSS 正式发布了 4.0 版本&#xff0c;针对性能和灵活性进行了优化&#xff0c;重新构想了配置和定制体验&#xff0c;并充分利用了 Web 平台提供的最新进展。 新的高性能引擎- 完整构建速度提高 5 …...

pandas基础:文件的读取和写入

文件的读取和写入 读取csv文件 csv文件&#xff1a; name,age,city Alice,25,New York Bob,30,Los Angelesread_csv(filename) header&#xff1a;如 何处理文件的第一行。header0将第一行作为列名&#xff0c;headerNone表示文件中没有列名&#xff0c;所有行都是数据。 im…...

【MySQL — 数据库增删改查操作】深入解析MySQL的create insert 操作

数据库CRUD操作 1 CRUD简介 CURD是对数据库中的记录进行基本的增删改查操作: 2. Create 新增 语法 INSERT [INTO] table_name[(column [&#xff0c;column] ...)] VALUES(value_list)[&#xff0c;(value_list)] ... # value 后面的列的个数和类型&#xff0c;要和表结构匹配…...

每日OJ_牛客_小红的子串_滑动窗口+前缀和_C++_Java

目录 牛客_小红的子串_滑动窗口前缀和 题目解析 C代码 Java代码 牛客_小红的子串_滑动窗口前缀和 小红的子串 描述&#xff1a; 小红拿到了一个长度为nnn的字符串&#xff0c;她准备选取一段子串&#xff0c;满足该子串中字母的种类数量在[l,r]之间。小红想知道&…...

HTTP 配置与应用(局域网)

想做一个自己学习的有关的csdn账号&#xff0c;努力奋斗......会更新我计算机网络实验课程的所有内容&#xff0c;还有其他的学习知识^_^&#xff0c;为自己巩固一下所学知识&#xff0c;下次更新HTTP 配置与应用&#xff08;不同网段&#xff09;。 我是一个萌新小白&#xf…...

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...

CMake基础:构建流程详解

目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

高危文件识别的常用算法:原理、应用与企业场景

高危文件识别的常用算法&#xff1a;原理、应用与企业场景 高危文件识别旨在检测可能导致安全威胁的文件&#xff0c;如包含恶意代码、敏感数据或欺诈内容的文档&#xff0c;在企业协同办公环境中&#xff08;如Teams、Google Workspace&#xff09;尤为重要。结合大模型技术&…...

leetcodeSQL解题:3564. 季节性销售分析

leetcodeSQL解题&#xff1a;3564. 季节性销售分析 题目&#xff1a; 表&#xff1a;sales ---------------------- | Column Name | Type | ---------------------- | sale_id | int | | product_id | int | | sale_date | date | | quantity | int | | price | decimal | -…...

《基于Apache Flink的流处理》笔记

思维导图 1-3 章 4-7章 8-11 章 参考资料 源码&#xff1a; https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...

自然语言处理——循环神经网络

自然语言处理——循环神经网络 循环神经网络应用到基于机器学习的自然语言处理任务序列到类别同步的序列到序列模式异步的序列到序列模式 参数学习和长程依赖问题基于门控的循环神经网络门控循环单元&#xff08;GRU&#xff09;长短期记忆神经网络&#xff08;LSTM&#xff09…...

图表类系列各种样式PPT模版分享

图标图表系列PPT模版&#xff0c;柱状图PPT模版&#xff0c;线状图PPT模版&#xff0c;折线图PPT模版&#xff0c;饼状图PPT模版&#xff0c;雷达图PPT模版&#xff0c;树状图PPT模版 图表类系列各种样式PPT模版分享&#xff1a;图表系列PPT模板https://pan.quark.cn/s/20d40aa…...

dify打造数据可视化图表

一、概述 在日常工作和学习中&#xff0c;我们经常需要和数据打交道。无论是分析报告、项目展示&#xff0c;还是简单的数据洞察&#xff0c;一个清晰直观的图表&#xff0c;往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server&#xff0c;由蚂蚁集团 AntV 团队…...

mac 安装homebrew (nvm 及git)

mac 安装nvm 及git 万恶之源 mac 安装这些东西离不开Xcode。及homebrew 一、先说安装git步骤 通用&#xff1a; 方法一&#xff1a;使用 Homebrew 安装 Git&#xff08;推荐&#xff09; 步骤如下&#xff1a;打开终端&#xff08;Terminal.app&#xff09; 1.安装 Homebrew…...

Python竞赛环境搭建全攻略

Python环境搭建竞赛技术文章大纲 竞赛背景与意义 竞赛的目的与价值Python在竞赛中的应用场景环境搭建对竞赛效率的影响 竞赛环境需求分析 常见竞赛类型&#xff08;算法、数据分析、机器学习等&#xff09;不同竞赛对Python版本及库的要求硬件与操作系统的兼容性问题 Pyth…...