로그인하여 페이지를 편집하고 싶습니다. edittoken을 얻을 수 있지만 action = edit에 전달하면 badtoken이라고 표시됩니다. 내가 놓친 것이 있습니까?
__apiJson__ = "https://zh.wikipedia.org/w/api.php?format=json&"
def login():
username = "???" #use your own
password = "???" #use your own
username = urllib.parse.quote(username)
password = urllib.parse.quote(password)
r = requests.post(__apiJson__ + "action=login&lgname={username}&lgpassword={password}".
format(username=username,password=password))
content = r.json()
content = content['login']
if(content['result'] == 'NeedToken'):
cookies = r.cookies
token = content['token']
r = requests.post(__apiJson__ + "action=login&lgname={username}&lgpassword={password}&lgtoken={token}".
format(username=username,password=password,token=token),cookies=cookies)
content = r.json()
content = content['login']
assert content['result']=="Success"
return r.cookies
def getEditToken(archivePage):
r = requests.post(__apiJson__ + "action=query&prop=info&intoken=edit&titles={title}".format(title=archivePage),cookies=cookies)
content = r.json()
content = content['query']['pages']
content = content[list(content.keys())[0]]
editToken = content['edittoken']
if(editToken == '+\\'):
raise Exception()
return editToken
cookies = login()
editToken = getEditToken("User:???/test") #use your own
editToken=urllib.parse.quote(editToken)
r = requests.post("https://zh.wikipedia.org/w/api.php?action=edit&format=json&title=User:Gqqnb/沙盒&text=helloworld&summary=test&token={token}".format(token=editToken),
cookies=cookies,headers={"Content-Type":"application/x-www-form-urlencoded"})
content = r.json()
나는 내 질문에 답한다. 그냥 사용 requests.session()
오히려 sessionless보다, requests.get
하고 post
.
이 기사는 인터넷에서 수집됩니다. 재 인쇄 할 때 출처를 알려주십시오.
침해가 발생한 경우 연락 주시기 바랍니다[email protected] 삭제
몇 마디 만하겠습니다