Проблема при загрузке на YouTube с помощью Google API Java Client - PullRequest
1 голос
/ 07 марта 2011

Я использую клиентскую библиотеку Java API Google (http://code.google.com/p/google-api-java-client/) для загрузки видео на телефон Android на YouTube.

Вот код, который у меня есть:

// Create the meta data
Entry entry = new Entry();
entry.group = new MediaGroup();
entry.group.title = "test title";
entry.group.description = "test description";
entry.group.category = new MediaCategory();
entry.group.category.Cat = "People\n";

XmlNamespaceDictionary namespaceDictionary = Util.NAMESPACE_DICTIONARY;

AtomContent aContent = new AtomContent();
aContent.entry = entry;
aContent.namespaceDictionary = namespaceDictionary;

// Create the actual video data
InputStreamContent bContent = new InputStreamContent();
bContent.inputStream =
    context.getContentResolver().openInputStream(media);
bContent.type = context.getContentResolver().getType(media);
bContent.length = videoAsset.getLength();

// Build up the POST request
MultipartRelatedContent multiContent = new MultipartRelatedContent();
multiContent.parts.add(aContent);
multiContent.parts.add(bContent);


HttpRequest request = transport.buildPostRequest();
request.url = YouTubeUrl.uploadUrl();
GoogleHeaders headers = (GoogleHeaders) request.headers;
headers.setSlugFromFileName("mytest.3gpp");
request.content = multiContent;
request.headers.contentType = multiContent.getType();

request.execute();

К сожалению, я получаю исключение при вызове request.execute ():

03-06 23:28:58.887: WARN/System.err(18923): com.google.api.client.http.HttpResponseException: 415 Unsupported Media Type
03-06 23:28:58.897: WARN/System.err(18923):     at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:221)
03-06 23:28:58.897: WARN/System.err(18923):     at com.abless.vidshare.YouTubeAPI.upload(YouTubeAPI.java:118)
03-06 23:28:58.897: WARN/System.err(18923):     at com.abless.vidshare.VidShare.onActivityResult(VidShare.java:185)
03-06 23:28:58.897: WARN/System.err(18923):     at android.app.Activity.dispatchActivityResult(Activity.java:3931)
03-06 23:28:58.907: WARN/System.err(18923):     at android.app.ActivityThread.deliverResults(ActivityThread.java:3730)
03-06 23:28:58.907: WARN/System.err(18923):     at android.app.ActivityThread.handleSendResult(ActivityThread.java:3776)
03-06 23:28:58.907: WARN/System.err(18923):     at android.app.ActivityThread.access$2800(ActivityThread.java:135)
03-06 23:28:58.907: WARN/System.err(18923):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2166)
03-06 23:28:58.907: WARN/System.err(18923):     at android.os.Handler.dispatchMessage(Handler.java:99)
03-06 23:28:58.907: WARN/System.err(18923):     at android.os.Looper.loop(Looper.java:144)
03-06 23:28:58.907: WARN/System.err(18923):     at android.app.ActivityThread.main(ActivityThread.java:4937)
03-06 23:28:58.907: WARN/System.err(18923):     at java.lang.reflect.Method.invokeNative(Native Method)
03-06 23:28:58.917: WARN/System.err(18923):     at java.lang.reflect.Method.invoke(Method.java:521)
03-06 23:28:58.917: WARN/System.err(18923):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
03-06 23:28:58.917: WARN/System.err(18923):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
03-06 23:28:58.917: WARN/System.err(18923):     at dalvik.system.NativeStart.main(Native Method)

Что я делаю не так? Похоже, Content-Length не определяется автоматически MultipartRelatedContent, может быть, это проблема? У меня быловзгляните на код реализации, и MultipartRelatedContent.getLength () вернет -1, что не очень полезно.

Кому-нибудь удалось использовать клиентскую библиотеку Java API Google для успешной загрузки видео на YouTube?

Спасибо.

-Alexander

Редактировать: даже если я заполню часть Content-Length, я все равно получаю ту же ошибку (415 Unsupported Media Type), так что это нене решить. Кажется, что заголовок POST неверен?

Ответы [ 2 ]

0 голосов
/ 18 мая 2011

Если кого-то интересует пример использования нового google-api-java-client, я прикрепил его к bug 16 .

0 голосов
/ 08 марта 2011

Сам разобрался ... оказывается, YouTubeURL использовал опцию JsonC. Закомментировав эту строку, все работало прекрасно.

...