2013-10-20 53 views
1

我有一个小型的c程序,它与我的安全DVR进行连接并进行身份验证,后者又开始通过套接字向我发送数据。我可以在端口5000或端口80上连接,发送不同的认证方法以开始接收视频/图像。我的问题是;首先,我对c是新手,并且对如何处理通过套接字接收的数据感到迷茫。这是我发送的用于验证的数据。通过tcp socket与c处理镜像

char authenticate[] = { 
    0x31, 0x31, 0x31, 0x31, 0x88, 0x00, 0x00, 0x00, 
    0x01, 0x01, 0x00, 0x00, 0x88, 0x7d, 0xa6, 0x47, 
    0x0c, 0x00, 0x00, 0x00, 0x78, 0x00, 0x00, 0x00, 
    0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 
    0x61, 0x64, 0x6d, 0x69, 0x6e, 0x00, 0x00, 0x00, 
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 
    0x00, 0x00, 0x00, 0x00, 0x31, 0x32, 0x33, 0x34, 
    0x35, 0x36, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 
    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 
    0x43, 0x6f, 0x6c, 0x74, 0x6f, 0x6e, 0x73, 0x2d, 
    0x4d, 0x61, 0x63, 0x42, 0x6f, 0x6f, 0x6b, 0x2d, 
    0x50, 0x72, 0x6f, 0x2e, 0x6c, 0x6f, 0x63, 0x61, 
    0x6c, 0x00, 0x00, 0x00, 0x35, 0x34, 0x32, 0x36, 
    0x39, 0x36, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00 
}; 

    x = sendto(sockfd, authenticate, sizeof(authenticate), 0, 
    (struct sockaddr*)&servaddr, sizeof(servaddr)); 

我然后用

