2025Äêjsµ÷ÓõçÄÔÉãÏñÍ·´úÂ루2025Äêǰ¶Ëµ÷ÓõçÄÔÉãÏñÍ·£©
hls.js°ó¶¨¶à¸öÉãÏñÍ·²½Öè
ʹÓÃhls.js°ó¶¨¶à¸öÉãÏñÍ·µÄ²½ÖèÖ÷Òª°üÀ¨ÒÔÏÂËĵ㣺°²×°hls.js£ºÊ×ÏÈ£¬ÐèÒªÔÚÏîÄ¿Öа²×°hls.js¿â¡£ÕâÊÇʵÏÖÊÓÆµÁ÷²¥·ÅµÄ»ù´¡¡£¿ÉÒÔͨ¹ýnpm½øÐа²×°£¬ÃüÁîΪnpm i hls.js -S¡£°²×°Íê³Éºó£¬¼´¿ÉÔÚÏîÄ¿ÖÐÒýÈ벢ʹÓÃhls.js¡£´´½¨HTML½á¹¹£ºÔÚHTMLÖУ¬ÎªÃ¿¸öÉãÏñÍ·´´½¨Ò»¸övideo±êÇ©£¬ÓÃÓÚÏÔʾÊÓÆµÁ÷¡£
º£¿µHLS²¥·Åʧ°Üͨ³£ÓëÉ豸ÅäÖá¢ÍøÂç»·¾³»ò²¥·ÅÆ÷¼æÈÝÐÔÏà¹Ø£¬¿Éͨ¹ýÒÔϲ½ÖèÅŲé½â¾ö£ºÉ豸¶Ë³£¼ûÔÒò¼°½â¾ö·½·¨ HLSÐÒé먦Æô£ºµÇ¼º£¿µÉ豸Web¹ÜÀí½çÃæ£¬½øÈ롸ÅäÖÃ-ÍøÂç-¸ß¼¶ÅäÖÃ-Á÷ýÌ塹£¬È·±£HLSÐÒ鿪¹ØÒÑ¿ªÆô£¬ÇҶ˿ڣ¨Ä¬ÈÏ8080£©Î´±»Õ¼Óá£
hls.js¹¦ÄÜÖ÷ÒªÓɶà¸öcontroller¸ºÔð£¬Èçabr-controller¡¢buffer-controller¡¢stream-controllerµÈ£¬¸÷×ÔÖ´ÐÐÊÓÆµÁ÷µÄÀÈ¡¡¢½âÎö¡¢²¥·ÅµÈÈÎÎñ£¬Í¨¹ýʼþ¼àÌýÍê³É¡£´Ó³õʼ»¯¼ÓÔØm3u8£¬µ½Ñ¡ÔñÂëÂʼÓÔØ¶ÔÓ¦tsÎļþ£¬ÔÙµ½½âÂëtsתΪmp4²¥·Å£¬Õû¸öÁ÷³Ì¸´ÔÓ£¬Éæ¼°¶à¸ö»·½Ú¡£
°²×°ÓëÅäÖÃÁ÷ýÌå·þÎñÆ÷£º°²×°EasyNVR·þÎñÆ÷£¬²¢ÅäÖÃÉãÏñ»úµÄRTSPÁ÷µØÖ·£¬Ó³ÉäUPnP¶Ë¿Ú£¬»ñÈ¡²¢²âÊÔRTSPµØÖ·ÊÇ·ñ¿ÉÓá£Ìí¼ÓÉãÏñÍ·ÐÅÏ¢²¢½øÐÐHLSתÂ룺ÔÚEasyNVRÖÐÌí¼ÓÉãÏñÍ·ÐÅÏ¢£¬ÅäÖÃתÂë²ÎÊý£¬½«RTSPÊÓÆµÁ÷ת»»ÎªHLS¸ñʽ¡£
ÈçºÎÓÃdjangoµ÷ÓÃÉãÏñÍ·(djangoÔõôʵÏÖÊÓÆµ²¥·Å)
£®ÓÃÉãÏñÍ·ÅÄÕÕ 2£®ÔÚÎı¾¿òÊäÈëÎļþÃû 3£®°´ÏÂÅÄÕÕ°´Å¥£¬»ñÈ¡ÉãÏñÍ·ÄÚµÄͼÏñ 4£®ÔÚÅÄϵÄÕÕÆ¬ÉÏÓÐÒ»ºì¿ò½ØÈ¡¹Ì¶¨´óСµÄÕÕÆ¬¡£5£®±£´æÎª±¾µØÍ¼ÏñΪjpg¸ñʽ£¬²»µÃѹËõ»ÖÊ ¼¼Êõ¹Ø¼ü£¬ÏàÐÅÒ²ÊÇ´ó¼Ò×î¸ÐÐËȤµÄ²¿·ÖÒ²¾ÍÊÇÈçºÎÈÃÒ»¸öÉãÏñÍ·¹¤×÷£¬²¢ÅÄÏÂÒ»ÕÅÕÕÆ¬ÁË¡£
Ò»ÖÖ³£¼ûµÄ·½·¨ÊÇʹÓÃVUE½áºÏDjango¿ò¼Ü£º»ñȡýÌåÊäÈëÐí¿É£ºÇ°¶Ëͨ¹ýµ÷ÓÃMediaDevices.getUserMedia£¨£© APIÀ´»ñÈ¡Óû§µÄýÌåÊäÈëÐí¿É£¬Õâ»áµ¯³öÒ»¸ö¶Ô»°¿òÈÃÓû§Ñ¡ÔñÊÇ·ñÔÊÐí·ÃÎÊÉãÏñÍ·¡£Éú³ÉMediaStream¶ÔÏó£ºÒ»µ©Óû§ÊÚȨ£¬Ç°¶Ë¾ÍÄÜ»ñÈ¡µ½Ò»¸ö°üº¬ÊÓÆµ¹ìµÀµÄMediaStream¶ÔÏó¡£
pip install python-dotenv´´½¨DjangoÊÓͼ ÔÚviews.pyÖбàдÊÓͼº¯Êý£¬Í¨¹ýos.getenv£¨£©¶ÁÈ¡.env±äÁ¿²¢·µ»ØJSONÏìÓ¦¡£
ÑéÖ¤ Python °æ±¾£ºÔÚ cmd ÖÐÊäÈëÒÔÏÂÃüÁȷÈÏ Python °æ±¾Îª 6£ºpython -VÈôδÏÔʾ°æ±¾ºÅ£¬Ðè¼ì²éϵͳ»·¾³±äÁ¿ PATH ÊÇ·ñ°üº¬ Python °²×°Â·¾¶£¨Èç C£ºUsersÓû§ÃûAnaconda3£©¡£
·½·¨Ò»£ºÍ¨¹ý ±êÇ©ÉùÃ÷È«¾Ö±äÁ¿ÊµÏÖ²½Ö裺ÔÚ Django Ä£°åÖУ¬Ê¹Óà ±êÇ©¶¨Òå JavaScript ±äÁ¿£¬²¢½« Django ±äÁ¿Öµ¸³¸øËüÃÇ¡£È·±£ ±êÇ©ÔÚÒýÈëÍⲿ JavaScript Îļþ֮ǰÉùÃ÷£¬ÒÔ±£Ö¤±äÁ¿¿É·ÃÎÊÐÔ¡£
ÐÔÄÜ¿¼Á¿£º¶¥²ãµ¼ÈëÓë¾Ö²¿µ¼Èë²îÒ켫СPythonµ¼Èë»úÖÆ£ºÊ״ε¼Èëʱ£¬Ä£¿é»á±»¼ÓÔØµ½sys.modulesÖУ¬ºóÐøµ¼ÈëÖ±½Ó´Ó»º´æ»ñÈ¡£¬ÎÞÐèÖØ¸´½âÎöÎļþ»òÖ´ÐдúÂë¡£Òò´Ë£¬ÎÞÂÛµ¼ÈëÓï¾äλÓÚÄ£¿é¶¥²ã»¹ÊǺ¯ÊýÄÚ²¿£¬Ê״μÓÔØºóµÄÐÔÄÜ¿ªÏú¼¸ºõÏàͬ¡£
JS´ò¿ªÉãÏñÍ·²¢½ØÍ¼ÉÏ´«
Ê×ÏÈ£¬´ò¿ªÉãÏñÍ·Ö÷ҪʹÓÃgetUserMedia·½·¨»ñȡýÌåÁ÷£¬È»ºó½«»ñÈ¡µÄÁ÷Ìí¼Óµ½video±êÇ©ÖУ¬ÒÔʵʱÏÔʾÉãÏñÍ·»Ãæ¡£½Ó×Å£¬½ØÈ¡Í¼Æ¬ÀûÓÃcanvas»æÍ¼¹¦ÄÜ¡£Í¨¹ý½«videoµÄÄÚÈÝ»æÖÆÖÁcanvasÖУ¬Íê³É½ØÍ¼²Ù×÷¡£Ö®ºó£¬½«½ØÍ¼µÄÄÚÈÝת»»Îªbase64¸ñʽ£¬ÉÏ´«ÖÁ·þÎñÆ÷¡£
ʵÏÖÍ·µÄ·½·¨´úÂë¡£±àдCSSÑùʽµÄ·½·¨´úÂë¡£htmlÉÏ´«´úÂë¡£JS´¦Àí·½·¨´úÂë¡£²âÊÔ½á¹ûÈçÏ¡£
ÍøÒ³µ÷ÓÃÉãÏñÍ·£¬ºÜ¶àä¯ÀÀÆ÷²»Ö§³ÖµÄ¡£Ë¼Â·ÊÇ£ºµ÷ÓÃÉãÏñÍ·ÅÄÕպ󣬻ñÈ¡µ½Í¼Æ¬µÄµØÖ·£¬»òÕßÎļþ¶þ½øÖÆÄÚÈÝ£¬Òì²½´«Êäµ½·þÎñÆ÷¡£ÉÏ´«Ò²ÓÐÁ½ÖÖ·½·¨°É£¬Ò»ÖÖÊÇÓÃH5µÄfileÀàÐÍinput±êÇ©£¬Í¨¹ý±íµ¥´«µÄ¡£Ò»ÖÖÊÇͨ¹ýjs°ÑÎļþת³Ébase64±àÂë¸ñʽ´«ÊäµÄ¡£
H5Ò³ÃæÖÐʵÏÖɨÂëºóÌá½»µ½µçÄÔÉϵŦÄÜ£¬¿ÉÒÔͨ¹ýµ÷ÓÃÊÖ»úÉãÏñͷɨÂ룬²¢ÀûÓÃWebSocket¼¼Êõ»ò´î½¨Node.js·þÎñÆ÷À´ÊµÏÖ¡£¾ßÌå²½ÖèÈçÏ£ºµ÷ÓÃÊÖ»úÉãÏñÍ·½øÐÐɨÂ룺ÔÚH5Ò³ÃæÖУ¬Ê¹ÓÃHTML5µÄÏà¹ØAPIºÍµÚÈý·½¿â£¨Èçhtml5-qrcode£©À´µ÷ÓÃÊÖ»úÉãÏñÍ·½øÐÐɨÂë¡£
ÔÚÅÄÕÕÒ³ÃæjsÖУ¬ÊµÏÖÅÄÕÕ¡¢ÖØÅÄ¡¢Çл»ÉãÏñÍ·ºÍÉÏ´«ÕÕÆ¬µÄ¹¦ÄÜ¡£µã»÷ÅÄÕÕ°´Å¥£¬Ê¹ÓÃwx.createCameraContext£¨£©´´½¨Ïà»úÉÏÏÂÎÄ£¬µ÷ÓÃtakePhoto·½·¨ÅÄÕÕ¡£µã»÷ÖØÅİ´Å¥£¬ÖØÖÃÅÄÕÕ״̬¡£µã»÷Çл»ÉãÏñÍ·°´Å¥£¬Çл»Ç°ºóÉãÏñÍ·¡£µã»÷ÉÏ´«ÕÕÆ¬°´Å¥£¬Ê¹ÓÃwx.uploadFile£¨£©ÉÏ´«ÕÕÆ¬£¬Ìá½»´ò¿¨Êý¾Ý¡£