cURL は強力な PHP ライブラリです。PHP の cURL ライブラリを使用すると、Web ページを簡単かつ効果的にクロールしてコンテンツを収集し、シミュレートされたログイン Web ページを完成させるために Cookie を設定できます。curl は、開発者が使用できる豊富な機能を提供します。 cURL については、PHP マニュアルを参照してください。この記事では、cURL の使用方法を共有する例として、オープン ソースの中国 (oschina) へのシミュレートされたログインを取り上げます。
PHP のcurl() は Web ページのクロールにおいて比較的効率的であり、マルチスレッドをサポートしていますが、file_get_contents() は、curl 拡張機能を使用する場合には、それを有効にする必要があります。
まずログイン コードを見てみましょう:
//模拟登录 function login_post($url, $cookie, $post) { $curl = curl_init();//初始化curl模块 curl_setopt($curl, CURLOPT_URL, $url);//登录提交的地址 curl_setopt($curl, CURLOPT_HEADER, 0);//是否显示头信息 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 0);//是否自动显示返回的信息 curl_setopt($curl, CURLOPT_COOKIEJAR, $cookie); //设置Cookie信息保存在指定的文件中 curl_setopt($curl, CURLOPT_POST, 1);//post方式提交 curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($post));//要提交的信息 curl_exec($curl);//执行cURL curl_close($curl);//关闭cURL资源,并且释放系统资源 }
関数 login_post() は最初にcurl_init() を初期化し、次にcurl_setopt() を使用して関連する設定を行います。送信する URL アドレス、保存されている Cookie ファイル、投稿データ (ユーザー名とパスワードなど)、情報を返すかどうかなどのオプション情報を指定すると、curl_exec でcurl が実行され、最後にcurl_close() でリソースが解放されます。 PHP 独自の http_build_query() は配列を接続された文字列に変換できることに注意してください。
次に、ログインに成功したら、ログイン成功後のページ情報を取得する必要があります。
//登录成功后获取数据 function get_content($url, $cookie) { $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); //读取cookie $rs = curl_exec($ch); //执行cURL抓取页面内容 curl_close($ch); return $rs; }
関数 get_content() も最初にcurlを初期化し、次に関連するオプションを設定し、curlを実行してリソースを解放します。このうち、CURLOPT_RETURTRANSFER を 1 に設定すると情報が自動的に返され、CURLOPT_COOKIEFILE はログイン時に保存された Cookie 情報を読み取って、最終的にページのコンテンツを返すことができます。
最終的な目標は、通常のログインに成功した場合にのみ取得できる有益な情報である模擬ログイン後の情報を取得することです。次に、Open Source China のモバイル バージョンへのログインを例として、ログイン成功後の情報を取得する方法を確認します。
//设置post的数据 $post = array ( 'email' => 'oschina账户', 'pwd' => 'oschina密码', 'goto_page' => '/my', 'error_page' => '/login', 'save_login' => '1', 'submit' => '现在登录' ); //登录地址 $url = "http://m.oschina.net/action/user/login"; //设置cookie保存路径 $cookie = dirname(__FILE__) . '/cookie_oschina.txt'; //登录后要获取信息的地址 $url2 = "http://m.oschina.net/my"; //模拟登录 login_post($url, $cookie, $post); //获取登录页的信息 $content = get_content($url2, $cookie); //删除cookie文件 @ unlink($cookie); //匹配页面信息 $preg = "/<td class='portrait'>(.*)<\/td>/i"; preg_match_all($preg, $content, $arr); $str = $arr[1][0]; //输出内容 echo $str;
上記のコードを実行すると、最終的にログイン ユーザーのアバター画像が取得されたことがわかります。
1.curl を初期化します。
2.curl_setopt を使用してターゲット URL とその他のオプションを設定します。 3 、curl_exec、curl を実行します。
4. 実行後、curl を閉じます。
5. データを出力します。
参考文献
" PHP CURL を使用したデータの POST」、著者: Veda、http://www.nowmagic.net/librarys/veda/detail/124
「php は、discuz へのログインをシミュレートし、投稿をシミュレートするために、curl を使用します」、著者: 天心、