php之红包发放规则

php之红包发放规则,第1张

使用PHP发红包,当我们输入红包数量和总金额后,PHP会根据这两个值进行随机分配每个金额,保证每个人都能领取到一个红包,每个红包金额不等,就是要求红包金额要有差异,所有红包金额总额应该等于总金额。

代码有两个php文件

1.oauth2.php

<?php

$code=$_GET['code']

$state=$_GET['state']

$appid='XXXX'

$appsecret='XXXXXXXX'//

if (empty($code)) $this->error('授权失败')

$token_url='https://api.weixin.qq.com/sns/oauth2/access_token?appid='.$appid'&secret='.$appsecret.'&code='.$code.'&grant_type=authorization_code'

$token=json_decode(file_get_contents($token_url))

if (isset($token->errcode)) {

echo '<h1>错误1</h1>'.$token->errcode

echo '<br/><h2>错误信息1:</h2>'.$token->errmsg

exit

}

session_start()

$_SESSION['openid']= $token->openid

header('location:url/redpack.php')//要跳转的文件路径

?>

2.redpack.php

<?php

//XXXXX。。是需要开发者自己填写的内容,注意不要泄密

 // 从session中获取到openid;

$openid=$_SESSION["openid"]

    if(empty($openid))

    {

header('location:https://open.weixin.qq.com/connect/oauth2/authorize?appid=XXXXXXXX&redirect_uri=http://www.XXXXXXX.com/oauth2.php&respose_type=code&scope=snsapi_base&state=XXXX&connect_redirect=1#wechat_redirect')

    }

}

// 关键的函数

public function weixin_red_packet(){

  // 请求参数

  // 随机字符串

  $data['nonce_str']=$this->get_unique_value()

  //商户号,输入你的商户号

  $data['mch_id']="XXXXXXX"

  //商户订单号,可以按要求自己组合28位的商户订单号

  $data['mch_billno']=$data['mch_id'].date("ymd")."XXXXXX".rand(1000,9999)

  //公众帐号appid,输入自己的公众号appid

  $data['wxappid']="XXXXXXX"

  //商户名称

  $data['send_name']="XXXXX"

  //用户openid,输入待发红包的用户openid

  session_start()

  $data['re_openid']=$_SESSION["openid"]

  //付款金额

  $data['total_amount']="XXXX"

  //红包发放总人数

  $data['total_num']="XXXX"

  //红包祝福语

  $data['wishing']="XXXX"

  //IP地址

  $data['client_ip']=$_SERVER['LOCAL_ADDR']

  //活动名称

  $data['act_name']="XXXXX"

  //备注

  $data['remark']="XXXXX"

  // 生成签名

  //对数据数组进行处理

  //API密钥,输入自己的K 微信商户号里面的K

  $appsecret="XXXXXXXXXXXXXX" //

  $data=array_filter($data)

  ksort($data)

  $str=""

  foreach($data as $k=>$v){

    $str.=$k."=".$v."&"

  }

  $str.="key=".$appsecret

  $data['sign']=strtoupper(MD5($str))

  /*

    发红包 *** 作过程:

      1.将请求数据转换成xml

      2.发送请求

      3.将请求结果转换为数组

      4.将请求信息和请求结果录入到数据库中

      4.判断是否通信成功

      5.判断是否转账成功

   */

  //发红包接口地址

  $url="https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack"

  //将请求数据由数组转换成xml

  $xml=$this->arraytoxml($data)

  //进行请求 *** 作

  $res=$this->curl($xml,$url)

  //将请求结果由xml转换成数组

  $arr=$this->xmltoarray($res)

}

// 生成32位唯一随机字符串

private function get_unique_value(){

  $str=uniqid(mt_rand(),1)

  $str=sha1($str)

  return md5($str)

}

// 将数组转换成xml

private function arraytoxml($arr){

  $xml="<xml>"

  foreach($arr as $k=>$v){

    $xml.="<".$k.">".$v."</".$k.">"

  }

  $xml.="</xml>"

  return $xml

}

// 将xml转换成数组

private function xmltoarray($xml){

  //禁止引用外部xml实体

  libxml_disable_entity_loader(true)

  $xmlstring=simplexml_load_string($xml,"SimpleXMLElement",LIBXML_NOCDATA)

  $arr=json_decode(json_encode($xmlstring),true)

  return $arr

}

//进行curl *** 作

private function curl($param="",$url) {

  $postUrl = $url

  $curlPost = $param

  //初始化curl

  $ch = curl_init()

  //抓取指定网页

  curl_setopt($ch, CURLOPT_URL,$postUrl)

  //设置header

  curl_setopt($ch, CURLOPT_HEADER, 0)

  //要求结果为字符串且输出到屏幕上

  curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1)

  //post提交方式

  curl_setopt($ch, CURLOPT_POST, 1)

  // 增加 HTTP Header(头)里的字段

  curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost)

  // 终止从服务端进行验证

  curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE)

  curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE)

  //证书放到网站根目录的cert文件夹底下

  curl_setopt($ch,CURLOPT_SSLCERT,dirname(__FILE__).DIRECTORY_SEPARATOR.

        'cert'.DIRECTORY_SEPARATOR.'apiclient_cert.pem')

    curl_setopt($ch,CURLOPT_SSLKEY,dirname(__FILE__).DIRECTORY_SEPARATOR.

        'cert'.DIRECTORY_SEPARATOR.'apiient_key.pem')

    curl_setopt($ch,CURLOPT_CAINFO,dirname(__FILE__).DIRECTORY_SEPARATOR.

        'cert'.DIRECTORY_SEPARATOR.'rootca.pem')

  //运行curl

  $data = curl_exec($ch)

  //关闭curl

  curl_close($ch)

  return $data

}

?>

可参考官方文档进行调整开发,希望能有帮助,望采纳

如下需求

需要将1元的红包,拆分成10个,每一个红包的金额均不相等,接受用户的输入 个数和金额,并且红包个数的最小金额,和最大金额不能大于输入金额。

由于微信红包的火热,一些红包爱好者就出现了红包扫雷的菠菜玩法,有群红包、H5游戏,可以是手气佳者、也可以是尾数符合者,玩法多种多样。

而一般脱离微信外的程序、游戏、网页、APP、都是差不多跟机器人在玩,前期让你赚钱,后期慢慢割你韭菜,和币圈合约是一个道理。

后期会持续更新和剖析扫雷红包机器人和其通过盈亏比例调节割韭菜等细节


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/11315478.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存