cari
Rumahpembangunan bahagian belakangtutorial phpPHP封装的HttpClient类用法实例_PHP教程

PHP封装的HttpClient类用法实例_PHP教程

Jul 13, 2016 am 09:50 AM
httpclientphpContohpenggunaanbaik hatiBerpura-pura

PHP封装的HttpClient类用法实例

         本文实例讲述了PHP封装的HttpClient类。分享给大家供大家参考。具体分析如下:

         这是一段php封装的HttpClient类,可实现GET POST Cookie Session等简单的功能。原来做过,这两天重新修改了一下。

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

210

211

212

213

214

215

216

217

218

219

220

221

222

223

224

225

226

227

228

229

230

231

232

233

234

235

236

237

238

239

240

241

242

243

244

245

246

247

248

249

250

251

252

253

/*

* Filename: httpclient.php

* Created on 2012-12-21

* Created by RobinTang

* To change the template for this generated file go to

* Window - Preferences - PHPeclipse - PHP - Code Templates

*/

class SinCookie {

public $name; // Cookie名称

public $value; // Cookie值

// 下面三个属性现在未实现

public $expires; // 过期时间

public $path; // 路径

public $domain; // 域

// 从Cookie字符串创建一个Cookie对象

function __construct($s = false) {

if ($s) {

$i1 = strpos($s, '=');

$i2 = strpos($s, ';');

$this->name = trim(substr($s, 0, $i1));

$this->value = trim(substr($s, $i1 +1, $i2 - $i1 -1));

}

}

// 获取Cookie键值对

function getKeyValue() {

return "$this->name=$this->value";

}

}

// 会话上下文

class SinHttpContext {

public $cookies; // 会话Cookies

public $referer; // 前一个页面地址

function __construct() {

$this->cookies = array ();

$this->refrer = "";

}

// 设置Cookie

function cookie($key, $val) {

$ck = new SinCookie();

$ck->name = $key;

$ck->value = $val;

$this->addCookie($ck);

}

// 添加Cookie

function addCookie($ck) {

$this->cookies[$ck->name] = $ck;

}

// 获取Cookies字串,请求时用到

function cookiesString() {

$res = '';

foreach ($this->cookies as $ck) {

$res .= $ck->getKeyValue() . ';';

}

return $res;

}

}

// Http请求对象

class SinHttpRequest {

public $url; // 请求地址

public $method = 'GET'; // 请求方法

public $host; // 主机

public $path; // 路径

public $scheme; // 协议,http

public $port; // 端口

public $header; // 请求头

public $body; // 请求正文

// 设置头

function setHeader($k, $v) {

if (!isset ($this->header)) {

$this->header = array ();

}

$this->header[$k] = $v;

}

// 获取请求字符串

// 包含头和请求正文

// 获取之后直接写socket就行

function reqString() {

$matches = parse_url($this->url);

!isset ($matches['host']) && $matches['host'] = '';

!isset ($matches['path']) && $matches['path'] = '';

!isset ($matches['query']) && $matches['query'] = '';

!isset ($matches['port']) && $matches['port'] = '';

$host = $matches['host'];

$path = $matches['path'] ? $matches['path'] . ($matches['query'] ? '?' . $matches['query'] : '') : '/';

$port = !empty ($matches['port']) ? $matches['port'] : 80;

$scheme = $matches['scheme'] ? $matches['scheme'] : 'http';

$this->host = $host;

$this->path = $path;

$this->scheme = $scheme;

$this->port = $port;

$method = strtoupper($this->method);

$res = "$method $path HTTP/1.1\r\n";

$res .= "Host: $host\r\n";

if ($this->header) {

reset($this->header);

while (list ($k, $v) = each($this->header)) {

if (isset ($v) && strlen($v) > 0)

$res .= "$k: $v\r\n";

}

}

$res .= "\r\n";

if ($this->body) {

$res .= $this->body;

$res .= "\r\n\r\n";

}

return $res;

}

}

// Http响应

class SinHttpResponse {

public $scheme; // 协议

public $stasus; // 状态,成功的时候是ok

public $code; // 状态码,成功的时候是200

public $header; // 响应头

public $body; // 响应正文

function __construct() {

$this->header = array ();

$this->body = null;

}

function setHeader($key, $val) {

$this->header[$key] = $val;

}

}

// HttpClient

