小程序里微信支付

//小程序发起支付页面js

toPay: function (e) {
var uid = this.data.uid;
var openid = app.globalData.openid;
var o_number = new Date().getTime();
var o_price = e.currentTarget.dataset.text;
var web_url = app.globalData.web_url;
var web_url1 = web_url + "/Mark/toPay";
wx.request({
url: web_url1,
data: {
openid: openid,
o_number: o_number,
uid: uid,
o_price: o_price
},
dataType: 'json',
success: function (res) {
// console.log(res);
wx.requestPayment({
'timeStamp': res.data.timeStamp,
'nonceStr': res.data.nonceStr,
'package': res.data.package,
'signType': 'MD5',
'paySign': res.data.paySign,
'success': function (res) {
var web_url2 = web_url + "/Mark/payOver";
wx.request({
url: web_url2, //仅为示例,并非真实的接口地址
data: {
o_number: o_number,
},
header: {
'content-type': 'application/json' // 默认值
},
success: function (res) {
wx.showToast({
title: '支付成功',
icon: 'success',
duration: 2000
})
setTimeout( function () {
wx.redirectTo({
url: '/pages/gdhealth/view/memeber/order'
})
}, 2000)

}
})
},
'fail': function (res) {
}
})
},
fail: function (res) { },
complete: function (res) { },
})
},


