HttpWebRequests の基本的な紹介
まず、仕事に適したツールが必要になります。Firefox 用のライブ HTTP ヘッダープラグインをダウンロードします。これにより、HTTP ヘッダーをリアルタイムで表示できるため、Web サイトとやり取りするときに送信される POST データを表示できます。Web サイトに送信されるデータがわかったら、独自の HTTP Web 要求をプログラムで作成してプロセスをエミュレートできます。ツール > ライブ HTTP ヘッダー
[ツール] > [ライブ HTTP ヘッダー]に移動して、ライブ HTTP ヘッダーを読み込みます。ログインしたい Web サイトへの GUI ナビゲートをロードしたら、デモンストレーションのためにFacebookを使用します。ログインの準備ができている資格情報を入力しますが、その前に GUI テキスト ウィンドウをクリアし、Captureというラベルの付いたチェック ボックスがオンになっていることを確認します。ログインすると、必要な POST データを含むリクエストに関するさまざまな情報がテキスト ウィンドウに表示されます。
POST データを簡単に識別できるように、 [すべて保存... ] をクリックし、テキスト ドキュメントでユーザー名を検索するのが最善の方法です。私のリクエストでは、POST データは次のようになりました。
lsd=AVp-UAbD&display=&legacy_return=1&return_session=0&trynum=1&charset_test=%E2%82%AC%2C%C2%B4%2C%E2%82%AC%2C%C2%B4%2C%E6%B0%B4%2C %D0%94%2C%D0%84&timezone=0&lgnrnd=214119_mDgc&lgnjs=1356154880&email=%myfacebookemail40outlook.com&pass=myfacebookpassword&default_persistent=0
これは、次のように C# で定義できます。
StringBuilder postData = new StringBuilder();
postData.Append("lsd=AVqRGVie&display=");
postData.Append("&legacy_return=1");
postData.Append("&return_session=0");
postData.Append("&trynum=1");
postData.Append("&charset_test=%E2%82%AC%2C%C2%B4%2C%E2%82%AC%2C%C2%B4%2C%E6%B0%B4%2C%D0%94%2C%D0%84");
postData.Append("&timezone=0");
postData.Append("&lgnrnd=153743_eO6D");
postData.Append("&lgnjs=1355614667");
postData.Append(String.Format("&email={0}", "CUSTOM_EMAIL"));
postData.Append(String.Format("&pass={0}", "CUSTOM_PASSWORD"));
postData.Append("&default_persistent=0");
Web ブラウザーを介して「手動で」送信できる POST データと、そのデータを使用して C# で要求をエミュレートする方法との関係を示すことを目指しています。POST データの送信は決定論的とはほど遠いことを理解してください。さまざまな Web サイトがさまざまな方法で動作し、あらゆる種類のものを自分のやり方で投げることができます。以下は、Facebook の資格情報が正しいことを検証するためにまとめた関数です。クラスとそのメンバーは十分に自己文書化されているため、ここで非常に深く掘り下げることはできませんし、すべきでもありません。WebRequest.Method プロパティなど、MSDNで使用されているメソッドについては、私が提供できるよりも優れた情報を見つけることができます。
private bool ValidateFacebookCredentials(string email, string password)
{
CookieContainer cookies = new CookieContainer();
HttpWebRequest request = null;
HttpWebResponse response = null;
string returnData = string.Empty;
//Need to retrieve cookies first
request = (HttpWebRequest)WebRequest.Create(new Uri("https://www.facebook.com/login.php?login_attempt=1"));
request.Method = "GET";
request.CookieContainer = cookies;
response = (HttpWebResponse)request.GetResponse();
//Set up the request
request = (HttpWebRequest)WebRequest.Create(new Uri("https://www.facebook.com/login.php?login_attempt=1"));
request.Method = "POST";
request.ContentType = "application/x-www-form-urlencoded";
request.UserAgent = "Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.2.13) Gecko/20101203 Firefox/3.6.13";
request.Referer = "https://www.facebook.com/login.php?login_attempt=1";
request.AllowAutoRedirect = true;
request.KeepAlive = true;
request.CookieContainer = cookies;
//Format the POST data
StringBuilder postData = new StringBuilder();
postData.Append("lsd=AVqRGVie&display=");
postData.Append("&legacy_return=1");
postData.Append("&return_session=0");
postData.Append("&trynum=1");
postData.Append("&charset_test=%E2%82%AC%2C%C2%B4%2C%E2%82%AC%2C%C2%B4%2C%E6%B0%B4%2C%D0%94%2C%D0%84");
postData.Append("&timezone=0");
postData.Append("&lgnrnd=153743_eO6D");
postData.Append("&lgnjs=1355614667");
postData.Append(String.Format("&email={0}", email));
postData.Append(String.Format("&pass={0}", password));
postData.Append("&default_persistent=0");
//write the POST data to the stream
using(StreamWriter writer = new StreamWriter(request.GetRequestStream()))
writer.Write(postData.ToString());
response = (HttpWebResponse)request.GetResponse();
//Read the web page (HTML) that we retrieve after sending the request
using (StreamReader reader = new StreamReader(response.GetResponseStream()))
returnData = reader.ReadToEnd();
return !returnData.Contains("Please re-enter your password");
}