while(1) 
{ 
    n = recvfrom(sockfd, data, 2048, 0, NULL, NULL); 

recieving数据当我通过连接http端口80这是我接收图像数据:

Content-length: 2153 
Content-type: image/jpeg 

ˇÿˇ‡JFIFHHˇ€Cˇ€Cˇ¿#ˇƒ 
    ˇƒ8 2A!$X"#3QRTqëîóò“’÷ˇƒˇƒ@ 
     !1A"2QRqrë#SacÅ°¢≥—“ÒBCstÇí¥”ˇ⁄  ?e›n◊}mÀ⁄ÔÅ≥j¿ò[0ÂáֱNU…9'*‚®@ô &yéïùr‰Ù®{ï“däŒÆl$Kkë  R,√fƒSl—EX 
    z \û£≠âflüÈ‚≠ê*àÉ*—1E;q}Ì[email protected]>øÆÂòŸR≠^Ì˝çò ı;R∆b¡»ü>aÊ∫a˙5KKüz∑¶Î´D“≤κl∂ÎÓ„∆Àn∫¥•sh8vß4≠äöûñy‰H¢çyºí0TQrÏ@π dÅèåfi*XY*F¨Óƒl™¢‰˝S^sgh]î…flzXNü‡†2∑ñæ5t€Tp`qìåos◊iGùjˆ˙+FÈ™‚‘_§≈[”Jˇ  *•<*´∆≥ÁpVGfl 
    ï¶ñ—€{ñgíJmd*ôï„å[YT-J†∞π∂¯ë…{¶dyÓaÓhå©!øg⁄∆™≤È: 
    ≥Ô`Mú)∞ÚÌǯhˇÿ„Tø∑,9˛õ°˛ıØö~ø«ûÔ˝˙aa{ÜÔû÷Èé‡ÂΩk÷ºµ\sÉÒ¬XÓ∞`¯⁄X“">eäÅœ»G¡ìöÜ"˘mütòÅtuÓbÌh;vB1dflL ∂) 
    ´È 
    Hm∂Í 
    Ω¡î*Ä≤e‘nÄï‘HΩ…77ÙIè6%â%ãµ"T¿n¢Í3%‹zj#™:”ÂmR˛=L ZsZ[_ïz±»r…™2®ú.«]∑$q¢1)ùftÙ˘îà[q£°Îü&%Ï÷@á∂¿ôEy!ËÇJ0‚‚j»¥|∆fi–ü5"èRj›D˘„õUäú≥û>•«bdôãq]Ö$2ˆ„Gc#,ó±Ò<√-p}ZÍSÛ               £ëóŒsäóNçı≠◊òÊö•mÈÇ_W„Y2∆∫9œxπŸ¸*±’dË⁄1(¸05{üfW∆Éû 
    ‘ÿSÑ‘„û.JTÓ9˙Ìø˝∆º=∆  ¬ï∆h≥!`uˆ’Uçõèd„Ï…ı®*GÕıŸ6iíÆiñ¶’ØmBë‰WáÈö˛â‚ı∞>Ó˛◊_Â’ˇπ?º”˘øh~8TÔÕ/ùˆO¬Ewü^◊]…6 
    ÕïÊ«p2ˆ◊ä”õU÷ËÖˆ◊䲲ãk–«_2ûk4Éÿ‰aÖƒîP∑ùg⁄†·¢µ’ÂS÷}XNï¯5GWæßGk”óS8fòˇ;˝âp;≈“ƒ5ˇ˜„Éû·&Áa¨ö2tÿ±íÉìcÇeÓ"¬Â„(8¯:øØíM £rmfiá~≠æ(:oT/U≤/täó  U√ñT0ëªÕ  ê’¢ví[email protected]˙‚ìO7ÖÆÒ‘D<[email protected];F®—yÑmPǃ5É+FZÀ"8≥-˙7"ç–ãm{Å∑Öunü»à·®icëcoDìf¬·ñ)!å A¡ñÂNrx√aeP\ZM®£  ‘Y\<kJÿ‚’Ó#„Œª+â3 
    ¨π©%Uü±Àñ¨œò§S2àŸßUJjwûYã[email protected]Ç∆˚¶&hr⁄xj¬ì È™sàK-… 28Fm‡Ôr√û  8Qè 
    ª∑ØP ptt£‚N—Œ∆Iπ ıo«Y{Èe.U[´‰•ı∫ÎæöÙU’‘…)¶Gy 
    †“ä]ãä6U≤Å∞b 7X„  ™˙@ÓMÖ∑>_ó 
    =fiÔ>·π∂ˇ÷ãÎΩfl«Y!µÎô≥—ß;¨J™èΩ|tLoîRˇM›[email protected]ŸÍ±≈±Ê∏Ï~qkãsv≈Xõ‰í∞Lπ/cR,j*6.Sí„ÿ˘fÑ»7f|_™≥RçÿíE°°bã {{Ïõç#·Ãæ:7çú√´u  o 
    ⁄N¨Ω\€ù◊K,Z4àÕ8N\˙πÍë’D∫vbfl∏¢>äz.¸¨⁄Ä‘°dx≈ªàˆÕ45‡ßõub-ü%TVTN8⁄∞¨≤µÁñÜD[;o—˘ƒNˇóóØ[ò;´¡O*∫¿ƒ©∏2ߘG#20˘H∆µªú’2€∂O°Â⁄Ùb®äÌ/hÿQÁXÓŸJzB¬Öw]Ù2ÿ—⁄§∆«gÜö·´˚Ëãt‚+˛Iì¯∂⁄nÎ{ºVʬ)aà∆´°ÀÚËÃkr÷â„ç^1©ôæ 
    óv'ô8∆ãπkB˙цπ¯zÉsÀpv;Ã]ÓI€[Ìj/˙A≤øÒ}O˚ËS|Dûƒˇ¶3=ÓÍæ6?Ú…å!¥›¨Ûˆ¸f…€·I~à≥  g>∆®‰√Û0≥30®Æ) èMÖçGÃ∑dÑÖ∞¥Œéf≥ÔyµE¢Yå.õ·ç+r˙ú ≤ZÄP ‰y¨Km⁄±~ävfl¡'I+b»Ñî[ö<¬  æñ8raEãk 

我不能确定如果此数据是一些奇怪的编码,或者如果它需要处理某种方式使其有效。我已经搜索了没有运气或如何正确做到这一点的例子。如果我通过数据端口(端口5000通过发送通过而不是图像)数据看起来几乎相同,但我知道它可能是处理或未处理的H.246视频数据。

+0

只能通过80端口吗?如果从非保留端口连接(如5055),会发生什么情况?同时向我们展示如何在接收端处理阵列数据' – sukhvir

+0

看起来像您试图将二进制数据可视化为字符......您能分享您的输出方法吗? – xmoex

+0

唯一可用的其他端口是5000,用于将视频发送到客户端。当我使用端口5000时,它向我发送有关每个摄像机设置的信息,然后向我发送与上述图像数据几乎相同的视频数据。我没有访问服务器端代码,这是另一个问题。 – csechols

回答

0

原始数据的图像。它在终止标题的空白行之后开始。

代码:

n = recvfrom(sockfd, data, 2048, 0, NULL, NULL); // might as well replace with read(). 
// use a much larger buffer, ideally large enough to fit largest possible whole image 

headers_end_str = "\r\n\r\n"; 
headers_end_position = strstr(data, headers_end_str); 
headers_end_position += strlen(headers_end_str); 

if (headers_end_position > n) { ... } // handle errors 

FILE* fh = fopen("image.jpg", "wb"); 

int result = fwrite(&(data[ headers_end_position), n - headers_end_position, 1, fh); 
// check result for errors 

// continue reading from socket and writing to file, subsequent reads do not have headers 

这应该让你开始,你需要微调读数的其它数据,并且还错误处理和文件的末尾。

但是,即使在完成所有这些之前,您应该可以运行“file -s image.jpg”(在linux或cygwin上),它会告诉你它是一个JPEG图像。

0

我使用WireShark来监视DVR和它的Web浏览器插件客户端之间的通信,并且验证消息标题与您的文章(0x31 0x31 0x31 0x31 ...)类似。你是如何构建这个数组的?我搜索了很多这个协议文档,但我没有找到。

在我的情况下,我做的端口7171(这是一个DVR设置)的请求。我还用了一段时间(真)来监听这个端口,服务器给我发送一个h264流。

问题是,流是不是像rtps协议描述,看到这个伟大的post。在我们的例子中,我们必须首先解析一种专有标头(以0x31 0x31 0x31 0x31开始)来标记帧,sps和pps。