最近应业务需求,做了支付宝支付和微信支付,今天分享一下手机端app支付宝支付对接流程,实际开发过程是前后端分离,前端调用后端API接口,实现功能返回数据,我所用的跨挤啊为TP5,大致可以分为四步:

1.在蚂蚁金服开放平台创建应用,签约商户,生成应用公钥和私钥;

2.配置统一下单支付参数;

3.整合支付宝demo类文件;

4.创建Alipay支付类,类内创建两个方法(alipay_app:统一下单方法和alipay_notify:支付成功异步回调方法);

第一步主要是在蚂蚁金服开放平台登录你的支付宝账号,接入支付功能,个人就选个人,服务商就选服务商,需要填写一些材料,如手机号,邮箱等,完成后就可以创建应用啦,创建应用完成后需要进行签约,只有签约之后你应用里面开放的支付功能才会生效,签约也需要填一堆信息,签约需要审核,成功后你会拿到一个2088开头partner值,这个第三步配置参数的时候需要用到,之后还要为你的应用生成公钥和私钥,这点在开放平台开发文档中有详细描述,下载生成秘钥工具,选择对应的秘钥类型,秘钥和公钥一定要保存好,这里就不多做赘述啦,到此开放平台的准备工作就结束了。

第二步就是整合支付宝demo文件了,我这里已经整合好了,直接把代码复制到两个文件中就可以了,一个为支付类,一个为通知类:

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

254

255

256

257

258

259

260

261

262

263

264

265

266

267

268

269

270

271

272

273

274

275

276

277

278

279

280

281

282

283

284

285

286

287

288

289

290

291

292

293

294

/*此为支付类*/

class AlipayApp{

 /**

  * 把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串

  * @param $para 需要拼接的数组

  * return 拼接完成以后的字符串

  */

 function createLinkstring($para,$showQuotes = false) {

  // $arg = "";

  // while (list ($key, $val) = each ($para)) {

  // $arg.=$key."=".$val."&";

  // }

  ////去掉最后一个&字符

  // $arg = substr($arg,0,count($arg)-2);

  ////如果存在转义字符,那么去掉转义

  // if(get_magic_quotes_gpc()){$arg = stripslashes($arg);}

  // return $arg;

  $arg = "";

  $quotes = '';

  if($showQuotes){

   $quotes = '"';

  }

  foreach ($para as $key => $val) {

   if($arg == ''){

    $arg = $key.'='.$quotes.$val.$quotes;

   }else{

    $arg = $arg.'&'.$key.'='.$quotes.$val.$quotes;

   }

  }

  if(get_magic_quotes_gpc()){$arg = stripslashes($arg);}

  return $arg;

 }

 /**

  * 对数组排序

  * @param $para 排序前的数组

  * return 排序后的数组

  */

 function argSort($para) {

  ksort($para);

  reset($para);

  return $para;

 }

 /**

  * 除去数组中的空值和签名参数

  * @param $para 签名参数组

  * return 去掉空值与签名参数后的新签名参数组

  */

 function paraFilter($para) {

  $para_filter = array();

  while (list ($key, $val) = each ($para)) {

   if($key == "sign" || $key == "sign_type" || $val == "")continue;

   else$para_filter[$key] = $para[$key];

  }

  return $para_filter;

 }

 function query_timestamp() {

  $url = $this->alipay_gateway_new."service=query_timestamp&partner=".trim(strtolower($this->alipay_config['partner']))."&_input_charset=".trim(strtolower($this->alipay_config['input_charset']));

  $encrypt_key = "";

  $doc = new DOMDocument();

  $doc->load($url);

  $itemEncrypt_key = $doc->getElementsByTagName( "encrypt_key" );

  $encrypt_key = $itemEncrypt_key->item(0)->nodeValue;

  return $encrypt_key;

 }

 /**

  * 写日志,方便测试(看网站需求,也可以改成把记录存入数据库)

  * 注意:服务器需要开通fopen配置

  * @param $word 要写入日志里的文本内容 默认值:空值

  */

