Android Volley StringRequest有时无法正常工作

时间:2019-03-22 03:56:24

标签: android android-volley

我正在使用以下代码从API获取一些本地视频网址。

public void getVideoAds(String serverURL){
    String url = "http://"+serverURL+"/video/";

    StringRequest stringRequest = new StringRequest(url, new Response.Listener<String>() {
        @Override
        public void onResponse(String response) {
            try {
                JSONObject jsonObj = new JSONObject(response);
                JSONObject defaultObj = jsonObj.getJSONObject("default");
                JSONArray videoObj = jsonObj.getJSONArray("videos");

                defaultUrl = defaultObj.getString("url");

                for (int i = 0; i < videoObj.length(); i++){
                    JSONObject video = videoObj.getJSONObject(i);

                    VideoAd v = new VideoAd();
                    v.setName(getVideoNameFromLink(video.getString("url")));
                    v.setUrl(video.getString("url"));
                    v.setVideoId(video.getInt("id"));
                    v.setVersion(video.getInt("version"));
                    v.setLocalPath("");

                    vidArrLst.add(v);
                }

                playLoopVideo();
            } catch (Exception e) {
                Log.d(TAG, "getVidAds res err: " + e.getMessage());
            }

        }
    }, new Response.ErrorListener() {
        @Override
        public void onErrorResponse(VolleyError error) {
            Toast.makeText(ctx, "VideoAds Err: "+error.getLocalizedMessage(), Toast.LENGTH_LONG).show();
            Log.d(TAG, "getVidAds err: " + error.getMessage());
        }
    });

    queue.add(stringRequest);
}

onCreate()中,我这样初始化RequestQueue

queue = Volley.newRequestQueue(this);

有时候,getVideoAds()有效。有时,它不起作用。同样奇怪的是,即使在Exception上使用了catch(),我也没有收到任何错误。如果不起作用,请执行Clean Project -> Rebuild Project -> Make Project,然后再次起作用。但是经过几次构建之后,大部分只是再构建1次,它再次停止工作。

如果您想了解有关playLoopVideo的更多信息,请查看我制作的SO question。这与我的应用中的视频播放有关。如果我尝试在getVideoAds的onResponse中播放视频,则当前无法播放视频,这就是为什么我对此提出了不同的问题,因为也许如果我修复Volley,视频将再次播放。 / p>

如果需要,这是我的build.gradle(app)。

apply plugin: 'com.android.application'

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "biz.net.com.streamer"
        minSdkVersion 17
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
    compileOptions {
        sourceCompatibility 1.8
        targetCompatibility 1.8
    }
}

dependencies {
    implementation fileTree(include: ['*.jar'], dir: 'libs')
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
    implementation 'com.google.android.exoplayer:exoplayer:2.9.1'
    implementation 'com.android.volley:volley:1.1.1'
}

更新:

这真的很奇怪。我的getVideoAds()方法在另一个方法中调用,该方法调用在同一服务器上的不同API上生成StringRequest的方法。为了使其更容易理解,下面是它的代码。

private void getAdvertisements(final String serverURL){
    getVideoAds(serverURL);
    getMessageAds(serverURL);

    new android.os.Handler().postDelayed(
            new Runnable() {
                public void run() {
                    Log.d(TAG, "Updating ads marquee");
                    getMessageAds(serverURL);
                }
            },
            300000);
}

当前,getMessageAds()调用的API不会返回任何内容。我试图评论它和下面的处理程序,终于奏效了。即使是视频播放也可以。然后,我尝试取消注释getMessageAds()并在服务器上添加一些消息,一切正常。但是删除邮件后,它将再次停止工作。

发生这种情况的原因可能是什么?

1 个答案:

答案 0 :(得分:0)

在齐射中添加

  stringRequest.setRetryPolicy(DefaultRetryPolicy(20000, 3, 1.0f));