class SinHttpClient {

public $keepcontext = true; // 是否维持会话

public $context; // 上下文

public $request; // 请求

public $response; // 响应

public $debug = false;

// 是否在Debug模式,

//为true的时候会打印出请求内容和相同的头部

function __construct() {

$this->request = new SinHttpRequest();

$this->response = new SinHttpResponse();

$this->context = new SinHttpContext();

$this->timeout = 15; // 默认的超时为15s

}

// 清除上一次的请求内容

function clearRequest() {

$this->request->body = '';

$this->request->setHeader('Content-Length', false);

$this->request->setHeader('Content-Type', false);

}

// post方法

// data为请求的数据

// 为键值对的时候模拟表单提交

// 其他时候为数据提交,提交的形式为xml

// 如有其他需求,请自行扩展

function post($url, $data = false) {

$this->clearRequest();

if ($data) {

if (is_array($data)) {

$con = http_build_query($data);

$this->request->setHeader('Content-Type', 'application/x-www-form-urlencoded');

} else {

$con = $data;

$this->request->setHeader('Content-Type', 'text/xml; charset=utf-8');

}

$this->request->body = $con;

$this->request->method = "POST";

$this->request->setHeader('Content-Length', strlen($con));

}

$this->startRequest($url);

}

// get方法

function get($url) {

$this->clearRequest();

$this->request->method = "GET";

$this->startRequest($url);

}

// 该方法为内部调用方法,不用直接调用

function startRequest($url) {

$this->request->url = $url;

if ($this->keepcontext) {

// 如果保存上下文的话设置相关信息

$this->request->setHeader('Referer', $this->context->refrer);

$cks = $this->context->cookiesString();

if (strlen($cks) > 0)

$this->request->setHeader('Cookie', $cks);

}

// 获取请求内容

$reqstring = $this->request->reqString();

if ($this->debug)

echo "Request:\n$reqstring\n";

try {

$fp = fsockopen($this->request->host, $this->request->port, $errno, $errstr, $this->timeout);

} catch (Exception $ex) {

echo $ex->getMessage();

exit (0);

}

if ($fp) {

stream_set_blocking($fp, true);

stream_set_timeout($fp, $this->timeout);

// 写数据

fwrite($fp, $reqstring);

$status = stream_get_meta_data($fp);

if (!$status['timed_out']) { //未超时

// 下面的循环用来读取响应头部

while (!feof($fp)) {

$h = fgets($fp);

if ($this->debug)

echo $h;

if ($h && ($h == "\r\n" || $h == "\n"))

break;

$pos = strpos($h, ':');

if ($pos) {

$k = strtolower(trim(substr($h, 0, $pos)));

$v = trim(substr($h, $pos +1));

if ($k == 'set-cookie') {

// 更新Cookie

if ($this->keepcontext) {

$this->context->addCookie(new SinCookie($v));

}

} else {

// 添加到头里面去

$this->response->setHeader($k, $v);

}

} else {

// 第一行数据

// 解析响应状态

$preg = '/^(\S*) (\S*) (.*)$/';

preg_match_all($preg, $h, $arr);

isset ($arr[1][0]) & $this->response->scheme = trim($arr[1][0]);

isset ($arr[2][0]) & $this->response->stasus = trim($arr[2][0]);

isset ($arr[3][0]) & $this->response->code = trim($arr[3][0]);

}

}

// 获取响应正文长度

$len = (int) $this->response->header['content-length'];

$res = '';

// 下面的循环读取正文

while (!feof($fp) && $len > 0) {

$c = fread($fp, $len);

$res .= $c;

$len -= strlen($c);

}

$this->response->body = $res;

}

// 关闭Socket

fclose($fp);

// 把返回保存到上下文维持中

$this->context->refrer = $url;

}

}

}

// demo

// now let begin test it

$client = new SinHttpClient(); // create a client

$client->get('http://www.baidu.com/'); // get

echo $client->response->body; // echo

?>

希望本文所述对大家的php程序设计有所帮助。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1017843.htmlTechArticlePHP封装的HttpClient类用法实例 本文实例讲述了PHP封装的HttpClient类。分享给大家供大家参考。具体分析如下: 这是一段php封装的HttpClient类,...
Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Apakah beberapa masalah biasa yang boleh menyebabkan sesi PHP gagal?Apakah beberapa masalah biasa yang boleh menyebabkan sesi PHP gagal?Apr 25, 2025 am 12:16 AM

Sebab -sebab kegagalan phpsession termasuk kesilapan konfigurasi, isu cookie, dan tamat tempoh sesi. 1. Ralat Konfigurasi: Semak dan tetapkan session.save_path yang betul. Masalah 2.Cookie: Pastikan kuki ditetapkan dengan betul. 3.Session Expires: Laraskan Nilai Sesi.GC_MAXLifetime untuk melanjutkan masa sesi.

Bagaimanakah anda menyebarkan isu berkaitan sesi dalam PHP?Bagaimanakah anda menyebarkan isu berkaitan sesi dalam PHP?Apr 25, 2025 am 12:12 AM

