3

bitbucket の APIを使用してプライベート リポジトリの問題のリストを取得しようとしています。

HTTP Basic 認証はhurlで動作することを確認しましたが、Python では認証できません。このチュートリアルのコードを適応させて、次のスクリプトを作成しました。

import cookielib
import urllib2

class API():
    api_url = 'http://api.bitbucket.org/1.0/'

    def __init__(self, username, password):
        self._opener = self._create_opener(username, password)

    def _create_opener(self, username, password):
        cj = cookielib.LWPCookieJar()
        cookie_handler = urllib2.HTTPCookieProcessor(cj)
        password_manager = urllib2.HTTPPasswordMgrWithDefaultRealm()
        password_manager.add_password(None, self.api_url, username, password)
        auth_handler = urllib2.HTTPBasicAuthHandler(password_manager)
        opener = urllib2.build_opener(cookie_handler, auth_handler)
        return opener

    def get_issues(self, username, repository):
        query_url = self.api_url + 'repositories/%s/%s/issues/' % (username, repository)
        try:
            handler = self._opener.open(query_url)
        except urllib2.HTTPError, e:
            print e.headers
            raise e
        return handler.read()

api = API(username='my_username', password='XXXXXXXX')

api.get_issues('my_username', 'my_repository')結果:

>>> 
Server: nginx/0.7.62
Date: Mon, 19 Apr 2010 16:15:06 GMT
Content-Type: text/plain
Connection: close
Vary: Authorization,Cookie
Content-Length: 9

Traceback (most recent call last):
  File "C:/USERS/personal/bitbucket-burndown/bitbucket-api.py", line 29, in <module>
    print api.get_issues('my_username', 'my_repository')
  File "C:/USERS/personal/bitbucket-burndown/bitbucket-api.py", line 25, in get_issues
    raise e
HTTPError: HTTP Error 401: UNAUTHORIZED

api.get_issues('jespern', 'bitbucket')魅力のように機能します。

コードの何が問題になっていますか?

4

4 に答える 4

5

HTTPBasicAuthHandlerに問題があるようです。これは機能します:

class API():
    api_url = 'http://api.bitbucket.org/1.0/'

    def __init__(self, username, password, proxy=None):
        encodedstring = base64.encodestring("%s:%s" % (username, password))[:-1]
        self._auth = "Basic %s" % encodedstring
        self._opener = self._create_opener(proxy)

    def _create_opener(self, proxy=None):
        cj = cookielib.LWPCookieJar()
        cookie_handler = urllib2.HTTPCookieProcessor(cj)
        if proxy:
            proxy_handler = urllib2.ProxyHandler(proxy)
            opener = urllib2.build_opener(cookie_handler, proxy_handler)
        else:
            opener = urllib2.build_opener(cookie_handler)
        return opener

    def get_issues(self, username, repository):
        query_url = self.api_url + 'repositories/%s/%s/issues/' % (username, repository)
        try:
            req = urllib2.Request(query_url, None, {"Authorization": self._auth })
            handler = self._opener.open(req)
        except urllib2.HTTPError, e:
            print e.headers
            raise e
        return json.load(handler)
于 2010-04-19T18:40:19.170 に答える
2

Python の HTTPBasicAuthHandler にエラーはないと思います。基本認証は通常、次のプロセスに従います。

  • クライアントは資格情報なしでリクエストを行います。
  • サーバーは 401 エラーで応答します。
  • クライアントは資格情報を含む要求を再送信します。
  • サーバーはコンテンツで応答します。

BitBucket の場合、次のようになります。

  • クライアントは資格情報なしでリクエストを行います。
  • BitBucket は公開リポジトリのリストで応答します。

BitBucket は 401 を発行しないため、Python は認証情報を送信しません。

Cookie を使用せずに BitBucket で認証する例をご覧ください。

于 2011-02-14T16:15:22.423 に答える
1

BitbucketのAPIのPythonラッパーであるpython-bitbucketを見てください。元のライブラリには読み取りアクセスのみが含まれていますが、 ericofには認証と一部の書き込みアクセスが含まれています。これらは、https ://bitbucket.org/bkmontgomery/python-bitbucketに組み込まれています。

次のように、プライベートリポジトリからIssueを取得できます。

import bitbucket

bb = bitbucket.BitBucket(username='your-username', password='secret')
repo = bb.repository('your-username', 'your-private-repo')
issues = repo.issues()
于 2011-05-21T05:59:11.520 に答える
0

HTTPPasswordMgr をサブクラス化し、find_user_password() メソッドをオーバーライドして、コードがパスワードの検索をあきらめている場所を確認できます。私の推測では、 add_password() は期待どおりに機能していません。

于 2010-04-19T17:47:12.667 に答える