 function logResult($word='') {

  date_default_timezone_set("PRC");

  $fp = fopen("log.txt","a");

  flock($fp, LOCK_EX) ;

  fwrite($fp,"执行日期:".strftime("%Y%m%d%H%M%S",time())."\n".$word."\n");

  flock($fp, LOCK_UN);

  fclose($fp);

 }

 /**

  * 远程获取数据,POST模式

  * 注意:

  * 1.使用Crul需要修改服务器中php.ini文件的设置,找到php_curl.dll去掉前面的";"就行了

  * 2.文件夹中cacert.pem是SSL证书请保证其路径有效,目前默认路径是:getcwd().'\\cacert.pem'

  * @param $url 指定URL完整路径地址

  * @param $cacert_url 指定当前工作目录绝对路径

  * @param $para 请求的数据

  * @param $input_charset 编码格式。默认值:空值

  * return 远程输出的数据

  */

 function getHttpResponsePOST($url, $cacert_url, $para, $input_charset = '') {

  if (trim($input_charset) != '') {

   $url = $url."_input_charset=".$input_charset;

  }

  $curl = curl_init($url);

  curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);//SSL证书认证

  curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);//严格认证

  curl_setopt($curl, CURLOPT_CAINFO,$cacert_url);//证书地址

  curl_setopt($curl, CURLOPT_HEADER, 0 ); // 过滤HTTP头

  curl_setopt($curl,CURLOPT_RETURNTRANSFER, 1);// 显示输出结果

  curl_setopt($curl,CURLOPT_POST,true); // post传输数据

  curl_setopt($curl,CURLOPT_POSTFIELDS,$para);// post传输数据

  $responseText = curl_exec($curl);

  //var_dump( curl_error($curl) );//如果执行curl过程中出现异常,可打开此开关,以便查看异常内容

  curl_close($curl);

  return $responseText;

 }

 /**

  * 远程获取数据,GET模式

  * 注意:

  * 1.使用Crul需要修改服务器中php.ini文件的设置,找到php_curl.dll去掉前面的";"就行了

  * 2.文件夹中cacert.pem是SSL证书请保证其路径有效,目前默认路径是:getcwd().'\\cacert.pem'

  * @param $url 指定URL完整路径地址

  * @param $cacert_url 指定当前工作目录绝对路径

  * return 远程输出的数据

  */

 function getHttpResponseGET($url,$cacert_url) {

  $curl = curl_init($url);

  curl_setopt($curl, CURLOPT_HEADER, 0 ); // 过滤HTTP头

  curl_setopt($curl,CURLOPT_RETURNTRANSFER, 1);// 显示输出结果

  curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);//SSL证书认证

  curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);//严格认证

  curl_setopt($curl, CURLOPT_CAINFO,$cacert_url);//证书地址

  $responseText = curl_exec($curl);

  //var_dump( curl_error($curl) );//如果执行curl过程中出现异常,可打开此开关,以便查看异常内容

  curl_close($curl);

  return $responseText;

 }

 /**

  * 实现多种字符编码方式

  * @param $input 需要编码的字符串

  * @param $_output_charset 输出的编码格式

  * @param $_input_charset 输入的编码格式

  * return 编码后的字符串

  */

 function charsetEncode($input,$_output_charset ,$_input_charset) {

  $output = "";

  if(!isset($_output_charset) )$_output_charset = $_input_charset;

  if($_input_charset == $_output_charset || $input ==null ) {

   $output = $input;

  } elseif (function_exists("mb_convert_encoding")) {

   $output = mb_convert_encoding($input,$_output_charset,$_input_charset);

  } elseif(function_exists("iconv")) {

   $output = iconv($_input_charset,$_output_charset,$input);

  } else die("sorry, you have no libs support for charset change.");

  return $output;

 }

 /**

  * 实现多种字符解码方式

  * @param $input 需要解码的字符串

  * @param $_output_charset 输出的解码格式

  * @param $_input_charset 输入的解码格式

  * return 解码后的字符串

  */

 function charsetDecode($input,$_input_charset ,$_output_charset) {

  $output = "";

  if(!isset($_input_charset) )$_input_charset = $_input_charset ;

  if($_input_charset == $_output_charset || $input ==null ) {

   $output = $input;

  } elseif (function_exists("mb_convert_encoding")) {

   $output = mb_convert_encoding($input,$_output_charset,$_input_charset);

  } elseif(function_exists("iconv")) {

   $output = iconv($_input_charset,$_output_charset,$input);

  } else die("sorry, you have no libs support for charset changes.");

  return $output;

 }

 /**

  * RSA签名

  * @param $data 待签名数据

  * @param $private_key 商户私钥字符串

  * return 签名结果

  */

 function rsaSign($data, $private_key) {

  //以下为了初始化私钥,保证在您填写私钥时不管是带格式还是不带格式都可以通过验证。

  $private_key=str_replace("-----BEGIN RSA PRIVATE KEY-----","",$private_key);

  $private_key=str_replace("-----END RSA PRIVATE KEY-----","",$private_key);

  $private_key=str_replace("\n","",$private_key);

  $private_key="-----BEGIN RSA PRIVATE KEY-----".PHP_EOL .wordwrap($private_key, 64, "\n", true). PHP_EOL."-----END RSA PRIVATE KEY-----";

  $res=openssl_get_privatekey($private_key);

  if($res)

  {

   openssl_sign($data, $sign,$res);

  }

  else {

   echo "您的私钥格式不正确!"."<br/>"."The format of your private_key is incorrect!";

   exit();

  }

  openssl_free_key($res);

  //base64编码

  $sign = base64_encode($sign);

  return $sign;

 }

 /**

  * RSA验签

  * @param $data 待签名数据

  * @param $alipay_public_key 支付宝的公钥字符串

  * @param $sign 要校对的的签名结果

  * return 验证结果

  */

 function rsaVerify($data, $alipay_public_key, $sign) {

  //以下为了初始化私钥,保证在您填写私钥时不管是带格式还是不带格式都可以通过验证。

  $alipay_public_key=str_replace("-----BEGIN PUBLIC KEY-----","",$alipay_public_key);

  $alipay_public_key=str_replace("-----END PUBLIC KEY-----","",$alipay_public_key);

  $alipay_public_key=str_replace("\n","",$alipay_public_key);

  $alipay_public_key='-----BEGIN PUBLIC KEY-----'.PHP_EOL.wordwrap($alipay_public_key, 64, "\n", true) .PHP_EOL.'-----END PUBLIC KEY-----';

  $res=openssl_get_publickey($alipay_public_key);

  if($res)

  {

   $result = (bool)openssl_verify($data, base64_decode($sign), $res);

  }

  else {

   echo "您的支付宝公钥格式不正确!"."<br/>"."The format of your alipay_public_key is incorrect!";

   exit();

  }

  openssl_free_key($res);

  return $result;

 }

}

  

