我目前有一个webview
,当你按下mp3链接,mp3将开始播放。我们最近更改了所有的链接,它们现在是"https"而不是"http"。我从日志中收到的错误如下:
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): FATAL EXCEPTION: main
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): android.content.ActivityNotFoundException: No Activity found to handle Intent { act=android.intent.action.VIEW dat=https://s3.amazonaws.com/StopDropRave/Week+of+August+8/Flawless+ft.+Army+of+Karmen+-+L.I.E.+%28Love+Automatic+Dubstep+Remix%29.mp3 typ=audio/* }
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1409)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at android.app.Instrumentation.execStartActivity(Instrumentation.java:1379)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at android.app.Activity.startActivityFromChild(Activity.java:3067)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at android.app.Activity.startActivityForResult(Activity.java:2847)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at android.app.Activity.startActivity(Activity.java:2933)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at ravebox.dev.sdr.BlogActivity$HelloWebViewClient$1.onClick(BlogActivity.java:158)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:159)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at android.os.Handler.dispatchMessage(Handler.java:99)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at android.os.Looper.loop(Looper.java:123)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at android.app.ActivityThread.main(ActivityThread.java:3835)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at java.lang.reflect.Method.invokeNative(Native Method)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at java.lang.reflect.Method.invoke(Method.java:507)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
08-09 17:26:59.060: ERROR/AndroidRuntime(5574): at dalvik.system.NativeStart.main(Native Method)
我不知道是不是因为https。不知道。什么好主意吗?由于
这是我对这个特定活动的清单的一部分:
<activity android:name=".BlogActivity"
android:label="@string/app_name"
android:screenOrientation="portrait">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
这里也是我处理侦听部分的代码的一部分。它实际上打开了一个对话框,用户可以在其中选择收听或下载。下载工作完美,但监听不改变链接到https后。
private class HelloWebViewClient extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(final WebView view,
final String url) {
view.loadUrl(url);
view.getSettings().getAllowFileAccess();
view.getSettings().setJavaScriptEnabled(true);
view.getCertificate();
// load the dropbox files so people can listen to the track
if (url.startsWith("https://") && url.endsWith(".mp3")) {
view.getCertificate();
progressWebView.dismiss();
progressWebView.cancel();
/*blogDialog.setButton("Listen",
new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog,
int which) {
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setDataAndType(Uri.parse(url), "audio/*");
view.getContext().startActivity(intent);
}
});*/
blogDialog.setButton2("Download",
new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog,
int which) {
sdrUrl = url.toString();
new DownloadFile().execute();
}
});
blogDialog.show();
} else {
return super.shouldOverrideUrlLoading(view, url);
}
return true;
}
}
看起来你有"BlogActivity",你正试图从中播放任何音频文件。默认情况下,Android音乐播放器应用程序将用于播放链接中的数据。音乐播放器应用程序中的流媒体播放器活动的数据方案设置为"http"只有,因此不会播放内容从您的新链接与"https"方案。
SO已经有这样的查询,这里是链接,从https链接流音频问题
这就是为什么下载工作正常,但播放不。因此,我建议您在播放之前将文件下载到设备上的临时位置