//接口



    // 支付完成
    public function payOver(){
        $o_number=input("o_number");
        $w['o_number'] = $o_number;
        $order = Db::table("sws_order")->where($w)->find();
        $o_u_id=$order['o_u_id'];
        $upuser['u_ispay']=1;
        Db::table("sws_user")->where(array("u_id"=>$o_u_id))->update($upuser);
        $up['o_status'] = 1;
        $up['o_paytime'] = time();
        Db::table("sws_order")->where($w)->update($up);
        return json(1);
    }


   




    // 支付
    public function toPay(){
         //生成预订单
        $openid = input("openid");
        $o_number=input("o_number");
        $uid=input("uid");
        $o_price=input("o_price");
        $da['o_number']=$o_number;
        $da['o_u_id']=$uid;
        $da['o_price']=$o_price;
        $da['o_status']=5;
        Db::table("sws_order")->insertGetId($da);
        // 统一下单参数构造
         $unifiedorder = array(
          'appid'         => Config("APPID"),
          'mch_id'        => Config("MCHID"),
          'nonce_str'     => self::getNonceStr(),
          'body'          =>"赛沃思",
          'out_trade_no'  => $o_number,
          'total_fee'     => $o_price*100,
          // 'spbill_create_ip'  => get_client_ip(),
          'notify_url'    => 'https://'.$_SERVER['HTTP_HOST'].'/Api/Wxpay/notify',
          'trade_type'    => 'JSAPI',
          'openid'        => $openid
         );
         $unifiedorder['sign'] = self::makeSign($unifiedorder);
        //请求数据
         $xmldata = self::array2xml($unifiedorder);
         $url = 'https://api.mch.weixin.qq.com/pay/unifiedorder';
         $res = self::curl_post_ssl($url, $xmldata);
         if(!$res){
          self::return_err("Can't connect the server");
         }
         // 这句file_put_contents是用来查看服务器返回的结果 测试完可以删除了
         //file_put_contents(APP_ROOT.'/Statics/log1.txt',$res,FILE_APPEND);
                
         $content = self::xml2array($res);
         $data = array(
          'appId'     => Config("APPID"),
          'timeStamp' => "'".time()."'",
          'nonceStr'  => self::getNonceStr(),
          'package'   => 'prepay_id='.$content['prepay_id'],
          'signType'  => 'MD5'
         );
                
         $data['paySign'] = self::makeSign($data);
                
         return json($data);
    }






    //---------------------------------------------------------------用到的函数------------------------------------------------------------
    /**
     * 错误返回提示
     * @param string $errMsg 错误信息
     * @param string $status 错误码
     * @return  json的数据
     */
    protected function return_err($errMsg='error',$status=0){
        exit(json_encode(array('status'=>$status,'result'=>'fail','errmsg'=>$errMsg)));
    }
    
    
    /**
     * 正确返回
     * @param   array $data 要返回的数组
     * @return  json的数据
     */
    protected function return_data($data=array()){
        exit(json_encode(array('status'=>1,'result'=>'success','data'=>$data)));
    }
  
    /**
     * 将一个数组转换为 XML 结构的字符串
     * @param array $arr 要转换的数组
     * @param int $level 节点层级, 1 为 Root.
     * @return string XML 结构的字符串
     */
    protected 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}>" . $this->array2xml($value, $level + 1)."</{$tagname}>";
            }
        }
        $s = preg_replace("/([\x01-\x08\x0b-\x0c\x0e-\x1f])+/", ' ', $s);
        return $level == 1 ? $s."</xml>" : $s;
    }
    
    /**
     * 将xml转为array
     * @param  string   $xml xml字符串
     * @return array    转换得到的数组
     */
    protected function xml2array($xml){   
        //禁止引用外部xml实体
        libxml_disable_entity_loader(true);
        $result= json_decode(json_encode(simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA)), true);        
        return $result;
    }
    
    /**
     * 
     * 产生随机字符串,不长于32位
     * @param int $length
     * @return 产生的随机字符串
     */
    protected function getNonceStr($length = 32) {
        $chars = "abcdefghijklmnopqrstuvwxyz0123456789";  
        $str ="";
        for ( $i = 0; $i < $length; $i++ )  {  
            $str .= substr($chars, mt_rand(0, strlen($chars)-1), 1);  
        } 
        return $str;
    }
    
    /**
    * 生成签名
    * @return 签名
    */
    protected function makeSign($data){
        //获取微信支付秘钥
        $key = Config("KEY");
        // 去空
        $data=array_filter($data);
        //签名步骤一:按字典序排序参数
        ksort($data);
        $string_a=http_build_query($data);
        $string_a=urldecode($string_a);
        //签名步骤二:在string后加入KEY
        //$config=$this->config;
        $string_sign_temp=$string_a."&key=".$key;
        //签名步骤三:MD5加密
        $sign = md5($string_sign_temp);
        // 签名步骤四:所有字符转为大写
        $result=strtoupper($sign);
        return $result;
    }
    
    /**
     * 微信支付发起请求
     */
    protected function curl_post_ssl1($url, $xmldata, $second=30,$aHeader=array()){
        $ch = curl_init();
        //超时时间
        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
        curl_setopt($ch,CURLOPT_RETURNTRANSFER, 1);
        //这里设置代理,如果有的话
        //curl_setopt($ch,CURLOPT_PROXY, '10.206.30.98');
        //curl_setopt($ch,CURLOPT_PROXYPORT, 8080);
        curl_setopt($ch,CURLOPT_URL,$url);
        curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
        curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0);
        // curl_setopt($ch, CURLOPT_SSLVERSION, 1);
        // var_dump(Config("api_cert"));
        //默认格式为PEM,可以注释
        curl_setopt($ch,CURLOPT_SSLCERTTYPE,'PEM');
        curl_setopt($ch,CURLOPT_SSLCERT,Config("api_cert"));
        //默认格式为PEM,可以注释
        curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM');
        curl_setopt($ch,CURLOPT_SSLKEY,Config("api_key"));
        
        //curl_setopt($ch,CURLOPT_CAINFO,$config['rootca']);


        if( count($aHeader) >= 1 ){
            curl_setopt($ch, CURLOPT_HTTPHEADER, $aHeader);
        }
     
        curl_setopt($ch,CURLOPT_POST, 1);
        curl_setopt($ch,CURLOPT_POSTFIELDS,$xmldata);
        $data = curl_exec($ch);
        if($data){
            curl_close($ch);
            return $data;
        }else { 
            $error = curl_errno($ch);
            echo "call faild, errorCode:$error\n"; 
            curl_close($ch);
            return false;
        }
    }


    protected function curl_post_ssl($url, $xmldata, $second=30,$aHeader=array()){
        $ch = curl_init();
        //超时时间
        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
        curl_setopt($ch,CURLOPT_RETURNTRANSFER, 1);
        //这里设置代理,如果有的话
        //curl_setopt($ch,CURLOPT_PROXY, '10.206.30.98');
        //curl_setopt($ch,CURLOPT_PROXYPORT, 8080);
        curl_setopt($ch,CURLOPT_URL,$url);
        curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
        curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0);
        // curl_setopt($ch, CURLOPT_SSLVERSION, 1);
        
        //默认格式为PEM,可以注释
        // curl_setopt($ch,CURLOPT_SSLCERTTYPE,'PEM');
        // curl_setopt($ch,CURLOPT_SSLCERT,Config("api_cert"));
        // //默认格式为PEM,可以注释
        // curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM');
        // curl_setopt($ch,CURLOPT_SSLKEY,Config("api_key"));
        
        //curl_setopt($ch,CURLOPT_CAINFO,$config['rootca']);


        if( count($aHeader) >= 1 ){
            curl_setopt($ch, CURLOPT_HTTPHEADER, $aHeader);
        }
     
        curl_setopt($ch,CURLOPT_POST, 1);
        curl_setopt($ch,CURLOPT_POSTFIELDS,$xmldata);
        $data = curl_exec($ch);
        if($data){
            curl_close($ch);
            return $data;
        }else { 
            $error = curl_errno($ch);
            echo "call faild, errorCode:$error\n"; 
            curl_close($ch);
            return false;
        }
    }

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
校园悬赏任务平台对字典管理、论坛管理、任务资讯任务资讯公告管理、接取用户管理、任务管理、任务咨询管理、任务收藏管理、任务评价管理、任务订单管理、发布用户管理、管理员管理等进行集中化处理。经过前面自己查阅的网络知识,加上自己在学校课堂上学习的知识,决定开发系统选择小程序模式这种高效率的模式完成系统功能开发。这种模式让操作员基于浏览器的方式进行网站访问,采用的主流的Java语言这种面向对象的语言进行校园悬赏任务平台程序的开发,在数据库的选择上面,选择功能强大的Mysql数据库进行数据的存放操作。校园悬赏任务平台的开发让用户查看任务信息变得容易,让管理员高效管理任务信息。 校园悬赏任务平台具有管理员角色,用户角色,这几个操作权限。 校园悬赏任务平台针对管理员设置的功能有:添加并管理各种类型信息,管理用户账户信息,管理任务信息,管理任务资讯公告信息等内容。 校园悬赏任务平台针对用户设置的功能有:查看并修改个人信息,查看任务信息,查看任务资讯公告信息等内容。 系统登录功能是程序必不可少的功能,在登录页面必填的数据有两项,一项就是账号,另一项数据就是密码,当管理员正确填写并提交这二者数据之后,管理员就可以进入系统后台功能操作区。项目管理页面提供的功能操作有:查看任务,删除任务操作,新增任务操作,修改任务操作。任务资讯公告信息管理页面提供的功能操作有:新增任务资讯公告,修改任务资讯公告,删除任务资讯公告操作。任务资讯公告类型管理页面显示所有任务资讯公告类型,在此页面既可以让管理员添加新的任务资讯公告信息类型,也能对已有的任务资讯公告类型信息执行编辑更新,失效的任务资讯公告类型信息也能让管理员快速删除。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值