gpt4 book ai didi

c# - 带有 Visual Studios 2010 的 .NET 4.0 中的 ONVIF 身份验证

转载 作者:可可西里 更新时间:2023-11-01 08:43:52 33 4
gpt4 key购买 nike

我的任务是尝试与建筑物中的 ONVIF 摄像头建立通信,最终升级公司的家庭自动化解决方案以自动识别 ONVIF 摄像头并能够设置它们并使用它们的服务。

我已经能够通过这种方式收集一些基本信息,例如它的型号、MAC 地址和固件版本:

    EndpointAddress endPointAddress = new EndpointAddress("<mycameraurl:<mycameraport>/onvif/device_service");
CustomBinding bind = new CustomBinding("DeviceBinding");
DeviceClient temp = new DeviceClient(bind, endPointAddress);
String[] arrayString = new String[4];
String res = temp.GetDeviceInformation(out arrayString[0], out arrayString[1], out arrayString[2], out arrayString[3]);
MessageBox.Show("Model " + arrayString[0] + ", FirmwareVersion " + arrayString[1] + ", SerialNumber " + arrayString[2] + ", HardwareId " + arrayString[3]);

我的 app.config 文件中有 customBinding 的 xml 规范:

  <customBinding>
<binding name="DeviceBinding">
<textMessageEncoding maxReadPoolSize="64" maxWritePoolSize="16"
messageVersion="Soap12" writeEncoding="utf-8">
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
</textMessageEncoding>
<httpTransport manualAddressing="false" maxBufferPoolSize="524288"
maxReceivedMessageSize="65536" allowCookies="false" authenticationScheme="Anonymous"
bypassProxyOnLocal="false" decompressionEnabled="true" hostNameComparisonMode="StrongWildcard"
keepAliveEnabled="false" maxBufferSize="65536" proxyAuthenticationScheme="Anonymous"
realm="" transferMode="Buffered" unsafeConnectionNtlmAuthentication="false"
useDefaultWebProxy="true" />
</binding>
</customBinding>

我的问题是我不可能深入了解我可以问相机的内容。我尝试任何操作都会收到“400 - 错误请求”错误,根据我的阅读,这是因为我需要处理相机的身份验证。

问题是,我发现的关于 WS-Security(似乎由 ONVIF 使用)的所有内容都非常、非常困惑,有很多不同的解决方案,但没有一个真正适合我。例如,this post here 让它听起来很简单,但我已经尝试创建一个 UserNameSecurityToken,但我仍然收到 400 个错误的请求错误。因为我不知道那是不是因为我的 token 系统写错了,如果是因为相机不支持我尝试做的事情。

我已经尝试过 WSHttpBinding 并将其置于用户名模式,但是使用 WSHttpBinding 破坏了我能够创建的基本信息发现(带有 MustUnderstand 错误)...

对我有什么建议吗?简单的 WS-Security/.NET、C#/ONVIF 教程,一切都会被接受。

最佳答案

好的:

EndpointAddress serviceAddress = new EndpointAddress("<mycameraurl:<mycameraport>/onvif/device_service");

HttpTransportBindingElement httpBinding = new HttpTransportBindingElement();

httpBinding.AuthenticationScheme = AuthenticationSchemes.Digest;

var messageElement = new TextMessageEncodingBindingElement();

messageElement.MessageVersion = MessageVersion.CreateVersion(EnvelopeVersion.Soap12, AddressingVersion.None);

CustomBinding bind = new CustomBinding(messageElement, httpBinding);

// Add our custom behavior - this require the Microsoft WSE 3.0 SDK

PasswordDigestBehavior behavior = new PasswordDigestBehavior(CameraASCIIStringLogin, CameraASCIIStringPassword);

DeviceClient client = new DeviceClient(bind, serviceAddress);

client.Endpoint.Behaviors.Add(behavior);

// We can now ask for information

client.GetSystemDateAndTime();

client.GetNetworkInterfaces();

client.GetScopes();

client.GetRelayOutputs();

client.GetWsdlUrl();

问题在于,除了最简单的信息之外,相机在提供任何信息之前都需要进行身份验证,而最棘手的部分是最终捕获一个有效的 xml onvif 消息并在我自己的软件中重新创建它。

关于c# - 带有 Visual Studios 2010 的 .NET 4.0 中的 ONVIF 身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5638247/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com