标签 函数 下的文章

好坑的微擎1.0+版本

如果遇到报错显示SQL中包含禁用函数 那么你就要检查是否有包含以下单词命名的表
'load_file', 'floor', 'hex', 'substring', 'if', 'ord', 'char', 'benchmark', 'reverse', 'strcmp', 'datadir', 'updatexml', 'extractvalue', 'name_const', 'multipoint', 'database', 'user',注意是包含比如我命名表名yoby_user,一样会显示这个错误


扫码二维码阅读

微擎js支付中的应用讲解和代码实例

js支付体验好,不需要跳转,直接在本页面内完成支付,但是微擎给的代码非常简单,在实际开发中还是有很多的坑,感谢黄河指导,完成了支付的开发.

首先需要配置支付信息,在这里不多说了,主要是微擎后台和商户里面,重点说开发.先说前端,对于我们没有加载微擎公共开头结尾,那就要自己加载一些必须的代码.

<a href="javascript:void(0);" data-name="李白"  class="weui_btn weui_btn_plain_primary weui_btn_inline">支付</a>
<?php
$wx = $_W['account']['jssdkconfig'];
$wx['url'] ='http://'.$_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'] ;
?>
<script>
    window.sysinfo = {"uniacid":{php echo $this->weid},"acid":{$_W['acid']}};

    var appIdstr = "{$wx['appId']}";
    var timestampstr = "{$wx['timestamp']}";
    var nonceStrstr = "{$wx['nonceStr']}";
    var signaturestr = "{$wx['signature']}";
wx.config({
    debug: false,
    appId: appIdstr,
    timestamp: timestampstr,
    nonceStr: nonceStrstr,
    signature: signaturestr,
        jsApiList: [
        'checkJsApi',
        'onMenuShareTimeline',
        'onMenuShareAppMessage','showMenuItems','hideOptionMenu','chooseWXPay',
    ]
});
</script>
<script type="text/javascript" src='http://res.wx.qq.com/open/js/jweixin-1.0.0.js'></script>
 <script src="{php echo $this->yobyurl}zepto.min.js"></script>
<script type="text/javascript" src="{$_W['siteroot']}app/resource/js/lib/mui.min.js"></script>
<script type="text/javascript" src="{$_W['siteroot']}app/resource/js/app/util.js"></script>
<script>
$(function(){

document.addEventListener('WeixinJSBridgeReady', function onBridgeReady() {

$('.weui_btn').click(function(){
        $.getJSON("{$ajaxurl}",{name:name}, function(data, status){
        //这里传递参数到生成订单
            if(status == 'success'){
           
                util.pay({
                    orderFee : data.fee,
                    payMethod : 'wechat',
                    orderTitle : '微信支付金额' + data.fee + '元',
                    orderTid : data.ordertid,
                    module : 'yoby_test',
                    success : function(result) {//支付成功
                    $.alert('支付成功');
                   //可不写   
                    },
                    fail : function(result) {//支付失败
                       $.alert('支付失败');
                    },
                    complete : function(result) {//无论成功失败
                    //可不写
                    }
                });
            }
        });
       
        });
});
});

</script>

js代码就上面这么多,当然实际开发中需要自己调整代码,接着需要在site.php里面重要两个方法,一个是生成订单,一个是成功支付后的业务处理.开发终是不能传递参数到支付后的,所以首先把需要参数保存到订单中,一般

    public function doMobilepay() {//生成订单 $ajaxurl就是指向这里的方法
echo json_encode(array('fee'=>$n,'ordertid'=>$sn));//生成订单要返回一个json,一般包括金额和订单号即可,注意订单号需要唯一
}

public function payResult($params) {//支付成功处理,非常重要,你支付后业务处理要放到这里面
if ($params['result'] == 'success' && $params['from'] == 'notify') {//里面放业务代码
需要注意,这里面$_W['openid']是获取不到的,用下面代码
$uid = $params['tag']['uid'];
$openid = $params['user'];
$weid = $params['uniacid'];
$tid=$params['tid'];//这就是生成的唯一订单号 
$fee = $params['fee'];//金额
然后到订单表查询这个订单的信息包括传递的参数

}

}

到此支付开发就完成了,送一个生成订单函数

//生成sn订单,22位
function sn(){
return date('YmdHis').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
}

支付涉及钱的处理,所以要经过多重测试,可以用0.01元来测试,确认没问题再正式上线,有条件可以公测.开发中订单表至少包含金额,订单号,openid,weid以及传递的参数字段.


扫码二维码阅读

php数组的打乱与重组在表单提交中应用

extract数组打乱成变量
compact变量重组成数组

以上两个函数很多人不怎么使用,其实在表单处理中有着很好应用,学会了可以写很少的代码来添加数据更新数据;
在添加数据一般都是接受POST过来的数据,然后组成数组,再进行处理;

$i = "999";
$arr  = array(
'a'=>'我爱你',
'b'=>1,
'c'=>0,
'd'=>'美国',
);
extract($arr);
$arr2 = compact('a','b','c','d','i');
Array
(
    [a] => 我爱你
    [b] => 1
    [c] => 0
    [d] => 美国
    [i] => 999
)

以上是一个例子,实际应用中处理POST

extract($_POST);

使用这个最要注意的是保证数据库中字段名称和表单的一致,如果有少量不一致的,需要打乱后单独处理;学习这两个函数以后,处理表单事半功倍效果


扫码二维码阅读

POST和GET在curl中应用

在做爬虫,抓取网站,做同步,api开发,以及微信公众号开发中,curl使用非常重要,下面就来介绍curl使用;

函数两枚

//post提交
function post($url,$msg){//post ssl
$ch = curl_init();

if (class_exists('\CURLFile')) {
    curl_setopt($ch, CURLOPT_SAFE_UPLOAD, true);
} else {
    if (defined('CURLOPT_SAFE_UPLOAD')) {
        curl_setopt($ch, CURLOPT_SAFE_UPLOAD, false);
    }
}
//$msg = array('media'=>"@".$filepath);
//5.6+ $msg = array('media'=>new \CURLFile($filepath));
preg_match('/https:\/\//',$url)?$ssl=TRUE:$ssl=FALSE;
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_URL,$url);
if($ssl){
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
}
curl_setopt($ch, CURLOPT_POSTFIELDS,$msg);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$data = curl_exec($ch);
curl_close($ch);
return $data;
    }

//get获取
function get($url){   
 $ch = curl_init();
 preg_match('/https:\/\//',$url)?$ssl=TRUE:$ssl=FALSE;
 curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_HEADER, 0);
if($ssl){
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
}
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
$data  =  curl_exec($ch);
curl_close($ch);
return $data; 
}

两个函数都支持ssl,也就是https开头访问,能够自动判断是否是https网站;
特别注意5.6以上包括5.6版本php 上传可是和以前完全不一样,这是一个大坑


扫码二维码阅读

php自定义函数讲解之去除文章内空格换行

知识点

php中默认去除函数为trim,但是只能去除开头末尾空格,对于换行,内容中空格去无能为力,此时就要自定义函数来解决;

用途

去除空格有什么用呢?比如,微信中分享的描述,就需要去除内容中空格,换行等特殊字符,否则是不能分享的;

函数

function trimx($str) 
{ 
$str = trim($str);
$str = preg_replace("/\t/","",$str);
$str = preg_replace("/\r\n/","",$str); 
$str = preg_replace("/\r/","",$str); 
$str = preg_replace("/\n/","",$str); 
$str = preg_replace("/ /","",$str);
return trim($str);
}

说明

本函数功能就是去除换行,空格,跳格等


扫码二维码阅读