/* *

 * 类名:AlipayNotify

 * 功能:支付宝通知处理类

 * 详细:处理支付宝各接口通知返回

 * 版本:1.0

 * 日期:2016-06-06

 * 说明:

 * 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。

 * 该代码仅供学习和研究支付宝接口使用,只是提供一个参考

 *************************注意*************************

 * 调试通知返回时,可查看或改写log日志的写入TXT里的数据,来检查通知返回是否正常

 */

class AlipayNotify {

 /**

  * HTTPS形式消息验证地址

  */

 var $https_verify_url = 'https://mapi.alipay.com/gateway.do?service=notify_verify&';

 /**

  * HTTP形式消息验证地址

  */

 var $http_verify_url = 'http://notify.alipay.com/trade/notify_query.do?';

 var $alipay_config;

 function __construct($alipay_config){

  $this->alipay_config = $alipay_config;

 }

 function AlipayNotify($alipay_config) {

  $this->__construct($alipay_config);

 }

 /**

  * 获取返回时的签名验证结果

  * @param $para_temp 通知返回来的参数数组

  * @param $sign 返回的签名结果

  * @return 签名验证结果

  */

 function getSignVeryfy($para_temp, $sign) {

  $alipayapp = new \Alipayapp();

  //除去待签名参数数组中的空值和签名参数

  $para_filter = $alipayapp->paraFilter($para_temp);

  //对待签名参数数组排序

  $para_sort = $alipayapp->argSort($para_filter);

  //把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串

  $prestr = $alipayapp->createLinkstring($para_sort);

  $isSgin = false;

  switch (strtoupper(trim($this->alipay_config['sign_type']))) {

   case "RSA" :

    $isSgin = $alipayapp->rsaVerify($prestr, trim($this->alipay_config['alipay_public_key']), $sign);

    break;

   default :

    $isSgin = false;

  }

  return $isSgin;

 }

