打开http连接进行音频流传输

如何解决打开http连接进行音频流传输

| 我正在尝试创建一个用于播放现场广播的应用程序。我正在使用以下方法打开http连接,并为此网址指定“ http://64.62.xxx.xxxx:xxx / \” 但是我得到了nullpointer异常,
                public InputStream OpenHttpConnection(String urlString) throws IOException
{
    InputStream in = null;
    int response = -1;

    URL url = new URL(urlString); 
    URLConnection conn = url.openConnection();


    if (!(conn instanceof HttpURLConnection))                     
        throw new IOException(\"Error connecting\");

    try{
        HttpURLConnection httpConn = (HttpURLConnection) conn;
        httpConn.setAllowUserInteraction(false);
        conn.setDoInput(true);
        httpConn.setInstanceFollowRedirects(true);
        httpConn.setRequestMethod(\"GET\");
        httpConn.connect(); 
        response = httpConn.getResponseCode();
        System.out.println(\"Response : \"+response);
        if (response == HttpURLConnection.HTTP_OK) 
        {
            in = httpConn.getInputStream();
        }     
    }
    catch (Exception ex)
    {
        throw new IOException(\"Error connecting\");            
    }
    return in;     
}
有没有其他方法可以从这种类型的网址流式传输数据,或者我需要在上述方法中添加其他内容? 我创建了MediaPlayer的实例。我的logcat显示以下错误: 05-25 15:50:08.067:DEBUG / MediaPlayer(1032):无法在客户端打开文件,尝试在服务器端 05-25 15:50:08.189:WARN / MediaPlayer(1032):信息/警告(1、26) 05-25 15:50:08.217:错误/ PlayerDriver(31):命令PLAYER_INIT完成并显示错误或信息PVMFFailure 05-25 15:50:08.217:错误/ MediaPlayer(1032):错误(1,-1) 05-25 15:50:08.237:WARN / PlayerDriver(31):PVMFInfoErrorHandlingComplete 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):创建失败: 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):java.io.IOException:准备失败。:status = 0x1 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于android.media.MediaPlayer.prepare(本机方法) 05-25 15:50:08.357:调试/ MediaPlayer(1032):位于android.media.MediaPlayer.create(MediaPlayer.java:608) 05-25 15:50:08.357:调试/ MediaPlayer(1032):位于android.media.MediaPlayer.create(MediaPlayer.java:585) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于org.sample.AudioPlayer.AudioPlayer.PlayRadio(AudioPlayer.java:190) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于org.sample.AudioPlayer.AudioPlayer.access $ 1(AudioPlayer.java:123) 05-25 15:50:08.357:调试/ MediaPlayer(1032):在org.sample.AudioPlayer.AudioPlayer $ 3.onClick(AudioPlayer.java:77) 05-25 15:50:08.357:调试/ MediaPlayer(1032):在android.view.View.performClick(View.java:2364) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于android.view.View.onTouchEvent(View.java:4179) 05-25 15:50:08.357:调试/ MediaPlayer(1032):位于android.widget.TextView.onTouchEvent(TextView.java:6541) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于android.view.View.dispatchTouchEvent(View.java:3709) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):位于android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 05-25 15:50:08.357:调试/ MediaPlayer(1032):在com.android.internal.policy.impl.PhoneWindow $ DecorView.superDispatchTouchEvent(PhoneWindow.java:1659) 05-25 15:50:08.357:调试/ MediaPlayer(1032):在com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107) 05-25 15:50:08.357:调试/ MediaPlayer(1032):位于android.app.Activity.dispatchTouchEvent(Activity.java:2061) 05-25 15:50:08.357:调试/ MediaPlayer(1032):在com.android.internal.policy.impl.PhoneWindow $ DecorView.dispatchTouchEvent(PhoneWindow.java:1643) 05-25 15:50:08.357:调试/ MediaPlayer(1032):在android.view.ViewRoot.handleMessage(ViewRoot.java:1691) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):在android.os.Handler.dispatchMessage(Handler.java:99) 05-25 15:50:08.357:调试/ MediaPlayer(1032):位于android.os.Looper.loop(Looper.java:123) 05-25 15:50:08.357:调试/ MediaPlayer(1032):位于android.app.ActivityThread.main(ActivityThread.java:4363) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):at java.lang.reflect.Method.invokeNative(本机方法) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):at java.lang.reflect.Method.invoke(Method.java:521) 05-25 15:50:08.357:调试/ MediaPlayer(1032):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:860) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 05-25 15:50:08.357:DEBUG / MediaPlayer(1032):在dalvik.system.NativeStart.main(本机方法) 05-25 15:51:05.277:DEBUG / dalvikvm(97):GC在127ms内释放了14个对象/ 560个字节 05-25 15:51:13.280:DEBUG / AndroidRuntime(1032):关闭VM 05-25 15:51:13.280:WARN / dalvikvm(1032):threadid = 3:线程以未捕获的异常退出(group = 0x4001b188) 05-25 15:51:13.280:错误/ AndroidRuntime(1032):未捕获的处理程序:由于未捕获的异常而导致线程主退出 谢谢!!     

解决方法

首先检查来自服务器的连接,您可以使用HTTP调试器 因为你想播放音频 创建一个媒体播放器实例并在SetDataSource中设置filedescriptor
m_player.setOnPreparedListener(this);
m_player.setAudioStreamType(AudioManager.STREAM_MUSIC);
m_player.setDataSource(filedescriptor fd);
m_player.prepareAsync();
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-