微信发送红包示例(php)

简介: 微信红包接口微信红包是微信支付推出的一款基于微信客户端的免费服务应用,微信红包以微信支付为核心安全保障,为广大用户提供安全,快捷的移劢支付服务。 请求URL现金红包https://api.mch.

微信红包接口

微信红包是微信支付推出的一款基于微信客户端的免费服务应用,微信红包以微信支付

为核心安全保障,为广大用户提供安全,快捷的移劢支付服务。

 

请求URL

现金红包

https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack

 

裂变红包

https://api.mch.weixin.qq.com/mmpaymkttransfers/sendgroupredpack

 

企业付款

https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers

请求的参数:

3924735281.png

以现金红包为例:请求参数示例:

 <xml>
	<act_name>123123</act_name>
	<client_ip>
		<![CDATA[127.0.0.1]]>
	</client_ip>
	<mch_billno>
		1281216601201609200000000000
	</mch_billno>
	<mch_id>1281216601</mch_id>
	<nonce_str>
		<![CDATA[CgSaD2zSG6ds2r2ulSuSmj3zKUXSukSS]]>
	</nonce_str>
	<re_openid>
		<![CDATA[okzyKwbDW-d7Spc0M112zWZjaa3E]]>
	</re_openid>
	<remark>
		1231
	</remark>
	<send_name>
		<![CDATA[haha哈]]>
	</send_name>
	<total_amount>1.00</total_amount>
	<total_num>1</total_num>
	<wishing>
		<![CDATA[祝您好运]]>
	</wishing>
	<wxappid>
		<![CDATA[wxa316d1ce30f2c952]]>
	</wxappid>
	<sign>
		<![CDATA[52F30DAD7E0ADFA842627179502BC2F3]]>
	</sign>
</xml>

核心代码如下:

$config里面包含了必须的appid,和其他参数,可以看上图详情。只需调用yiy_send(要发送给谁的(openid),金额,配置参数)
/*随机字符串*/
	private function random($length, $numeric = FALSE) {
		$seed = base_convert(md5(microtime() . $_SERVER['DOCUMENT_ROOT']), 16, $numeric ? 10 : 35);
		$seed = $numeric ? (str_replace('0', '', $seed) . '012340567890') : ($seed . 'zZ' . strtoupper($seed));
		if ($numeric) {
			$hash = '';
		} else {
			$hash = chr(rand(1, 26) + rand(0, 1) * 32 + 64);
			$length--;
		}
		$max = strlen($seed) - 1;
		for ($i = 0; $i < $length; $i++) {
			$hash .= $seed{mt_rand(0, $max)};
		}
		return $hash;
	}

	//发送红包
	private function yiy_send($openid,$price,$config) {
		$uniacid = 2;
		$api = $config['api'];
		$activity = $config['activity'];
		$url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack';
		$pars = array();
		$pars['nonce_str'] = $this->random(32);
		$pars['mch_billno'] = $api['mchid'] . date('YmdHis');
		$pars['mch_id'] = $api['mchid'];
		$pars['wxappid'] = $api['appid'];
		$pars['send_name'] = $activity['provider'];
		$pars['re_openid'] = $openid;
		$pars['total_amount'] = $price*100;
		$pars['total_num'] = 1;
		$pars['wishing'] = $activity['wish'];
		$pars['client_ip'] = $api['ip'];
		$pars['act_name'] = $activity['title'];
		$pars['remark'] = $activity['remark'];
	
		ksort($pars);
		$string1 = '';
		foreach($pars as $k => $v) {
			$string1 .= "{$k}={$v}&";
		}
		$string1 .= "key={$api['password']}";
		$pars['sign'] = strtoupper(md5($string1));
		$xml = $this->array2xml($pars);
		define(M_PATH, dirname(__FILE__). '/./../../../../addons/ly_huilife/');
		$extras = array();
		//此处为证书位置(绝对路径),改成适合自己的,我这里放的比较那啥。。。。忽略///
		$extras['CURLOPT_CAINFO'] = M_PATH . '/cert/rootca.pem.' . $uniacid;
		$extras['CURLOPT_SSLCERT'] = M_PATH . '/cert/apiclient_cert.pem.' . $uniacid;
		$extras['CURLOPT_SSLKEY'] = M_PATH . '/cert/apiclient_key.pem.' . $uniacid;
		$procResult = null;
		$resp = $this->CurlPostSsl($url, $xml, $extras);
		return $resp;
	}

	//提交
	private function CurlPostSsl($url,$xml,$extras){
		$ch = curl_init();   
		curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60);	
		curl_setopt($ch,CURLOPT_TIMEOUT,60);
		curl_setopt($ch,CURLOPT_RETURNTRANSFER, 1);    	
		curl_setopt($ch,CURLOPT_URL,$url);
		curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
		curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,false);
		curl_setopt($ch, CURLOPT_SSLVERSION, 1);
		curl_setopt($ch,CURLOPT_SSLCERT,$extras['CURLOPT_SSLCERT']);    	
		curl_setopt($ch,CURLOPT_SSLKEY,$extras['CURLOPT_SSLKEY']);
		curl_setopt($ch,CURLOPT_CAINFO,$extras['CURLOPT_CAINFO']);
		curl_setopt($ch,CURLOPT_POST, 1);
		curl_setopt($ch,CURLOPT_POSTFIELDS,$xml);
		$data = curl_exec($ch);
		var_dump($data);
		if($data){
			curl_close($ch);            
			$rsxml = simplexml_load_string($data);
			if($rsxml->return_code == 'SUCCESS' && $rsxml->result_code == 'SUCCESS'){
				return array('code'=>1,'msg'=>'发放成功');
			}else{
			//这里你可以获取,并返回详细失败信息,我这里都用这种方式返回了。
				return array('code'=>0,'msg'=>'#1未知错误,稍后再试');    
			}
		}else{ 
			$error = curl_errno($ch);
			curl_close($ch);
			return array('code'=>0,'msg'=>$error );
		}
	}

	function array2xml($arr, $level = 1) {
		$s = $level == 1 ? "<xml>" : '';
		foreach ($arr as $tagname => $value) {
			if (is_numeric($tagname)) {
				$tagname = $value['TagName'];
				unset($value['TagName']);
			}
			if (!is_array($value)) {
				$s .= "<{$tagname}>" . (!is_numeric($value) ? '<![CDATA[' : '') . $value . (!is_numeric($value) ? ']]>' : '') . "</{$tagname}>";
			} else {
				$s .= "<{$tagname}>" . array2xml($value, $level + 1) . "</{$tagname}>";
			}
		}
		$s = preg_replace("/([\x01-\x08\x0b-\x0c\x0e-\x1f])+/", ' ', $s);
		return $level == 1 ? $s . "</xml>" : $s;
	}

