JIRA-Python 的基本身份验证不再适用于 REST API 调用。接下来是什么?

Basic Authentication for JIRA-Python no longer works for REST API calls. What next?

在 Python 中,我曾经能够使用一段简单的代码通过 REST 使用 JIRA 进行身份验证:

from jira import JIRA

my_JIRA_username = 'my_name'
my_JIRA_pass = 'my_password'
server = {'server': 'https://my_site.atlassian.net'}
jira = JIRA(server, basic_auth = (my_JIRA_username, my_JIRA_pass))

然后可以做一些简单的事情,比如:

my_issue = jira.issue('MYISSUE-1')
print my_issue.key

但是 JIRA 已经改变了一些东西,我猜测不再允许通过 REST API 这样的基本身份验证。相反,我收到 401 错误。

我厌倦了创建一个 API 令牌,如这里所建议的: https://confluence.atlassian.com/cloud/api-tokens-938839638.html 除了我不知道在哪里使用它(如果我只是将它用作密码,它就不起作用,就像上面的代码一样)。

我研究了 OAuth 作为替代方案,但我找不到任何对我来说有意义的从 A 点到 B 点的代码。

相反,我发现了这样的事情: https://bitbucket.org/atlassianlabs/atlassian-oauth-examples/src/master/python/app.py

这对我来说纯粹是胡言乱语。不可能那么复杂!

任何人都可以提供一个简单的 jira-python 示例,说明使用从初始化到简单 REST 调用的基本身份验证以外的东西吗?

将不胜感激!我几个月的工作现在毫无用处,仅仅是因为我无法再进行身份验证。

此外,如果您能解释如何以及何时使用 JIRA 允许您在其云实例上生成的 API 令牌,我们将不胜感激,因为我也不明白!

由于在基本身份验证中已弃用密码,因此将使用 API 令牌取而代之(如您偶然发现的)。在您的代码中,您需要使用 email 代替 usernameapiToken 而不是密码。在你的代码中它应该是

# jira = JIRA(server, basic_auth = (my_JIRA_username, my_JIRA_pass))
jira = JIRA(server, basic_auth = (email, apiToken))

试试看,告诉我们效果如何。