本文整理匯總了PHP中HttpRequest::post方法的典型用法代碼示例。如果您正苦於以下問題:PHP HttpRequest::post方法的具體用法?PHP HttpRequest::post怎麽用?PHP HttpRequest::post使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類HttpRequest
的用法示例。
在下文中一共展示了HttpRequest::post方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: HttpRequest
/** Generic request using the protocol:
* POSTs data & files, checks the magic header
* @param array $post Arbitrary data to POST
* @param array $files Files to upload: { name: path | [path, filename] | [path, filename, mimetype] }
* @return HttpResponse
* @throws RemScriptProtocolError
*/
function _request($post, $files)
{
# Prepare
$request = new HttpRequest($this->script_url, 'POST');
$request->mimicBrowser();
$request->headers['Connection'] = 'Close';
$request->post($post);
if (!empty($files)) {
foreach ($files as $name => $upload) {
list($path, $filename, $mimetype) = (array) $upload + array(null, null, null);
$request->upload($name, $path, $filename, $mimetype);
}
}
# Request
try {
$response = $request->open();
} catch (HttpRequestError $e) {
throw new RemScriptProtocolError('Request error: ' . $e->getMessage(), RemScriptProtocolError::REQUEST_ERROR, $e);
}
# Response: check code
if ($response->code != 200) {
throw new RemScriptProtocolError('Response code: ' . $response->code);
}
# Response: check magic
$expected = self::RESPONSE_MAGIC;
$actual = fread($response->f, strlen($expected));
if ($actual !== $expected) {
throw new RemScriptProtocolError('Wrong magic: ' . var_export($actual, 1));
}
# All okay
return $response;
}
示例2: loginAction
public function loginAction()
{
$this->view->disable();
$http_request = new HttpRequest();
print_r($_SERVER);
$header = array('Host:106.37.195.128', 'User-Agent:Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:40.0) Gecko/20100101 Firefox/40.0', 'Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 'Accept-Language:zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3', 'Referer:http://106.37.195.128/chinalifepcsfa/system/userLogin.do', 'Connection:keep-alive');
$data = 'platformType=0&userId=530123197902182620&password=sp182620';
$http_respone = $http_request->post('http://106.37.195.128/chinalifepcsfa/system/userLogin.do', $header, $data);
if (isset($http_respone->headers['Location'])) {
$location = $http_respone->headers['Location'];
$cookies = $http_respone->cookies;
$header2 = array('Host:106.37.195.128', 'User-Agent:Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:40.0) Gecko/20100101 Firefox/40.0', 'Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 'Accept-Language:zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3', 'Referer:http://106.37.195.128/chinalifepcsfa/system/userLogin.do', 'Connection:keep-alive');
$http_respone2 = $http_request->get($location, $header2, $cookies);
preg_match('@href="(/chinalifepcsfa/user/electronicInsurance.do\\?.*)"@Ui', $http_respone2->content, $matches);
$entrance_href = 'http://106.37.195.128' . $matches[1];
$header3 = array('Host:106.37.195.128', 'User-Agent:Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:40.0) Gecko/20100101 Firefox/40.0', 'Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 'Accept-Language:zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3', 'Connection:keep-alive');
$http_respone3 = $http_request->get($entrance_href, $header3, $cookies);
$final_url = $http_respone3->headers['Location'];
$_SESSION['emu_url'] = $final_url;
$final_header = array('Host:106.37.195.128:7011', 'User-Agent:Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:40.0) Gecko/20100101 Firefox/40.0', 'Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 'Accept-Language:zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3', 'Connection:keep-alive');
$final_http_response = $http_request->get($final_url, $final_header, $cookies);
$_SESSION['emu_cookies'] = $final_http_response->cookies;
} else {
echo json_encode(array('success' => false, 'err_msg' => '用戶名或密碼錯誤!'));
}
}
示例3: _exec
protected function _exec()
{
$payLog = LogFactory::getLogger(array('prefix' => LogFactory::LOG_MODULE_PLATFORM, 'log_dir' => APP_ROOT . '/log/ApplePayment/', 'archive' => ILogger::ARCHIVE_YEAR_MONTH, 'log_level' => 1));
$gameuid = $this->getParam("gameuid", 'string');
$key = $this->getParam("key", 'string');
//提交審核的時候 使用 沙箱地址
// $verify_url = "https://sandbox.itunes.apple.com/verifyReceipt";
$verify_url = 'https://buy.itunes.apple.com/verifyReceipt';
$verify_postfields = json_encode(array("receipt-data" => $key));
$res = HttpRequest::post($verify_url, $verify_postfields);
$resData = json_decode($res['data'], true);
if ($resData !== NULL && $resData["status"] == 0) {
$tradeManager = new TradeLogManager();
$receipt = $resData["receipt"];
$id = $receipt['transaction_id'];
$account = $this->user_account_mgr->getUserAccount($gameuid);
$payLog->writeInfo($gameuid . " || " . $account['gem'] . " || " . json_encode($receipt));
$cached_orders = $tradeManager->getOrderCache($gameuid);
if (empty($cached_orders)) {
$cached_orders = array();
}
if (empty($receipt)) {
return array('status' => 'error');
}
if (in_array($id, $cached_orders)) {
return TRUE;
}
$rewards = InitUser::$treasure_activity;
$product_id = $receipt['product_id'];
if ($product_id == "FAMEGEM01") {
$change['gem'] = 200;
$item = $this->addReward($gameuid, $rewards['littleFarmGem']);
} elseif ($product_id == "FAMEGEM02") {
$change['gem'] = 1100;
$item = $this->addReward($gameuid, $rewards['largeFarmGem']);
} else {
$this->throwException("wrong product_id :" . $product_id, GameStatusCode::PARAMETER_ERROR);
}
$this->user_account_mgr->updateUserStatus($gameuid, $change);
$tradeinfo = array();
$tradeinfo['gameuid'] = $gameuid;
$tradeinfo['product_id'] = $product_id;
$tradeinfo['platform'] = "apple";
$tradeinfo['orderId'] = $id;
$tradeinfo['purchaseState'] = 1;
$tradeinfo['purchasetime'] = time();
$tradeinfo['status'] = 1;
$tradeManager->insert($tradeinfo);
$new_account = $this->user_account_mgr->getUserAccount($gameuid);
array_push($cached_orders, $id);
$tradeManager->setOrderCache($gameuid, $cached_orders);
$payLog->writeInfo($gameuid . " || " . $new_account['gem']);
if (empty($item)) {
return array("gem" => $new_account['gem']);
} else {
return array("gem" => $new_account['gem'], "items" => $item);
}
}
}
示例4: sendRequest
/**
* 發送一個rest Api 請求
* @param string $api 請求地址
* @param array<K,V> $query 請求參數
* @param string $method 請求方法 目前隻支持 GET, POST
* @param string $header http header
* @param string $curlOpts curl選項
* @return mixed 解析結果,如果失敗將返回false, 否則應返回解析後的服務端返回的json數據
*/
protected function sendRequest($api, $query, $method = "POST", $header = null, $curlOpts = null)
{
$url = $this->http->getResourceAddress($api);
$query['sign'] = $this->genSign($method, $url, $query);
if ($header == null) {
$header = array('User-Agent: ' . $this->makeUA());
}
if ($method == 'GET') {
$response = $this->http->get($api, $query, $header, $curlOpts);
} else {
$response = $this->http->post($api, $query, $header, $curlOpts);
}
return $this->parse($response);
}
示例5: testPost
/**
* @depends testCreateHttpRequest
* @param HttpRequest $http
*/
public function testPost($http)
{
$rs = $http->post('httpServer.php', $this->payload);
$this->valiedResponse($rs);
}