Kaedah untuk masalah sesi debug dalam PHP termasuk: 1. Periksa sama ada sesi dimulakan dengan betul; 2. Sahkan penghantaran ID sesi; 3. Semak penyimpanan dan bacaan data sesi; 4. Semak konfigurasi pelayan. Dengan mengeluarkan ID dan data sesi, melihat kandungan fail sesi, dan lain-lain, anda boleh mendiagnosis dan menyelesaikan masalah yang berkaitan dengan sesi.

Apa yang berlaku jika session_start () dipanggil beberapa kali?Apa yang berlaku jika session_start () dipanggil beberapa kali?Apr 25, 2025 am 12:06 AM

Pelbagai panggilan ke session_start () akan menghasilkan mesej amaran dan kemungkinan penggantian data. 1) PHP akan mengeluarkan amaran, menyebabkan sesi telah dimulakan. 2) Ia boleh menyebabkan penggantian data sesi yang tidak dijangka. 3) Gunakan session_status () untuk memeriksa status sesi untuk mengelakkan panggilan berulang.

Bagaimana anda mengkonfigurasi seumur hidup sesi di PHP?Bagaimana anda mengkonfigurasi seumur hidup sesi di PHP?Apr 25, 2025 am 12:05 AM

Mengkonfigurasi kitaran hayat sesi dalam PHP boleh dicapai dengan menetapkan sesi.gc_maxlifetime dan session.cookie_lifetime. 1) session.gc_maxlifetime mengawal masa survival data sesi pelayan, 2) session.cookie_lifetime mengawal kitaran hayat kuki klien. Apabila ditetapkan ke 0, kuki tamat apabila penyemak imbas ditutup.

Apakah kelebihan menggunakan pangkalan data untuk menyimpan sesi?Apakah kelebihan menggunakan pangkalan data untuk menyimpan sesi?Apr 24, 2025 am 12:16 AM

Kelebihan utama menggunakan sesi penyimpanan pangkalan data termasuk kegigihan, skalabilitas, dan keselamatan. 1. Kegigihan: Walaupun pelayan dimulakan semula, data sesi tidak dapat berubah. 2. Skalabiliti: Berkenaan dengan sistem yang diedarkan, memastikan data sesi disegerakkan di antara pelbagai pelayan. 3. Keselamatan: Pangkalan data menyediakan storan yang disulitkan untuk melindungi maklumat sensitif.

Bagaimana anda melaksanakan pengendalian sesi tersuai di PHP?Bagaimana anda melaksanakan pengendalian sesi tersuai di PHP?Apr 24, 2025 am 12:16 AM

Melaksanakan pemprosesan sesi tersuai dalam PHP boleh dilakukan dengan melaksanakan antara muka sessionHandlerInterface. Langkah -langkah khusus termasuk: 1) mewujudkan kelas yang melaksanakan sessionHandlerInterface, seperti CustomSessionHandler; 2) kaedah penulisan semula dalam antara muka (seperti terbuka, rapat, membaca, menulis, memusnahkan, gc) untuk menentukan kitaran hayat dan kaedah penyimpanan data sesi; 3) Daftar pemproses sesi tersuai dalam skrip PHP dan mulakan sesi. Ini membolehkan data disimpan dalam media seperti MySQL dan REDIS untuk meningkatkan prestasi, keselamatan dan skalabiliti.

Apakah ID Sesi?Apakah ID Sesi?Apr 24, 2025 am 12:13 AM

SesionID adalah mekanisme yang digunakan dalam aplikasi web untuk mengesan status sesi pengguna. 1. Ia adalah rentetan yang dijana secara rawak yang digunakan untuk mengekalkan maklumat identiti pengguna semasa pelbagai interaksi antara pengguna dan pelayan. 2. Pelayan menjana dan menghantarnya kepada klien melalui kuki atau parameter URL untuk membantu mengenal pasti dan mengaitkan permintaan ini dalam pelbagai permintaan pengguna. 3. Generasi biasanya menggunakan algoritma rawak untuk memastikan keunikan dan ketidakpastian. 4. Dalam pembangunan sebenar, pangkalan data dalam memori seperti REDIS boleh digunakan untuk menyimpan data sesi untuk meningkatkan prestasi dan keselamatan.

Bagaimanakah anda mengendalikan sesi dalam persekitaran tanpa kerakyatan (mis., API)?Bagaimanakah anda mengendalikan sesi dalam persekitaran tanpa kerakyatan (mis., API)?Apr 24, 2025 am 12:12 AM

Menguruskan sesi dalam persekitaran tanpa kerakyatan seperti API boleh dicapai dengan menggunakan JWT atau cookies. 1. JWT sesuai untuk ketiadaan dan skalabilitas, tetapi ia adalah saiz yang besar ketika datang ke data besar. 2.Cookies lebih tradisional dan mudah dilaksanakan, tetapi mereka perlu dikonfigurasikan dengan berhati -hati untuk memastikan keselamatan.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual