1

我有一个由 py​​thon/django 驱动的应用程序,它具有可以使用 gdata.youtube python 库将视频发布到 youtube 的功能

我的参考如下:https ://developers.google.com/youtube/1.0/developers_guide_python

前开发人员遵循了这个非常有用的页面中的说明,例如满足上传视频的要求和身份验证。但它不起作用。当我运行 firebug 时,有一个 500 INTERNAL SERVER ERROR 并且在我看来它可以追溯到 upload_prepare 函数,这很可能是在保存部分。

    def upload_prepare(request):
        if request.POST:
            form = UploadForm(request.user, request.POST)
            if form.is_valid():
                #error is in the next line
                video = form.save()

他还按照有关如何通过 Browserupload 发布 youtube 视频的说明进行操作

我的代码如下:

模型.py

    class Category(models.Model):
        text = models.CharField(max_length=100)
        label = models.CharField(max_length=100)
        scheme = models.URLField()

        def toGData(self):
            return gdata.media.Category(
                text=self.text,
                label=self.label,
                scheme=self.scheme)

    class YoutubeUser(models.Model):
        username = models.CharField(max_length=50)
        ...

        #Initialize gdata.youtube.service.YouTubeService object
        def yt_service(self):
            try:
                return selt._yt_service
            except AttributeError:
        #setting up developer key and client ID
                yt_service = gdata.youtube.service.YouTubeService()
                yt_service.developer_key = settings.SYNCR_YT_DEVKEY
                yt_service.client_id = 'LOLtest'
        #setting up a authentication token
                if self.token:
                    yt_service.SetAuthSubToken(self.token)
                self._yt_service = yt_service
                return yt_service

        #Setting up AuthSub authentication for web apps
        def authsub_url(self, request):
        #urls.py url
            base = reverse('authlanding', args=(self.id,))
            next = 'http://%s%s?next=%s' % (request.get_host(), base, urllib2.quote(request.build_absolute_uri()))
            scope = 'http://gdata.youtube.com'
            secure = False
            session = True

            return self.yt_service.GenerateAuthSubUrl(next, scope, secure, session)

        #upgrade to a session token
        def upgrade_to_session(self):
            yt_service = self.yt_service
            yt_service.SetAuthSubToken(self.token)
            yt_service.UpgradeToSessionToken()
            self.token = yt_service.current_token.get_token_string()
            self.save()

到目前为止,我的models.py中的代码,这里是我的forms.py中的代码,导致错误的保存函数在这里找到(查看上面的upload_prepare视图)

表格.py

    class UploadForm(forms.Form):
        video_title = forms.CharField(max_length=100)
        ...
        #https://developers.google.com/youtube/1.0/developers_guide_python#UploadingVideos
        #Browser-based upload
        def save(self):
            mediagroup = gdata.media.Group(
                title=gdata.media.Title(text=self.cleaned_data['video_title']),
                description=gdata.media.Description(description_type="plain", text=self.cleaned_data['video_description']),
                keywords=gdata.media.Keywords(text=self.cleaned_data['tags']),
        #category already in GData format look in models.py
                category=self.cleaned_data['category'].toGData(),
                player=None,
            )
            video_entry = gdata.youtube.YouTubeVideoEntry(media=mediagroup)
            response = self.yt_user.yt_service.GetFormUploadToken(video_entry)
            post_url = response[0]
            youtube_token = response[1]

            video = Video.objects.create(
                author=self.yt_user,
                post_url=post_url,
                youtube_token=youtube_token,
                title=self.cleaned_data['video_title'],
                description=self.cleaned_data['video_description'],
                tag_list=self.cleaned_data['tags'],
            )
            self.video = video
            return video

html 中用来传递数据的表单,另一方面结合了 django 表单、django 自定义标记和 ajax

表格.py

    class UploadForm(forms.Form):
        video_title = forms.CharField(max_length=100)
        video_description = forms.CharField(widget=forms.Textarea(attrs={'cols': 60,
                                             'rows': 10}))
        category = forms.ModelChoiceField(Category.objects, empty_label=None)
        tags     = TagField(
               label=_('tags (comma separated)'),
               required=True,
               )

youtube_tags.py

    def youtube_upload_form(context):
    #UploadForm from above
        upload_form = UploadForm(context['user'])
        context['upload_form'] = upload_form
        return context

    register.inclusion_tag('syncr/youtube/upload.html',
                   takes_context=True)(youtube_upload_form)

add_post.html

    <script>
        function upload_video_to_youtube(url){
            action = "%s?nexturl=%s" % (youtube_url, url)
            var new_form = create_element('form', {'method': 'post', 'action': action, 'enctype':"multipart/form-data"});
            $('#youtube_upload_form input').each(function(){
                var obj = this.cloneNode(true);
                new_form.appendChild(obj);
            });
            document.body.appendChild(new_form);
            new_form.submit();
        }
    </script>

    {% block body %}
    ...
    <div id="rd2-radioOptionContent" class="hide radioOptionContent">
    {% youtube_upload_form %}
    </div>
    {% endblock %}

希望每个人都能完美地了解我发布的代码。如果读得很清楚,参考上发布的大多数说明都遵循(尽管用于提交数据的表单略有不同),并且鉴于我有 500 内部服务器错误,我需要在这些代码行中找到问题。任何答案都非常感谢。

4

1 回答 1

0

您的 yt_service 方法的第二行有错字,应该是 self 而不是 selt。也许这就是问题所在?

于 2012-07-31T23:12:56.433 回答