 /**

  * 获取远程服务器ATN结果,验证返回URL

  * @param $notify_id 通知校验ID

  * @return 服务器ATN结果

  * 验证结果集:

  * invalid命令参数不对 出现这个错误,请检测返回处理中partner和key是否为空

  * true 返回正确信息

  * false 请检查防火墙或者是服务器阻止端口问题以及验证时间是否超过一分钟

  */

 function getResponse($notify_id) {

  $alipayapp = new \Alipayapp();

  $transport = strtolower(trim($this->alipay_config['transport']));

  $partner = trim($this->alipay_config['partner']);

  $veryfy_url = '';

  if($transport == 'https') {

   $veryfy_url = $this->https_verify_url;

  }

  else {

   $veryfy_url = $this->http_verify_url;

  }

  $veryfy_url = $veryfy_url."partner=" . $partner . "&notify_id=" . $notify_id;

  $responseTxt = $alipayapp->getHttpResponseGET($veryfy_url, $this->alipay_config['cacert']);

  return $responseTxt;

 }

}

第三步配置参数:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

//配置参数

public $alipay_config = array(

 //2088开头

 'partner' => '',

 //商户的私钥,此处填写原始私钥去头去尾,RSA公私钥生成:https://doc.open.alipay.com/doc2/detail.htm?spm=a219a.7629140.0.0.nBDxfy&treeId=58&articleId=103242&docType=1

 'private_key' => '',

 //支付宝的公钥,查看地址:https://openhome.alipay.com/platform/keyManage.htm?keyType=partner

 'alipay_public_key' => '',

 //异步通知接口

 'service'=> 'mobile.securitypay.pay',

 //字符编码格式 目前支持 gbk 或 utf-8

 'input_charset' => 'utf-8',

 //签名方式 不需修改

 'sign_type' => 'RSA',

 //ca证书路径地址,用于curl中ssl校验

 //请保证cacert.pem文件在当前文件夹目录中

 'cacert' => '/cacert.pem',

 //访问模式,根据自己的服务器是否支持ssl访问,若支持请选择https;若不支持请选择http

 'transport' => 'http',

);

创建$alipa_config属性,可以放到你的配置文件中方便引入,也可以直接放到Alipay类中,里面只要前三项需要自己填写,其余不变就好啦。

第四步就是创建Alipay类,类内定义两个方法,一个是alipay_app(统一下单),alipay_app中的一些参数需要自己补全,参数介绍点我,另一个是alipay_notify(支付成功后的异步回调)并引入第二步创建的两个类文件,本人开发用的是TP5框架,支付类放在第三方类库vendor目录下面,可以直接在控制器中用vendor()函数引入文件,例:vendor('Alipayapp.lib.alipay_notify');

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

//调用统一下单接口生成预支付订单并把数据返回给APP

public function alipay_app(Request $request)

