1

私はハッシュ破りのコンテストに参加しており、HTML フォームへの文字列の投稿とハッシュ スコアの取得を自動化しようとしています。これまでのところ、何かをURLに投稿することができましたが、それは私が期待している正確な文字列ではありません.

import urllib.parse, urllib.request

url = "http://almamater.xkcd.com/?edu=una.edu"
data = "test".encode("ascii")
header = {"Content-Type":"application/octet-stream"}
req = urllib.request.Request(url, data, header)
f = urllib.request.urlopen(req)
print(f.read())
#parse f to pull out hash

サイトから次のハッシュを取得します。

0fff9563bb3279289227ac77d319b6fff8d7e9f09da1247b72a0a265cd6d2a62645ad547ed8193db48cff847c06494a03f55666d3b47eb4c20456c9373c86297d630d5578ebd34cb40991578f9f52b18003efa35d3da6553ff35db91b81ab890bec1b189b7f52cb2a783ebb7d823d725b0b4a71f6824e88f68f982eefc6d19c6

これは、フォームに「test」(引用符なし) と入力すると得られる、私が予想したものとはかなり異なります。

e21091dbb0d61bc93db4d1f278a04fe1a51165fb7262c7da31f886ae09ff3e04c41483c500db2792c59742958d8f7f39fe4f4f2cdc7940b7b25e3289b89d344e06f76305b9de525933b5df5dae2a37388f82cf76374fe363587acfb49b9d2c8fc131ef4a32c762be083b07330989b298d60e312f56a6b8a4c0f53c9b59864fb7

明らかに、コードは私が期待していることを実行していません。任意のヒント?

4

1 に答える 1

1

フォーム データを送信すると、フィールド名も含まれるため、「test」を送信すると、実際に送信されるデータは「hashable=test」のようになります。次のようにデータを変更してみてください。

data = "hashable=test".encode("ascii")

または代わりに:

data = urllib.parse.urlencode({'hashable': 'test'})
于 2013-04-02T16:01:39.763 に答える