正确的返回结果是:

QQ图片20160920230430.pngQQ截图20160920224924.png

注意:传入的金额是以分为单位,比如1元,要写成100,不然红包过小会失败的(红包大于等于1元,小于等于200元),比如这样返回:

<xml>
<return_code><![CDATA[SUCCESS]]></return_code>
<return_msg><![CDATA[每个红包的平均金额必须在1.00元到200.00元之间.]]></return_msg>
<result_code><![CDATA[FAIL]]></result_code>
<err_code><![CDATA[MONEY_LIMIT]]></err_code>
<err_code_des><![CDATA[每个红包的平均金额必须在1.00元到200.00元之间.]]></err_code_des>
<mch_billno><![CDATA[1281216601201609200000000000]]></mch_billno>
<mch_id><![CDATA[1281216601]]></mch_id>
<wxappid><![CDATA[wxa316d1ce30f2c952]]></wxappid>
<re_openid><![CDATA[okzyKwbDW-d7Spc0M112zWZjaa3E]]></re_openid>
<total_amount>1</total_amount>
</xml>

更详细的文档:官方pdf:https://pay.weixin.qq.com/helper/cashredopenapi_V2.pdf

将编程看作是一门艺术,而不单单是个技术。 敲打的英文字符是我的黑白琴键, 思维图纸画出的是我编写的五线谱。 当美妙的华章响起,现实通往二进制的大门即将被打开。
相关文章
ly~
|
2月前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
81 6
|
5月前
|
存储 算法 安全
PHP AES加解密示例
PHP AES加解密示例
112 0
PHP AES加解密示例
|
1月前
|
云安全 存储 小程序
PHP微信小程序解决方案PhpMall
PHP微信小程序解决方案PhpMall
41 0
|
2月前
|
缓存 NoSQL PHP
使用PHP-redis实现键空间通知监听key失效事件的技术与代码示例
通过上述方法,你可以有效地在PHP中使用Redis来监听键空间通知,特别是针对键失效事件。这可以帮助你更好地管理缓存策略,及时响应键的变化。
96 3
|
3月前
|
SQL 安全 API
PHP代码审计示例(一)——淡然点图标系统SQL注入漏洞审计
PHP代码审计示例(一)——淡然点图标系统SQL注入漏洞审计
93 4
|
3月前
|
PHP
php使用方式示例
【8月更文挑战第2天】php使用方式示例
33 2
|
3月前
|
PHP
【Azure Developer】PHP网站使用AAD授权登录的参考示例
【Azure Developer】PHP网站使用AAD授权登录的参考示例
|
4月前
|
测试技术 PHP 开发者
原生php单元测试示例
通过上面的示例,我们可以看到,即使在缺乏专门测试框架的情况下,使用原生PHP代码进行基本的单元测试也是完全可行的。当然,对于更复杂的项目,利用像PHPUnit这样的专业工具将带来更多的便利和高级功能。不过,理解单元测试的基本概念和能够手工编写测试是每个PHP开发者的宝贵技能。
37 4
|
4月前
|
测试技术 PHP 开发者
原生php单元测试示例
通过上面的示例,我们可以看到,即使在缺乏专门测试框架的情况下,使用原生PHP代码进行基本的单元测试也是完全可行的。当然,对于更复杂的项目,利用像PHPUnit这样的专业工具将带来更多的便利和高级功能。不过,理解单元测试的基本概念和能够手工编写测试是每个PHP开发者的宝贵技能。
23 1
|
5月前
|
PHP 开发工具
php免费用免认证的微信支付宝支付
php免费用免认证的微信支付宝支付
41 5