有人用过delphi2009下的indy控件吗,我用idsnmp出现问题

山娃马小三儿 2009-03-06 09:00:39
IdSNMP1.Port :=161;
IdSNMP1.QuickSend('1.3.6.1.2.1.1.1.0', 'jpu.wlzx', '192.168.100.1', HostDesc);
以上在D7里成功得到设备描述值,在d2009中无反应
...全文
286 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
山娃马小三儿 2009-03-19
  • 打赏
  • 举报
回复
用dll吧,估计没戏
suine 2009-03-14
  • 打赏
  • 举报
回复
我的遭遇和你一样,在BCB6下用indy 9能取到值,在BCB2009下自带的indy10就取不到啦。
不知道用IDSNMP取过TRAP没有?我怎么取不到?
山娃马小三儿 2009-03-08
  • 打赏
  • 举报
回复
最终还是用dll搞定了,用d7做dll,用在d2009下
山娃马小三儿 2009-03-08
  • 打赏
  • 举报
回复
重新试了一下,可以发包,但是抓包显示:could't parse pdu type,有谁在RAD下成功过么
lextm 2009-03-08
  • 打赏
  • 举报
回复
可能是Indy的bug,需要联系一下开发团队。上个缺陷报告给他们看看吧。
山娃马小三儿 2009-03-08
  • 打赏
  • 举报
回复
抓包发现,无包交换,也就是说明,跟本不再工作
山娃马小三儿 2009-03-07
  • 打赏
  • 举报
回复
用了别的方法,也是在D7下可以通讯,到D2009下就不行了,到底怎么回事啊,是在同一台计算机上
山娃马小三儿 2009-03-07
  • 打赏
  • 举报
回复
怎么办啊
lextm 2009-03-07
  • 打赏
  • 举报
回复
如果是查询另外一台电脑,你不妨用Microsoft Network Monitor或者Wireshark抓一下网络包,看看到底是不是有SNMP的包在交换。
abc5566771 2009-03-07
  • 打赏
  • 举报
回复
建议查询一下indy10中相关控件的源代码。
山娃马小三儿 2009-03-07
  • 打赏
  • 举报
回复
snmpsend :=TSNMPSend.Create;
SNMPSend.Query.Clear;
SNMPSend.Query.Community :='jpu.wlzx';
SNMPSend.Query.PDUType := PDUGetRequest;
SNMPSend.Query.MIBAdd('1.3.6.1.2.1.1.1.0', '',ASN1_NULL);
snmpsend.TargetHost :='192.168.100.1';
//snmpsend.Query.
if snmpsend.SendRequest then
Edit1.Text :=(SNMPSend.Reply.MIBGet('1.3.6.1.2.1.1.1.0'));
snmpsend.Free;


同样的代码,D7下就返回结果,D2009不返回
山娃马小三儿 2009-03-07
  • 打赏
  • 举报
回复
好像不是这个引起的。我怀疑它底层的socket就没有工作
preserve 2009-03-07
  • 打赏
  • 举报
回复
注意D2009默认的string变成unicodestring了
山娃马小三儿 2009-03-06
  • 打赏
  • 举报
回复
在线求解啊
山娃马小三儿 2009-03-06
  • 打赏
  • 举报
回复
应该说在indy9下测试通过,在indy10不通过
使用TIdAntiFreeze对抗“冻结”   Indy使用一个特殊的组件TIdAntiFreeze来透明地解决客户程序用户界面“冻结”的问题。TIdAntiFreeze在Indy内部定时中断对栈的调用,并在中断期间调用Application.ProcessMessages方法处理消息,而外部的Indy调用继续保存阻塞状态,就好像TIdAntiFreeze对象不存在一样。你只要在程序中的任意地方添加一个TIdAntiFreeze对象,就能在客户程序中利用到阻塞式Socket的所有优点而避开它的一些显著缺点。   Indy使用了线程技术   阻塞式Socekt通常都采用线程技术,Indy也是如此。从最底层开始,Indy的设计都是线程化的。因此用Indy创建服务器和客户程序跟在Unix下十分相似,并且Delphi的快速开发环境和Indy对WinSock的良好封装使得应用程序创建更加容易。   Indy服务器模型   一个典型的Unix服务器有一个或多个监听进程,它们不停地监听进入的客户连接请求。对于每一个需要服务的客户,都fork一个新进程来处理该客户的所有事务。这样一个进程只处理一个客户连接,编程就变得十分容易。   Indy服务器工作原理同Unix服务器十分类似,只是Windows不像Unix那样支持fork,而是支持线程,因此Indy服务器为每一个客户连接分配一个线程。   图1显示了Indy服务器的工作原理。Indy服务器组件创建一个同应用程序主线程分离的监听线程来监听客户连接请求,对于接受的每一个客户,都创建一个新的线程来为该客户提供服务,所有与这一客户相关的事务都由该线程来处理。   使用组件TIdThreadMgrPool,Indy还支持线程池。   线程与Indy客户程序   Indy客户端组件并未使用线程。但是在一些高级的客户程序中,程序员可以在自定义的线程中使用Indy客户端组件,以使用户界面更加友好。

5,402

社区成员

发帖
与我相关
我的任务
社区描述
Delphi 开发及应用
社区管理员
  • VCL组件开发及应用社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