Question

I want to login and then edit a page. I can get edittoken, but when I pass it to action=edit, it says badtoken. Do I miss anything?

__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()
Was it helpful?

Solution

I answer my own question. Just use requests.session(), rather than the sessionless requests.get and post.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top