{

 vendor('Alipayapp.lib.AlipayApp');

 $param = $request->param();

 $tade_no = $param['orderCode'];//订单号 调用统一下单接口需要提供一个订单号

 $order = new Order(); //实例化订单

 $ret = $order->getOrderN2($tade_no); //查询订单信息 此处为我自己的查询订单信息方法,可以替换为你自己的

 $strOrg['partner']=$this->alipay_config['partner']; // 配置的partner

 $strOrg['seller_id']=$this->alipay_config['partner']; // 此处和partner值一样即可

 $strOrg['out_trade_no']=$tade_no; // 订单号

 $strOrg['subject']=""; // 商品的标题

 $strOrg['body']="";//商品名

 $strOrg['total_fee']=$ret['money'];// 金额

 $strOrg['notify_url']="";//回调地址,填写回调方法的绝对路径

 $strOrg['service']=$this->alipay_config['service'];

 $strOrg['payment_type']="1";

 $strOrg['_input_charset']="utf-8";

 $strOrg['it_b_pay']="30m";

 $alipay = new \Alipayapp();

 //将post接收到的数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串。

 $data=$alipay->createLinkstring($strOrg,true);//,true

 //将待签名字符串使用私钥签名,且做urlencode. 注意:请求到支付宝只需要做一次urlencode.

 $rsa_sign=urlencode($alipay->rsaSign($data, $this->alipay_config['private_key']));

 //把签名得到的sign和签名类型sign_type拼接在待签名字符串后面。

 $data = $data.'&sign='.'"'.$rsa_sign.'"'.'&sign_type='.'"'.$this->alipay_config['sign_type'].'"';

 //返回给客户端,建议在客户端使用私钥对应的公钥做一次验签,保证不是他人传输。

 $datajson['mdata']=$data;

 echo json_encode($datajson);

}

//支付成功后的回调方法

public function alipay_notify()

{

 vendor('Alipayapp.lib.alipay_notify');//引入支付通知类文件

 $alipayNotify = new \AlipayNotify($this->alipay_config);

 $order = new Order(); //实例化订单

 if($alipayNotify->getResponse($_POST['notify_id'])) //判断成功之后使用getResponse方法判断是否是支付宝发来的异步通知。

 {

  if($alipayNotify->getSignVeryfy($_POST, $_POST['sign'])) {//使用支付宝公钥验签

   //获取支付宝的通知返回参数,可参考技术文档中服务器异步通知参数列表

   //商户订单号

   $out_trade_no = $_POST['out_trade_no'];

   $ret = $order->getOrderN2($out_trade_no); //查询订单信息

   $total_amount=$ret['money']; //订单金额

   $total_fee = $_POST['total_fee']; //支付宝返回金额

   if($_POST['trade_status'] == 'TRADE_FINISHED') {

    //判断该笔订单是否在商户网站中已经做过处理

    //如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序

    //如果有做过处理,不执行商户的业务程序

    //注意:

    //退款日期超过可退款期限后(如三个月可退款),支付宝系统发送该交易状态通知

    //请务必判断请求时的out_trade_no、total_fee、seller_id与通知时获取的out_trade_no、total_fee、seller_id为一致的

    if($total_amount==$total_fee){

     //这里进行数据库操作,比如修改订单状态等

    }

   }else if ($_POST['trade_status'] == 'TRADE_SUCCESS') {

    //判断该笔订单是否在商户网站中已经做过处理,如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程

    //如果有做过处理,不执行商户的业务程序

    //注意:

    //付款完成后,支付宝系统发送该交易状态通知

    //请务必判断请求时的out_trade_no、total_fee、seller_id与通知时获取的out_trade_no、total_fee、seller_id为一致的

    if($total_amount==$total_fee){

     //这里进行数据库操作,比如修改订单状态等

    }

   }

   echo "success"; //请不要修改或删除

  }else{ //验证签名失败

   echo "sign fail";

  }

 }else{ //验证是否来自支付宝的通知失败

  echo "response fail";

 }

}

上述getOrderN2方法是我查询订单信息用的,需要替换成你自己的查询订单方法,以上四步完成正常的话支付宝支付功能就可以实现了,需要注意的是支付功能简单的在本地测试是不可以的,需要在服务器上测试,也有说用花生壳什么的...这个我没有研究,如果没有成功查看报错提示,在对接支付时有很多坑,遇到报错不要急,逐步解决一定可以实现支付功能的,如果自己实在解决不了的可以找支付宝技术人员,如果你想查看支付宝异步通知时的返回值,可以用 file_put_contents() 函数打印返回的参数,会在你指定的路径生成一个文件,里面就是返回的值啦。

