博客
关于我
基于librtmp客户端记录(H264+AAC)
阅读量:363 次
发布时间:2019-03-04

本文共 2532 字,大约阅读时间需要 8 分钟。

  基于librtmp开发rtmp客户端的demo,主要是按照雷神的demo(见5.1)来修改,修改后的demo能将获取到的音视频数据写成h264文件及aac文件。

1、flv格式

  介绍flv格式的博客有很多,个人觉得5.2及5.3结合起来看比较好,其中5.2的script tag应该得值是12才是对的。摘录些重要的。

在这里插入图片描述
  flv的tag类型有三种,video(9), audio(8), script_data(12)。
  tag的组成如下:
在这里插入图片描述
  如果视频格式是AVC(h264)的话,VideoTagHeader会多出4个字节的信息分别是一字节的AVCPacketType 和3字节的CompositionTime。
来自参考5.3的video tag及audio tag的图。
在这里插入图片描述
在这里插入图片描述

2、注意

  h264的sps及pps数据在发送视频帧之前会首先单独发送过来,需要做保存,因为有些rtmp serevr不会在每一个I帧前添加这些信息。

  收到的AAC音频需要根据解析到AAC格式信息添加adts头部,代表AAC音频采样率的2bit其值总是3

3、添加ADTS头部

/* *注意,这里的packetLen参数为raw aac Packet Len + 7; 7 bytes adts header */static void addADTStoPacket(char* packet, int packetLen, int frequence) {      int profile = 2;  //AAC LC,MediaCodecInfo.CodecProfileLevel.AACObjectLC;      int freqIdx = -1;  //48K, 见后面注释avpriv_mpeg4audio_sample_rates中32000对应的数组下标,来自ffmpeg源码      int chanCfg = 2;  //见后面注释channel_configuration,Stero双声道立体声     int avpriv_mpeg4audio_sample_rates[] = {          96000, 88200, 64000, 48000, 44100, 32000,                  24000, 22050, 16000, 12000, 11025, 8000, 7350      };      for(int i = 0; i < 13 ; ++i)      {          if(frequence == avpriv_mpeg4audio_sample_rates[i])          {              freqIdx = i;              break;          }      }          if(freqIdx == -1)     {         printf("Invaild frequence [%d] \n", frequence);         return ;     }      /*int avpriv_mpeg4audio_sample_rates[] = {          96000, 88200, 64000, 48000, 44100, 32000,                  24000, 22050, 16000, 12000, 11025, 8000, 7350      };      channel_configuration: 表示声道数chanCfg      0: Defined in AOT Specifc Config      1: 1 channel: front-center      2: 2 channels: front-left, front-right      3: 3 channels: front-center, front-left, front-right      4: 4 channels: front-center, front-left, front-right, back-center      5: 5 channels: front-center, front-left, front-right, back-left, back-right      6: 6 channels: front-center, front-left, front-right, back-left, back-right, LFE-channel      7: 8 channels: front-center, front-left, front-right, side-left, side-right, back-left, back-right, LFE-channel      8-15: Reserved      */      // fill in ADTS data      packet[0] = 0xFF;      packet[1] = 0xF1;      packet[2] = (char)(((profile-1)<<6) + (freqIdx<<2) +(chanCfg>>2));      packet[3] = (char)(((chanCfg&3)<<6) + (packetLen>>11));      packet[4] = (char)((packetLen&0x7FF) >> 3);      packet[5] = (char)(((packetLen&7)<<5) + 0x1F);      packet[6] = 0xFC;}

4、

  centos6.9上实现的demo,能同时写下flv,h264及AAC文件(只针对48KHZ ,AAC-LC,16bit采样位数)

5、参考

《1》、

《2》、
《3》、
《4》、
《5》、
《6》、
《7》

转载地址:http://htoe.baihongyu.com/

你可能感兴趣的文章
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南002---大数据之Nifi工作笔记0069
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>