XHS蒲公英破解更新

This commit is contained in:
luzhisheng 2021-09-01 15:44:13 +08:00
parent d494565ef5
commit ac59bdceb9
2 changed files with 31 additions and 40 deletions

View File

@ -11,26 +11,31 @@ class XhsApp(object):
self.nodejs_id_url = "http://127.0.0.1:3001/get_sign" self.nodejs_id_url = "http://127.0.0.1:3001/get_sign"
self.cookie_url = "https://www.xiaohongshu.com/fe_api/burdock/v2/shield/registerCanvas" self.cookie_url = "https://www.xiaohongshu.com/fe_api/burdock/v2/shield/registerCanvas"
self.login_url = "https://customer.xiaohongshu.com/api/cas/loginWithAccount" self.login_url = "https://customer.xiaohongshu.com/api/cas/loginWithAccount"
self.login_loginWithTicket_url = "https://pgy.xiaohongshu.com/api/solar/loginWithTicket" self.login_with_ticket_url = "https://pgy.xiaohongshu.com/api/solar/loginWithTicket"
self.sign = "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4280.141 " \ self.sign = "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) " \
"Safari/537.36~~~unknown~~~zh-CN~~~24~~~8~~~4~~~-480~~~Asia/Shanghai~~~1~~~1~~~1~~~1~~~unkno" \ "Chrome/87.0.4280.141 Safari/537.36~~~unknown~~~zh-CN~~~24~~~8~~~4~~~-480~~" \
"wn~~~Linux x86_64~~~Chrome PDF Plugin::Portable Document Format::application/x-google-chrome" \ "~Asia/Shanghai~~~1~~~1~~~1~~~1~~~unknown~~~Linux x86_64~~~Chrome PDF Plugin:" \
"-pdf~pdf,Chrome PDF Viewer::::application/pdf~pdf,Native Client::::application/x-nacl~,appl" \ ":Portable Document Format::application/x-google-chrome-pdf~pdf,Chrome PDF " \
"ication/x-pnacl~~~~canvas winding:yes~canvas fp:4ed6498d31241a0323aabbcc7f6d68a0~~~false~~~f" \ "Viewer::::application/pdf~pdf,Native Client::::application/x-nacl~,application/" \
"alse~~~false~~~false~~~false~~~0;false;false~~~0;1;2;3;4;5;6;7;8;9~~~124.04347730432432" "x-pnacl~~~~canvas winding:yes~canvas fp:3e5b9a791ef080c3734bf8450d4b1988~~~false~" \
"~~false~~~false~~~false~~~false~~~0;false;false~~~0;1;2;3;4;5;6;7;8;9~~~124.04347730590962"
def get_timestamp(self): def get_timestamp(self):
t = time.time() t = time.time()
return str(round(t * 1000)) return str(round(t * 1000))
def get_x_s(self, x_t): def get_x_s(self, x_s_data):
x_s_data = 'test1test/api/cas/loginWithAccount{"account":"test2","password":"test3",' \ data = {
'"service":"https://pgy.xiaohongshu.com"}' 'sign': x_s_data
x_s_data = x_s_data.replace("test1", x_t) \ }
.replace("test2", xhs_account.get('account')) \ req = requests.post(self.nodejs_x_s_url, data=data)
.replace("test3", xhs_account.get('password')) id = req.text
return id
def get_x_s_login(self, x_t):
x_s_data = f'{x_t}test/api/cas/loginWithAccount{{"account":"{xhs_account.get("account")}",' \
f'"password":"{xhs_account.get("password")}","service":"https://pgy.xiaohongshu.com"}}'
data = { data = {
'sign': x_s_data 'sign': x_s_data
} }
@ -70,39 +75,42 @@ class XhsApp(object):
req = requests.post(self.login_url, headers=headers, data=payload) req = requests.post(self.login_url, headers=headers, data=payload)
return req.text, req.headers return req.text, req.headers
def get_login_with_ticket(self, timestamp2, x_s, x_t, customerBeakerSessionId, st_data): def get_login_with_ticket(self, timestamp2, x_s, x_t, st_data):
headers = { headers = {
'cookie': f"timestamp2={timestamp2}; {customerBeakerSessionId}", 'cookie': f"timestamp2={timestamp2};",
'x-s': x_s, 'x-s': x_s,
'x-t': x_t, 'x-t': x_t,
'content-type': 'application/json;charset=UTF-8' 'content-type': 'application/json;charset=UTF-8'
} }
print(headers)
payload = "{\"ticket\":\"test1\"}" payload = "{\"ticket\":\"test1\"}"
payload = payload.replace("test1", st_data) payload = payload.replace("test1", st_data)
print(payload) req = requests.post(self.login_with_ticket_url, headers=headers, data=payload)
req = requests.post(self.login_loginWithTicket_url, headers=headers, data=payload)
return req return req
def run(self): def run(self):
x_t = self.get_timestamp() x_t = self.get_timestamp()
print('x_t : {}'.format(x_t)) print('x_t : {}'.format(x_t))
x_s_login = self.get_x_s_login(x_t)
x_s = self.get_x_s(x_t) print('x_s_login : {}'.format(x_s_login))
print('x_s : {}'.format(x_s))
id = self.get_id() id = self.get_id()
timestamp2 = self.get_cookie_timestamp2(id) timestamp2 = self.get_cookie_timestamp2(id)
print('timestamp2 : {}'.format(timestamp2)) print('timestamp2 : {}'.format(timestamp2))
text, headers = self.get_html(timestamp2, x_s, x_t)
text, headers = self.get_html(timestamp2, x_s_login, x_t)
text = json.loads(text) text = json.loads(text)
print(text) print(text)
x_t = self.get_timestamp()
print('x_t : {}'.format(x_t))
x_s = self.get_x_s(f'{x_t}test/api/solar/loginWithTicket{{"ticket":"{text.get("data")}"}}')
print('x_s : {}'.format(x_s))
lists = headers.get('Set-Cookie').split(';') lists = headers.get('Set-Cookie').split(';')
customerBeakerSessionId = lists[0] customerBeakerSessionId = lists[0]
print('customerBeakerSessionId : {}'.format(customerBeakerSessionId)) print('customerBeakerSessionId : {}'.format(customerBeakerSessionId))
res = self.get_login_with_ticket(timestamp2, x_s, x_t, customerBeakerSessionId, text.get('data')) res = self.get_login_with_ticket(timestamp2, x_s, x_t, text.get('data'))
print(res.text) print(res.text)
print(res.headers)
if __name__ == '__main__': if __name__ == '__main__':

View File

@ -1,17 +0,0 @@
import requests
url = "https://customer.xiaohongshu.com/api/cas/loginWithAccount"
payload = "{\"account\":\"feng.bao@winndoo.com\",\"password\":\"Winndoo@com123\"," \
"\"service\":\"https://pgy.xiaohongshu.com\"}"
headers = {
'content-type': 'application/json;charset=UTF-8',
'x-s': 'OiZk125KZga6ZjcWslMlOidB12MbOY1K0jwvOgACZgA3',
'x-t': '1623396152975',
'cookie': 'timestamp2=20210611efba504df43e1e6daff3fe96'
}
response = requests.request("POST", url, headers=headers, data=payload)
print(response.text)