php 获取小程序码 (B类接口) - 子钦加油

时间:2024-03-07 09:29:06

php 获取小程序码 (B类接口)

  • 生成小程序码的php代码
    public function qrcode(){
        $member_id  = session(\'id\');
        if(empty($member_id)) $this->error(\'请先登录\');

        //推广二维码
        $member = model(\'Member\')->where(\'id\',$member_id)->find();
        if($member[\'is_share\'] && $member[\'share_qrcode\']){
            $litpic   = $member[\'share_qrcode\'];
        }else{
        	header(\'content-type:image/jpg\');//加载速度快
    		//	生成小程序码
            $wechatObj	=	new \Wechat();//这是个类 这里有小程序appid和密码
            $url =	"https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=".$wechatObj->getAccessToken();

            $page  = \'pages/index/index\';
            $scene = \'share_id=\'.$member_id;
            $path  = \'./upload/qrcode/\'.$member_id.\'.jpg\';
			
	    $postData = array();
	    $postData[\'page\'] = $page;
            $postData[\'scene\'] = $scene;
            $data = json_encode($postData);
            
            $result	= $this->api_notice_increment($url,$data);
            $image = \'data:image/jpg;base64,\' . base64_encode($result);
            
            $other_result = $result;
            
            $file = fopen($path,"w");//打开文件准备写入
	    fwrite($file,$other_result);//写入
	    fclose($file);//关闭
            
            //return $result;
            $litpic   = $path;
            $litpic = ltrim($litpic,\'.\');
            //写入数据库
            $member->save([\'share_qrcode\'=>$litpic,\'is_share\'=>1]);
        }

        //推广人数
        $path_member = model(\'Member\')->where(\'path\',$member_id)->field(\'id,name,litpic,add_time\')->select();
        $path   = [];
        foreach($path_member as $v){
            $v[\'add_time\']  = date(\'Y-m-d H:i:s\',$v[\'add_time\']);
            $path[]     = $v;
        }
        $data   = [
            \'litpic\'    => $litpic,
            \'path\'      => $path,
        ];
        return json($data);


    }
    
    
    public function api_notice_increment($url,$data){
    	//return $data;
    	$curl = curl_init(); // 启动一个CURL会话
    	//$header = "Accept-Charset: utf-8";
        curl_setopt($curl, CURLOPT_URL, $url); // 要访问的地址
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); // 对认证证书来源的检测
        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); // 从证书中检查SSL加密算法是否存在
        curl_setopt($curl, CURLOPT_HTTPHEADER, array(\'Expect:\')); //解决数据包大不能提交
        curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转
        curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer
        curl_setopt($curl, CURLOPT_POST, 1); // 发送一个常规的Post请求
        curl_setopt($curl, CURLOPT_POSTFIELDS, $data); // Post提交的数据包
        curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循
        curl_setopt($curl, CURLOPT_HEADER, 0); // 显示返回的Header区域内容
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回

        $tmpInfo = curl_exec($curl); // 执行操作
        if (curl_errno($curl)) {
            echo \'Errno\'.curl_error($curl);
        }
        curl_close($curl); // 关键CURL会话
        return $tmpInfo; // 返回数据
	      
    }
    

function api_notice_increment($url,$data)
{
	$curl = curl_init();
	$a = strlen($data);
	$header = array("Content-Type: application/json; charset=utf-8","Content-Length: $a");
	curl_setopt($curl, CURLOPT_URL, $url);
	curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
	curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
	curl_setopt($curl,CURLOPT_POST,1);
	curl_setopt($curl,CURLOPT_POSTFIELDS,$data);
	curl_setopt($curl, CURLOPT_HEADER, 0);
	curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
	$res = curl_exec($curl);
	curl_close($curl);
	return $res;

}
  •  小程序端获取二维码中带的参数
/**
     * 生命周期函数--监听页面加载
     */
    onLoad: function(option) {
        console.log(option)
        if(option.id){
          this.setData({ id: option.id });
          this.data.business_id = option.id;
          this.loadData(option.id);
        }

        //接受二维码扫码并获取二维码中的参数
        if (option.scene){
          const ids = decodeURIComponent(option.scene).split(\'=\')[1];
          console.log("ids", ids);
          this.setData({ id: ids });
          this.data.business_id = ids;
          this.loadData(ids);
        }
        
      
    },
  •  效果如下图

 

  •  补充上wechat类
<?php

class Wechat
{
    // +----------------------------------------------------------------------
    // |        参数
    // +----------------------------------------------------------------------
	public $table;
	public $where_web;
    public $wechatId;
    public $wechatToken;
    public $wechatAppid;
    public $wechatAppsecret;
    public $wechatMchid;
    public $wechatPrivatekey;
    public $wechatAccessToken;
    public $wechatAccessTokenTime;
    public $wechatJsapiTicket;
    public $wechatJsapiTicketTime;



// +----------------------------------------------------------------------
// |	自动加载
// +----------------------------------------------------------------------
    public function __construct() {



        //测试
        /*$this->wechatId                       = 1;
        $this->wechatAppid                    =	\'wx1161dbcdd18c52c2\';
        $this->wechatAppsecret                = \'f373410716a198feb462182c69facb8a\';
        $this->wechatMchid                    = 1493574822;
        $this->wechatPrivatekey               = md5(123);
        */
        //客户appid
        $this->wechatId                       = 1;
        $this->wechatAppid                    =	\'your appid\';
        $this->wechatAppsecret                = \'your appsecret\';
        $this->wechatMchid                    = 商户号;
        $this->wechatPrivatekey               = \'私钥\';
        



        /*
			$this->wechatToken                    = $WechatInfo[\'wechat_token\'];
			$this->wechatAccessToken              = $WechatInfo[\'wechat_access_token\'];
			$this->wechatAccessTokenTime          = $WechatInfo[\'wechat_access_token_time\'];
			$this->wechatJsapiTicket              = $WechatInfo[\'wechat_jsapi_ticket\'];
			$this->wechatJsapiTicketTime          = $WechatInfo[\'wechat_jsapi_ticket_time\'];
    	*/
    }


// +----------------------------------------------------------------------
// |        获取access_token
// +----------------------------------------------------------------------
    public function getAccessToken(){

        $url  = \'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=\'.$this->wechatAppid.\'&secret=\'.$this->wechatAppsecret;
        $data = $this -> curlGet($url);
        $access_token =	$data[\'access_token\'];
        $expires_in   =	$data[\'expires_in\'];
        $save[\'wechat_access_token\']        = $access_token;
        $save[\'wechat_access_token_time\']   = ($expires_in+time())-360;
        $this	->	wechatAccessToken       = $save[\'wechat_access_token\'];
        $this	->	wechatAccessTokenTime   = $save[\'wechat_access_token_time\'];
        return $access_token;

    }
    // +----------------------------------------------------------------------
    // |        获取access_token
    // +----------------------------------------------------------------------
    public function getJsapiTicket(){

        $url  = \'https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=\'.$this -> getAccessToken().\'&type=jsapi\';
        $data = $this -> curlGet($url);

        $jsapi_ticket = $data[\'ticket\'];
        $expires_in   = $data[\'expires_in\'];

        $save[\'wechat_jsapi_ticket\']        = $jsapi_ticket;
        $save[\'wechat_jsapi_ticket_time\']   = ($expires_in+time())-360;

        $this->wechatJsapiTicket       = $save[\'wechat_jsapi_ticket\'];
        $this->wechatJsapiTicketTime   = $save[\'wechat_jsapi_ticket_time\'];

        return $jsapi_ticket;

    }
    // +----------------------------------------------------------------------
    // |        获取signature
    // +----------------------------------------------------------------------
    public function getSignature($appId,$timestamp,$nonceStr,$url)
    {

        $jsapi_ticket =  $this -> getJsapiTicket();
        $string1 = "jsapi_ticket={$jsapi_ticket}&noncestr={$nonceStr}&timestamp={$timestamp}&url={$url}";
        $signature = sha1($string1);
        return $signature;
    }
    // +----------------------------------------------------------------------
    // |        获取createNonceStr
    // +----------------------------------------------------------------------
    public function getCreateNonceStr($length = 16) {
        $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
        $str = "";
        for ($i = 0; $i < $length; $i++) {
          $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
        }
        return $str;
    }
    // +----------------------------------------------------------------------
    // |        下载本地
    // +----------------------------------------------------------------------
    public function curlDownload($url,$name)
    {
        $ch = curl_init ();
        curl_setopt ( $ch, CURLOPT_CUSTOMREQUEST, \'GET\' );
        curl_setopt ( $ch, CURLOPT_SSL_VERIFYPEER, false );
        curl_setopt ( $ch, CURLOPT_URL, $url );
        ob_start ();
        curl_exec ( $ch );
        $return_content = ob_get_contents ();
        ob_end_clean ();
        $return_code = curl_getinfo ( $ch, CURLINFO_HTTP_CODE );

        $filename = "Uploads/Card/{$name}";
        $fp= @fopen($filename,"a");
        fwrite($fp,$return_content);
        // 关闭URL请求
        curl_close($ch);

		$url = "/Uploads/Card/{$name}";

        return "{$url}";
    }
    // +----------------------------------------------------------------------
    // |        GET请求
    // +----------------------------------------------------------------------
    public function curlGet($url)
    {
            $ch = curl_init();
            curl_setopt($ch, CURLOPT_URL, $url);
            curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
            curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
            $output = curl_exec($ch);
            curl_close($ch);
            $jsoninfo = json_decode($output, true);
            return $jsoninfo;
    }
    // +----------------------------------------------------------------------
    // |        POST SSL请求
    // +----------------------------------------------------------------------
    public function curlPostSSL($url, $vars, $second=30,$aHeader=array()){
        $ch = curl_init();
        //超时时间
        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
        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_SSLCERTTYPE,\'PEM\');
        curl_setopt($ch,CURLOPT_SSLCERT,getcwd().\'/cert/apiclient_cert.pem\');
        //curl_setopt($ch,CURLOPT_SSLKEYTYPE,\'PEM\');
        curl_setopt($ch,CURLOPT_SSLKEY,getcwd().\'/cert/apiclient_key.pem\');

        if( count($aHeader) >= 1 ){
            curl_setopt($ch, CURLOPT_HTTPHEADER, $aHeader);
        }

        curl_setopt($ch,CURLOPT_POST, 1);
        curl_setopt($ch,CURLOPT_POSTFIELDS,$vars);
        $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;
        }
    }

	// +----------------------------------------------------------------------
    // | 发送退款
	//	 退款单号 out_trade_no
	//	 交易金额 total_fee
	//	 退款金额 refund_fee
    // +----------------------------------------------------------------------
	public function refund($out_trade_no,$total_fee,$refund_fee){

		$arr[\'appid\']			=	$this->wechatAppid;
		$arr[\'mch_id\']			=	$this->wechatMchid;
		$arr[\'nonce_str\']		=	$this->getNonceStr();
		$arr[\'out_trade_no\']	=	$out_trade_no;
		$arr[\'out_refund_no\']	=	$this->getNonceStr();
		$arr[\'total_fee\']		=	$total_fee;
		$arr[\'refund_fee\']		=	$refund_fee;
		$arr[\'sign\']			=	$this->MakeSign($arr);

		//将统一下单数组 转换xml
		$xml						=	$this->ToXml($arr);


		//post xml 到微信退款接口
		$url	=	"https://api.mch.weixin.qq.com/secapi/pay/refund";;//微信退款地址,post请求
		$ch=curl_init();
		//需要获取的URL地址,也可以在 curl_init() 函数中设置。
		curl_setopt($ch,CURLOPT_URL,$url);
		//启用时会将头文件的信息作为数据流输出。
		//curl_setopt($ch,CURLOPT_HEADER,1);
		//将 curl_exec() 获取的信息以文件流的形式返回,而不是直接输出。
		curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
		//证书检查
		curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
		//证书的类型。支持的格式有"PEM" (默认值), "DER"和"ENG"。
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		//一个包含PEM格式证书的文件名。
		curl_setopt($ch,CURLOPT_SSLCERT,GEN.\'/cert/apiclient_cert.pem\');
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		curl_setopt($ch,CURLOPT_TIMEOUT,30);
		//包含SSL私钥的文件名。
		curl_setopt($ch,CURLOPT_SSLKEY,GEN.\'/cert/apiclient_key.pem\');
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		//一个保存着1个或多个用来让服务端验证的证书的文件名。这个参数仅仅在和 CURLOPT_SSL_VERIFYPEER 一起使用时才有意义。 .
		// curl_setopt($ch,CURLOPT_CAINFO,getcwd().\'/cert/rootca.pem\');
		curl_setopt($ch,CURLOPT_POST,1);
		curl_setopt($ch,CURLOPT_POSTFIELDS,$xml);
	   $data=curl_exec($ch);
	   if($data){
			curl_close($ch);
			$data_arr = json_decode(json_encode(simplexml_load_string($data, \'SimpleXMLElement\', LIBXML_NOCDATA)), true);
			return $data_arr;
	   }else{
			$error	=	curl_errno($ch);
			return "curl 错误:".$error;
	   }
	}







	// +----------------------------------------------------------------------
    // | 企业付款
	//	 退款单号 out_trade_no
	//	 交易金额 total_fee
	//	 退款金额 refund_fee
    // +----------------------------------------------------------------------
	public function payment($partner_trade_no,$openid,$amount,$desc){

		//	获取
		$arr[\'mch_appid\']			=	$this->wechatAppid;
		$arr[\'mchid\']				=	$this->wechatMchid;
		$arr[\'nonce_str\']			=	$this->getNonceStr();
		$arr[\'partner_trade_no\']	=	$partner_trade_no;
		$arr[\'openid\']				=	$openid;
		$arr[\'check_name\']			=	"NO_CHECK";
		$arr[\'amount\']				=	$amount*100;
		$arr[\'desc\']				=	$desc;
		$arr[\'spbill_create_ip\']	=	request()->ip();
		$arr[\'sign\']				=	$this->MakeSign($arr);

		//将统一下单数组 转换xml
		$xml						=	$this->ToXml($arr);

		//post xml 到微信退款接口
		$url	=	"https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers";//微信退款地址,post请求
		$ch=curl_init();
		//需要获取的URL地址,也可以在 curl_init() 函数中设置。
		curl_setopt($ch,CURLOPT_URL,$url);
		//启用时会将头文件的信息作为数据流输出。
		//curl_setopt($ch,CURLOPT_HEADER,1);
		//将 curl_exec() 获取的信息以文件流的形式返回,而不是直接输出。
		curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
		//证书检查
		curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
		//证书的类型。支持的格式有"PEM" (默认值), "DER"和"ENG"。
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		//一个包含PEM格式证书的文件名。
		curl_setopt($ch,CURLOPT_SSLCERT,GEN.\'/cert/apiclient_cert.pem\');
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		curl_setopt($ch,CURLOPT_TIMEOUT,30);
		//包含SSL私钥的文件名。
		curl_setopt($ch,CURLOPT_SSLKEY,GEN.\'/cert/apiclient_key.pem\');
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		//一个保存着1个或多个用来让服务端验证的证书的文件名。这个参数仅仅在和 CURLOPT_SSL_VERIFYPEER 一起使用时才有意义。 .
		// curl_setopt($ch,CURLOPT_CAINFO,getcwd().\'/cert/rootca.pem\');
		curl_setopt($ch,CURLOPT_POST,1);
		curl_setopt($ch,CURLOPT_POSTFIELDS,$xml);
	   $data=curl_exec($ch);
	   if($data){
			curl_close($ch);
			$data_arr = json_decode(json_encode(simplexml_load_string($data, \'SimpleXMLElement\', LIBXML_NOCDATA)), true);
			return $data_arr;
	   }else{
			$error	=	curl_errno($ch);
			return "curl 错误:".$error;
	   }



	}



    // +----------------------------------------------------------------------
    // |        POST请求
    // +----------------------------------------------------------------------
    public function curlPost($url,$post_data)
    {
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
        if (!empty($post_data)){
            curl_setopt($ch, CURLOPT_POST, 1);
            curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
        }
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        $output = curl_exec($ch);

        return $output;
    }
	// +----------------------------------------------------------------------
    // |        齐力短信
    // +----------------------------------------------------------------------
	public function message($mobile){

		$info	=	M(\'web\')
				->	find();

		$post_data = array();
		$post_data[\'userid\']	=	$info[\'message_id\'];
		$post_data[\'account\']	=	$info[\'message_account\'];
		$post_data[\'password\']	=	$info[\'message_password\'];
		$code = rand(1111,9999);
		session(\'code\',$code);
		$post_data[\'content\'] = 	$info[\'message_autograph\'].\'您的验证码是:\'.$code.\' 请务必保管好,以免泄露\';
		$post_data[\'mobile\'] = $mobile;
		$post_data[\'sendtime\'] = date(\'Y-m-d\');
		$url=\'http://pt.sdqlweb.com/sms.aspx?action=send\';
		$o=\'\';
		foreach ($post_data as $k=>$v)
		{
		$o.="$k=".urlencode($v).\'&\';
		}
		$post_data=substr($o,0,-1);
		$ch = curl_init();
		curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
		curl_setopt($ch, CURLOPT_POST, 1);
		curl_setopt($ch, CURLOPT_URL,$url);
		curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
		curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
		$data = curl_exec($ch);
		$data = json_decode(json_encode(simplexml_load_string($data, \'SimpleXMLElement\', LIBXML_NOCDATA)), true);
        curl_close($ch);
		return $data;
	}
	// +----------------------------------------------------------------------
	// |        以post方式提交xml到对应的接口url
	// +----------------------------------------------------------------------
	public function postXmlCurl($xml, $url, $useCert = false, $second = 30)
	{
		$ch = curl_init();
		//设置超时
		curl_setopt($ch, CURLOPT_TIMEOUT, $second);
		curl_setopt($ch,CURLOPT_URL, $url);
		curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
		curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验
		//设置header
		curl_setopt($ch, CURLOPT_HEADER, FALSE);
		//要求结果为字符串且输出到屏幕上
		curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
		//post提交方式
		curl_setopt($ch, CURLOPT_POST, TRUE);
		curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);
		//运行curl
		$data = curl_exec($ch);
		//返回结果
		if($data){
			curl_close($ch);
			return $data;
		} else {
			$error = curl_errno($ch);
			curl_close($ch);
		}
	}
	// +----------------------------------------------------------------------
	// |        输出xml字符
	// +----------------------------------------------------------------------
	public function ToXml($array)
	{
		if(!is_array($array)
			|| count($array) <= 0)
		{
    		throw new WxPayException("数组数据异常!");
    	}
    	$xml = "<xml>";
    	foreach ($array as $key=>$val)
    	{
    		if (is_numeric($val)){
    			$xml.="<".$key.">".$val."</".$key.">";
    		}else{
    			$xml.="<".$key."><![CDATA[".$val."]]></".$key.">";
    		}
        }
        $xml.="</xml>";
        return $xml;
	}
	// +----------------------------------------------------------------------
	// |        获取微信RAS公钥
	// +----------------------------------------------------------------------
	public function get_pub_key(){

		$url				=	"https://fraud.mch.weixin.qq.com/risk/getpublickey";
		$arr[\'mch_id\']		=	$this->wechatMchid;
		$arr[\'nonce_str\']	=	$this->getNonceStr();
		$arr[\'sign_type\']	=	\'MD5\';
		$arr[\'sign\']		=	$this->MakeSign($arr);
		$xml				=	$this->ToXml($arr);
		$ch	=	curl_init();
		curl_setopt($ch,CURLOPT_URL,$url);
		curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
		curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,1);
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		curl_setopt($ch,CURLOPT_SSLCERT,getcwd().\'/cert/apiclient_cert.pem\');
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		curl_setopt($ch,CURLOPT_SSLKEY,getcwd().\'/cert/apiclient_key.pem\');
		curl_setopt($ch,CURLOPT_SSLCERTTYPE,\'pem\');
		curl_setopt($ch,CURLOPT_CAINFO,getcwd().\'/cert/rootca.pem\');
		curl_setopt($ch,CURLOPT_POST,1);
		curl_setopt($ch,CURLOPT_POSTFIELDS,$xml);
		$data	=	$this->FromXml(curl_exec($ch));
		//要创建的两个文件
		$TxtFileName = "./cert/public.pem";
		//以读写方式打写指定文件,如果文件不存则创建
		if( ($TxtRes=fopen ($TxtFileName,"w+")) === false){
			echo("创建可写文件:".$TxtFileName."失败");
			exit();
		}
			echo ("创建可写文件".$TxtFileName."成功!</br>");
			$StrConents	=	$data[\'pub_key\'];//要 写进文件的内容
		if(!fwrite ($TxtRes,$StrConents)){ //将信息写入文件
			echo ("尝试向文件".$TxtFileName."写入".$StrConents."失败!");
			fclose($TxtRes);
			exit();
		}
			echo ("尝试向文件".$TxtFileName."写入".$StrConents."成功!");
			fclose ($TxtRes); //关闭指针
	}
	// +----------------------------------------------------------------------
	// |        将xml转为array
	// +----------------------------------------------------------------------
	public function FromXml($xml)
	{
        //禁止引用外部xml实体
        libxml_disable_entity_loader(true);
        $this->values = json_decode(json_encode(simplexml_load_string($xml, \'SimpleXMLElement\', LIBXML_NOCDATA)), true);
		return $this->values;
	}
	// +----------------------------------------------------------------------
	// |        微信银行卡编码
	// +----------------------------------------------------------------------
	public function Cardcode($card_name)
	{
		$arr	=	array(
			\'工商银行\'=>1002,
			\'农业银行\'=>1005,
			\'中国银行\'=>1026,
			\'建设银行\'=>1003,
			\'招商银行\'=>1001,
			\'邮储银行\'=>1066,
			\'交通银行\'=>1020,
			\'浦发银行\'=>1004,
			\'民生银行\'=>1006,
			\'兴业银行\'=>1009,
			\'平安银行\'=>1010,
			\'中信银行\'=>1021,
			\'华夏银行\'=>1025,
			\'广发银行\'=>1027,
			\'光大银行\'=>1022,
			\'北京银行\'=>1032,
			\'宁波银行\'=>1056
		);

		foreach($arr as $k=>$v){
			if($k == $card_name){
				return $v;
			}
		}
	}
	// +----------------------------------------------------------------------
	// |        格式化参数格式化成url参数
	// +----------------------------------------------------------------------
	public function ToUrlParams($array)
	{
		$buff = "";
		foreach ($array as $k => $v)
		{
			if($k != "sign" && $v != "" && !is_array($v)){
				$buff .= $k . "=" . $v . "&";
			}
		}
		$buff = trim($buff, "&");
		return $buff;
	}
	// +----------------------------------------------------------------------
	// |        生成签名 本函数不覆盖sign成员变量,如要设置签名需要调用SetSign方法赋值
	// +----------------------------------------------------------------------
	public function MakeSign($array)
	{
		//签名步骤一:按字典序排序参数
		ksort($array);
		$string	=	$this->ToUrlParams($array);
		//签名步骤二:在string后加入KEY
		$string	=	$string."&key=".$this->wechatPrivatekey;
		//签名步骤三:MD5加密
		$string	=	md5($string);
		//签名步骤四:所有字符转为大写
		$string	=	strtoupper($string);
		return $string;
	}
	// +----------------------------------------------------------------------
	// |        产生的随机字符串
	// +----------------------------------------------------------------------
	public 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;
	}
	// +----------------------------------------------------------------------
	// |        打印log日志
	// +----------------------------------------------------------------------
	public function save_log($msg){
		error_log(date("Y-m-d H:i:s")."\r\n".print_r($msg,1)."\r\n \r\n \r\n ",3,\'./error.log\');
	}
	// +----------------------------------------------------------------------
	// |        将图片上传至微信服务器
	// +----------------------------------------------------------------------
	public function curlImg($images){

		$url		=	"https://api.weixin.qq.com/cgi-bin/material/add_material?access_token=".$this->getAccessToken()."&type=image";
		$ch1 		=	curl_init ();
		$timeout 	=	5;
		$real_path	=	"{$_SERVER[\'DOCUMENT_ROOT\']}{$images}";

		$data= array("media"=>"@{$real_path}",\'form-data\'=>$file_info);
		curl_setopt ( $ch1, CURLOPT_URL, $url );
		curl_setopt ( $ch1, CURLOPT_POST, 1 );
		curl_setopt ( $ch1, CURLOPT_RETURNTRANSFER, 1 );
		curl_setopt ( $ch1, CURLOPT_CONNECTTIMEOUT, $timeout );
		curl_setopt ( $ch1, CURLOPT_SSL_VERIFYPEER, FALSE );
		curl_setopt ( $ch1, CURLOPT_SSL_VERIFYHOST, false );
		curl_setopt ( $ch1, CURLOPT_POSTFIELDS, $data );
		$result = curl_exec ( $ch1 );
		curl_close ( $ch1 );
		if(curl_errno()==0){
			$result=json_decode($result,true);
			return $result;
		}else {
			return false;
		}
	}
	// +----------------------------------------------------------------------
	// |        将文章转换为微信文章
	// +----------------------------------------------------------------------
	public function wechatText($content){
		$parrent = "/<[img|IMG].*?src=\'(.*?)\'/";
		$str	=	html_entity_decode($content);
		preg_match_all($parrent,$str,$match);
		foreach( $match[1] as $v){
			$imgurl		=	$this->curlImg($v);
			$content	=	str_replace($v,$imgurl[\'url\'],$content);
		}
		return ($content);
	}
	// +----------------------------------------------------------------------
	// |        验证银行卡号
	// +----------------------------------------------------------------------
	 public function check_bank_card($card){

			$url	=	"https://ccdcapi.alipay.com/validateAndCacheCardInfo.json?_input_charset=utf-8&cardNo={$card}&cardBinCheck=true";
			$data	=	$this->curlGet($url);
			$name	=	[
					"SRCB"=> "深圳农村商业银行",
					"BGB"=> "广西北部湾银行",
					"SHRCB"=> "上海农村商业银行",
					"BJBANK"=> "北京银行",
					"WHCCB"=> "威海市商业银行",
					"BOZK"=> "周口银行",
					"KORLABANK"=> "库尔勒市商业银行",
					"SPABANK"=> "平安银行",
					"SDEB"=> "顺德农商银行",
					"HURCB"=> "湖北省农村信用社",
					"WRCB"=> "无锡农村商业银行",
					"BOCY"=> "朝阳银行",
					"CZBANK"=> "浙商银行",
					"HDBANK"=> "邯郸银行",
					"BOC"=> "中国银行",
					"BOD"=> "东莞银行",
					"CCB"=> "中国建设银行",
					"ZYCBANK"=> "遵义市商业银行",
					"SXCB"=> "绍兴银行",
					"GZRCU"=> "贵州省农村信用社",
					"ZJKCCB"=> "张家口市商业银行",
					"BOJZ"=> "锦州银行",
					"BOP"=> "平顶山银行",
					"HKB"=> "汉口银行",
					"SPDB"=> "上海浦东发展银行",
					"NXRCU"=> "宁夏黄河农村商业银行",
					"NYNB"=> "广东南粤银行",
					"GRCB"=> "广州农商银行",
					"BOSZ"=> "苏州银行",
					"HZCB"=> "杭州银行",
					"HSBK"=> "衡水银行",
					"HBC"=> "湖北银行",
					"JXBANK"=> "嘉兴银行",
					"HRXJB"=> "华融湘江银行",
					"BODD"=> "丹东银行",
					"AYCB"=> "安阳银行",
					"EGBANK"=> "恒丰银行",
					"CDB"=> "国家开发银行",
					"TCRCB"=> "江苏太仓农村商业银行",
					"NJCB"=> "南京银行",
					"ZZBANK"=> "郑州银行",
					"DYCB"=> "德阳商业银行",
					"YBCCB"=> "宜宾市商业银行",
					"SCRCU"=> "四川省农村信用",
					"KLB"=> "昆仑银行",
					"LSBANK"=> "莱商银行",
					"YDRCB"=> "尧都农商行",
					"CCQTGB"=> "重庆三峡银行",
					"FDB"=> "富滇银行",
					"JSRCU"=> "江苏省农村信用联合社",
					"JNBANK"=> "济宁银行",
					"CMB"=> "招商银行",
					"JINCHB"=> "晋城银行JCBANK",
					"FXCB"=> "阜新银行",
					"WHRCB"=> "武汉农村商业银行",
					"HBYCBANK"=> "湖北银行宜昌分行",
					"TZCB"=> "台州银行",
					"TACCB"=> "泰安市商业银行",
					"XCYH"=> "许昌银行",
					"CEB"=> "中国光大银行",
					"NXBANK"=> "宁夏银行",
					"HSBANK"=> "徽商银行",
					"JJBANK"=> "九江银行",
					"NHQS"=> "农信银清算中心",
					"MTBANK"=> "浙江民泰商业银行",
					"LANGFB"=> "廊坊银行",
					"ASCB"=> "鞍山银行",
					"KSRB"=> "昆山农村商业银行",
					"YXCCB"=> "玉溪市商业银行",
					"DLB"=> "大连银行",
					"DRCBCL"=> "东莞农村商业银行",
					"GCB"=> "广州银行",
					"NBBANK"=> "宁波银行",
					"BOYK"=> "营口银行",
					"SXRCCU"=> "陕西信合",
					"GLBANK"=> "桂林银行",
					"BOQH"=> "青海银行",
					"CDRCB"=> "成都农商银行",
					"QDCCB"=> "青岛银行",
					"HKBEA"=> "东亚银行",
					"HBHSBANK"=> "湖北银行黄石分行",
					"WZCB"=> "温州银行",
					"TRCB"=> "天津农商银行",
					"QLBANK"=> "齐鲁银行",
					"GDRCC"=> "广东省农村信用社联合社",
					"ZJTLCB"=> "浙江泰隆商业银行",
					"GZB"=> "赣州银行",
					"GYCB"=> "贵阳市商业银行",
					"CQBANK"=> "重庆银行",
					"DAQINGB"=> "龙江银行",
					"CGNB"=> "南充市商业银行",
					"SCCB"=> "三门峡银行",
					"CSRCB"=> "常熟农村商业银行",
					"SHBANK"=> "上海银行",
					"JLBANK"=> "吉林银行",
					"CZRCB"=> "常州农村信用联社",
					"BANKWF"=> "潍坊银行",
					"ZRCBANK"=> "张家港农村商业银行",
					"FJHXBC"=> "福建海峡银行",
					"ZJNX"=> "浙江省农村信用社联合社",
					"LZYH"=> "兰州银行",
					"JSB"=> "晋商银行",
					"BOHAIB"=> "渤海银行",
					"CZCB"=> "浙江稠州商业银行",
					"YQCCB"=> "阳泉银行",
					"SJBANK"=> "盛京银行",
					"XABANK"=> "西安银行",
					"BSB"=> "包商银行",
					"JSBANK"=> "江苏银行",
					"FSCB"=> "抚顺银行",
					"HNRCU"=> "河南省农村信用",
					"COMM"=> "交通银行",
					"XTB"=> "邢台银行",
					"CITIC"=> "中信银行",
					"HXBANK"=> "华夏银行",
					"HNRCC"=> "湖南省农村信用社",
					"DYCCB"=> "东营市商业银行",
					"ORBANK"=> "鄂尔多斯银行",
					"BJRCB"=> "北京农村商业银行",
					"XYBANK"=> "信阳银行",
					"ZGCCB"=> "自贡市商业银行",
					"CDCB"=> "成都银行",
					"HANABANK"=> "韩亚银行",
					"CMBC"=> "中国民生银行",
					"LYBANK"=> "洛阳银行",
					"GDB"=> "广东发展银行",
					"ZBCB"=> "齐商银行",
					"CBKF"=> "开封市商业银行",
					"H3CB"=> "内蒙古银行",
					"CIB"=> "兴业银行",
					"CRCBANK"=> "重庆农村商业银行",
					"SZSBK"=> "石嘴山银行",
					"DZBANK"=> "德州银行",
					"SRBANK"=> "上饶银行",
					"LSCCB"=> "乐山市商业银行",
					"JXRCU"=> "江西省农村信用",
					"ICBC"=> "中国工商银行",
					"JZBANK"=> "晋中市商业银行",
					"HZCCB"=> "湖州市商业银行",
					"NHB"=> "南海农村信用联社",
					"XXBANK"=> "新乡银行",
					"JRCB"=> "江苏江阴农村商业银行",
					"YNRCC"=> "云南省农村信用社",
					"ABC"=> "中国农业银行",
					"GXRCU"=> "广西省农村信用",
					"PSBC"=> "中国邮政储蓄银行",
					"BZMD"=> "驻马店银行",
					"ARCU"=> "安徽省农村信用社",
					"GSRCU"=> "甘肃省农村信用",
					"LYCB"=> "辽阳市商业银行",
					"JLRCU"=> "吉林农信",
					"URMQCCB"=> "乌鲁木齐市商业银行",
					"XLBANK"=> "中山小榄村镇银行",
					"CSCB"=> "长沙银行",
					"JHBANK"=> "金华银行",
					"BHB"=> "河北银行",
					"NBYZ"=> "鄞州银行",
					"LSBC"=> "临商银行",
					"BOCD"=> "承德银行",
					"SDRCU"=> "山东农信",
					"NCB"=> "南昌银行",
					"TCCB"=> "天津银行",
					"WJRCB"=> "吴江农商银行",
					"CBBQS"=> "城市商业银行资金清算中心",
					"HBRCU"=> "河北省农村信用社"
			 ];


			$bank	=	$data[\'bank\'];
			$name	=	$name[$bank];
			if($name){
				if($bank){
					$url1 			= "https://apimg.alipay.com/combo.png?d=cashier&t={$bank}";
					$msg[\'pic\']		=	$this->curlDownload($url1,time().\'.png\');
					$msg[\'logo\']	=	$this->imagecropper(\'.\'.$msg[\'pic\'],30,35);
					$msg[\'status\'] 	= 200;
					$msg[\'name\'] = $name;
					return $msg;
				}
			}else{
				$msg[\'status\'] = 500;
				$msg[\'data\'] = \'系统检测到该银行卡无效,请输入有效银行卡卡号\';
				return $msg;
			}

		}

/**
* 图像裁剪
* @param $title string 原图路径
* @param $content string 需要裁剪的宽
* @param $encode string 需要裁剪的高
*/
		public function imagecropper($source_path, $target_width, $target_height){

			$source_info = getimagesize($source_path);
			$source_width = $source_info[0];
			$source_height = $source_info[1];
			$source_mime = $source_info[\'mime\'];
			$source_x = 0;
			$source_y = 0;
			switch ($source_mime)
			{
				case \'image/gif\':
				$source_image = imagecreatefromgif($source_path);
				break;

				case \'image/jpeg\':
				$source_image = imagecreatefromjpeg($source_path);
				break;

				case \'image/png\':
				$source_image = imagecreatefrompng($source_path);
				break;

				default:
				return false;
				break;
			}
			$target_image = imagecreatetruecolor($target_width, $target_height);
			$cropped_image = imagecreatetruecolor($target_width, $target_height);
			// 裁剪
			imagecopy($cropped_image, $source_image,0,0, $source_x, $source_y, $target_width, $target_height);
			// 缩放
			imagecopyresampled($target_image, $cropped_image, 0, 0, 0, 0, $target_width, $target_height, $target_width, $target_height);
			imagecolortransparent($target_image,imagecolorallocate($target_image,255,255,255));
			$fileName = time()."1.png";
			$path	=	\'./Uploads/Card/\'.$fileName;
			imagepng($target_image,$path);
			return \'/Uploads/Card/\'.$fileName;
		}


		// 随机字符
	    public	function noncestr($length = 12){
			$chars = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
			$str ="";
			for ( $i = 0; $i < $length; $i++ )  {
				$str .= substr($chars, mt_rand(0, strlen($chars)-1), 1);
			}
			return $str;
		}

}
?>