phpカールは質問への回答をシミュレートします、常に400エラー
このWebサイトで質問への回答をシミュレートしたいです: http://zsjs.kaiwind.com/kf/html/index.html
彼は上記のページにログインし、新しいページに移動して質問に答え、すべての回答が完了し、修正された後、送信が許可されました。
すべての js 検証に合格した後、ajax リクエストがバックグラウンドに送信されてページが完成します。
彼が送信するデータは複雑ではありませんが、データ送信をシミュレートすると常にエラーが発生します。コードとエラー メッセージを以下に掲載します。ご協力いただければ幸いです。
コード:
カールリクエスト部分:
<?php<br /> function vget($url,$header = null){//模拟获取内容函数 <br /> global $browsers; <br /> $curl = curl_init();//启动一个CURL会话 <br /> curl_setopt($curl, CURLOPT_URL, $url);//要访问的地址 <br /> curl_setopt($curl, CURLOPT_HTTPHEADER, $browsers);//设置HTTP头 <br /> curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0);// 对认证证书来源的检查 <br /> curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1);// 从证书中检查SSL加密算法是否存在 <br /> curl_setopt($curl, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']);// 模拟用户使用的浏览器<br /> curl_setopt($curl,CURLOPT_REFERER,'HTTP://www.baidu.com'); <br /> curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1);// 使用自动跳转 <br /> curl_setopt($curl, CURLOPT_AUTOREFERER, 1);// 自动设置Referer <br /> curl_setopt($curl, CURLOPT_HTTPGET, 1);// 发送一个常规的GET请求<br /> curl_setopt($curl, CURLOPT_COOKIEJAR, $GLOBALS['cookie_file']);//保存cookie文件<br /> if(isset($header) && !is_null($header)){<br /> curl_setopt($curl, CURLOPT_HTTPHEADER, $header);//设置头信息的地方 <br /> }<br /> curl_setopt($curl, CURLOPT_HEADER, true);<br /> curl_setopt($curl, CURLOPT_TIMEOUT, 30);// 设置超时限制防止死循环 <br /> curl_setopt($curl, CURLOPT_HEADER, 0);// 显示返回的Header区域内容 <br /> curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);// 获取的信息以文件流的形式返回 <br /> $tmpInfo = curl_exec($curl);// 执行操作 <br /> if (curl_errno($curl)){<br /> echo 'Errno'.curl_error($curl);<br /> }<br /> curl_close($curl);// 关闭CURL会话<br /> return $tmpInfo;// 返回数据 <br /> }<br /> <br /> function vpost($url,$data){ // 模拟提交数据函数 <br /> global $browsers;<br /> //$header = "Content-type: application/x-www-form-urlencoded";//定义content-type为xml <br /> $curl = curl_init(); // 启动一个CURL会话 <br /> curl_setopt($curl, CURLOPT_URL, $url); // 要访问的地址 <br /> curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检查 <br /> curl_setopt($curl, CURLOPT_HTTPHEADER, $browsers);//设置HTTP头 <br /> curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); // 从证书中检查SSL加密算法是否存在 <br /> curl_setopt($curl, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); // 模拟用户使用的浏览器 <br /> curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转 <br /> curl_setopt($curl, CURLOPT_REFERER, 'http://zsjs.kaiwind.com/kf/html/question.html?15238132836?10');<br /> //curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer <br /> curl_setopt($curl, CURLOPT_POST, 1); // 发送一个常规的Post请求 <br /> curl_setopt($curl, CURLOPT_POSTFIELDS, $data); // Post提交的数据包 <br /> curl_setopt($curl, CURLOPT_COOKIEFILE, $GLOBALS['cookie_file']); // 读取上面所储存的Cookie信息 <br /> curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循环 <br /> curl_setopt($curl, CURLOPT_HEADER, 0); // 显示返回的Header区域内容 <br /> curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回 <br /> $tmpInfo = curl_exec($curl); // 执行操作 <br /> if (curl_errno($curl)){ <br /> echo 'Errno'.curl_error($curl); <br /> }<br /> curl_close($curl); // 关键CURL会话 <br /> return $tmpInfo; // 返回数据 <br /> }
実行部分:
<br> <?php <br /> header('Content-type:text/html;charset=utf-8');<br> $phone = '15238132836';<br> $area = '10';<br> $cookie_jar = tempnam('./','cookie');//セッション ID を保存する Cookie ファイルの場所を指定します<br> <br> $data = array(<br> 'tel'=>urlencode($phone),<br> 'エリア'=>urlencode($エリア)<br> );<br> <br> $GLOBALS['cookie_file'] = $cookie_jar;<br> require_once('./functions.php');<br> $url = 'http://zsjs.kaiwind.com/kf/html/index.html';<br> // vget($url);

phpssionscanStorestrings、numbers、arrays、andobjects.1.strings:textdatalikeusernames.2.numbers:integersorfloatsforcounters.3.arrays:listslikeshoppingcarts.4.objects:complextructuresthataresialized。

tostartaphpsession、outsession_start()atthescript'sbeginning.1)placeitbe foreanyouttosetthesscookie.2)usesionsionsionsionserdatalikelogintatussorshoppingcarts.3)再生セッションインドストップレベントフィックスアタック

セッション再生とは、新しいセッションIDを生成し、セッション固定攻撃の場合にユーザーが機密操作を実行するときに古いIDを無効にすることを指します。実装の手順には次のものが含まれます。1。感度操作を検出、2。新しいセッションIDを生成する、3。古いセッションIDを破壊し、4。ユーザー側のセッション情報を更新します。

PHPセッションは、アプリケーションのパフォーマンスに大きな影響を与えます。最適化方法には以下が含まれます。1。データベースを使用してセッションデータを保存して応答速度を向上させます。 2。セッションデータの使用を削減し、必要な情報のみを保存します。 3.非ブロッキングセッションプロセッサを使用して、同時実行機能を改善します。 4.セッションの有効期限を調整して、ユーザーエクスペリエンスとサーバーの負担のバランスを取ります。 5.永続的なセッションを使用して、データの読み取り時間と書き込み時間を減らします。

phpsesionsareserver-side、whilecookiesareclient-side.1)Sessionsionsionsoredataontheserver、aremoresecure.2)cookiesstoredataontheclient、cookiestoresecure、andlimitedinsizeisize.sesionsionsionivationivationivationivationivationivationivationivate

phpidentifiesauser'ssessionsingsinssessionCookiesIds.1)whensession_start()iscalled、phpgeneratesauniquesidstoredsored incoookienadphpsessidontheuser'sbrowser.2)thisidallowsphptortorieSessiondatadata fromthata

PHPセッションのセキュリティは、次の測定を通じて達成できます。1。session_regenerate_id()を使用して、ユーザーがログインまたは重要な操作である場合にセッションIDを再生します。 2. HTTPSプロトコルを介して送信セッションIDを暗号化します。 3。Session_Save_Path()を使用して、セッションデータを保存し、権限を正しく設定するためのSecure Directoryを指定します。

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

メモ帳++7.3.1
使いやすく無料のコードエディター

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