使用PHP实现手机端APP支付宝的支付功能的更多相关文章

  1. 11.采集手机端app企查查上司公司数据(未成功)

    ---恢复内容开始--- 采集企查查手机端app数据: 1.首先手机端安装app并usb连接电脑端,fiddler监控手机请求数据对数据进行分析抓取. 手机端界面与fiddler界面参照: 2.对获取 ...

  2. 网络爬虫中Fiddler抓取PC端网页数据包与手机端APP数据包

    1 引言 在编写网络爬虫时,第一步(也是极为关键一步)就是对网络的请求(request)和回复(response)进行分析,寻找其中的规律,然后才能通过网络爬虫进行模拟.浏览器大多也自带有调试工具可以 ...

  3. 【阿里云IoT+YF3300】14.阿里IoT Studio打造手机端APP

    在上一篇<13.阿里云IoT Studio WEB监控界面构建>中,我们介绍了用阿里云IoT Studio(原Link Develop)可视化构建WEB界面程序.本篇文章将介绍用阿里云Io ...

  4. 通过chrome识别手机端app元素--Chrome:inspector

    现实中应该有这样一种情况,就是一个app只支持手机端使用,同时他又是hybrid的,那么其中的webview部分的元素属性如何去获得呢? 使用下面的方法可以解决这个问题: 调试 Android Chr ...

  5. 手机端app开发初识

    1.所需软件说明 百度云下载链接: https://pan.baidu.com/s/1-TEQZP9QbJSlGSYedyAUFw密码: 2z8l 或者官方链接: Hbuilder:http://ww ...

  6. PC端写的API接口和手机端APP联合调试

    一.遇到问题的情况:项目框架:asp.net MVC5 ,写的给手机端调用的API接口. 二.自己在本地 IIS上部署项目,在手机端的请求服务器上把地址和端口换上本地部署的,如图所示 三.用管理员的身 ...

  7. App对接支付宝移动支付功能

    前段时间看了下app对接支付宝移动支付的功能,并自己总结了下支付宝移动支付的实现流程 一.申请流程          前提是已有现成的应用. 1.  申请地址            https://b ...

  8. 移动APP 支付宝快捷支付开发流程

    [代码] [Java]代码 ? 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 ...

  9. 手机端APP原型相关

    http://www.isux.us/demoo/index.php(很慢) https://www.mockplus.cn/

随机推荐

  1. QVector也是隐式数据共享的

    Behind the scenes, QString uses implicit sharing (copy-on-write) to reduce memory usage and to avoid ...

  2. when to use reinterpret_cast

    写的太好了.. When you convert for example int(12) to unsigned float (12.0f) your processor needs to invok ...

  3. mass

    @python青岛qq群 1.爬取豆瓣,登录一次爬取后再循环就退出登录,抓不到了: 2.用requests.session试试,只要session对象不释放,就能记住登录状态的cookie: 3.se ...

  4. Could not read document: Can not deserialize instance of java.lang.String out of START_ARRAY

    线上问题: { "timestamp": "1544510665", "status": 400, "error": & ...

  5. random模块的学习

    import random # ret = random.random() #随机取0-1中间的浮点数 # ret = random.randint(1,3) #随机取1-3中间的整数 # ret = ...

  6. NodeJs 使用 multer 实现文件上传

    Multer 是一个 node.js 中间件,用于处理 multipart/form-data 类型的表单数据,它主要用于上传文件 注意: Multer 不会处理任何非 multipart/form- ...

  7. 关于background-size 的一点小坑

    目前在做一个网页,要求使用一个图片作为背景,必须要全屏目填充,于是我想,这不是很简单的事情么: 有两种实现方法:首先设置添加一个div(或者body),把div(或者body)元素的宽和高都设置成10 ...

  8. spring三大核心

    IOC(控制反转) 下面是多个针对此理解的表达. 一个对象A依赖另一个对象B就要自己去new 这是高度耦合的 IOC容器的使用. 比如在B中使用A很多,哪一天A大量更改,那么B中就要修改好多代码. 通 ...

  9. Vue相关文章

    1.新手向:Vue 2.0 的建议学习顺序 2.用webstorm搭建vue项目 3.vue-cli3.0项目结构

  10. [Tools] 一种调试 Android App 接口的方式 (Fiddler/Wireshark)

    要求:Windows电脑与手机在同一局域网内(Wifi). [ Fiddler 设置代理 ] 下载地址:https://www.telerik.com/download/fiddler 依次 Tool ...