微信服务商支付phpsdk
① 第三方开发者怎么申请成为微信支付的服务商
三方开发者可以通过申请成为微信支付的服务商。申请的步骤就几步,根据它的要求即可申请成功啦,具体的要求步骤是:1:到公众平台注册一个公众号,记得是要服务号,并且要它认证的哦。如果没有认证,可以根据要求先认证。2:认证通过后,根据要求填写资料。3:验证一下账户,查看功能是否都正常能用,4:和它在线签署协议,成功后,即可成为它的服务商了。
嗯,我的回答应该很详细,如果有帮到你,记得给个好评哦。
② 如何用PHP实现微信支付,求教。新手!说明详细点
微信公众号JSAPI支付
一:配置参数
申请成功后,获取接口文件, 将所有文件放入项目根目录weixin下,在WxPay.ub.config.php中填入配置账户信息;
二:设置授权
开发者中心->网页服务->网页授权获取用户基本信息->修改;
“授权回调页面域名修改成你的域名地址即可,须保证网页授权已获得,不然会报redirect_uri 参数错误;
三:网页授权获取用户openid
js_api_call.php 请求文件中改动(所有传给微信的参数都在入口文件中接收)
$out_trade_no = $_GET['out_trade_no']; //商户系统内部订单号 32个字符内
$total_fee = $_GET['total_fee']*100; //订单总金额 单位为分,不能带小数点,所以须把价格乘以100,
不然获取prepay_id时会报错误(设置金额字段时最好设为小数点后2位)
$pay_status = get_pay_status($out_trade_no);//查看订单支付状态
$return_url = get_return_url($out_trade_no); //设置支付成功后跳转页面
//使用jsapi接口
$jsApi = new JsApi_pub();
//通过code获得openid
if (!isset($_GET['code'])) { //触发微信返回code码
//设置redirect_uri参数,返回code码地址,其实就是重定向到当前页面,获取用户code码参数
$url = WxPayConf_pub::JS_API_CALL_URL."?showwxpaytitle=1&out_trade_no=$out_trade_no&total_fee=$total_fee";
$url = $jsApi->createOauthUrlForCode($url);
Header("Location: $url");
}else{ //获取code码,以获取openid
$code = $_GET['code'];
$jsApi->setCode($code);
$openid = $jsApi->getOpenId(); //用户标识
}
再就是WxPayHubHelper.php文件 JsApi_pub()类下createOauthUrlForCode($redirectUrl)方法, 第二个参数
改为 $urlObj["redirect_uri"] = urlencode($redirectUrl); //对$url变量进行url编码 不然header重定向时无法获取订单号和金额
四:设置统一支付接口参数,获取prepay_id (预支付ID 微信生成的预支付 ID,用于后续接口调用中使用)
微信支付->开发配置->支付测试->测试授权目录和测试白名单添加
(支付授权目录需要精确到最细一级的目录,且在使用时,目录名称后直接加文件名,如ccc.com/weixin/)
确保你 WxPayPubHelper.php文件里 UnifiedOrder_pub 这个类的getPrepayId这个方法能正常使用
这一步的调试在 getPrepayId()内 var_mp($this->result); 就能看到错误代码;
posXml这个方法后调用了createXml这个方法
function postXml() {
$xml = $this->createXml();
//**在此处查看xml文件是否正常生成
include_once("log_.php");
$log = new Log_();
$log->log_result("log.txt",$xml);
//** 由于打印一些xml格式的文件只显示字符长度,不显示内容。于是用log的形式写在服务器上调试
$this->response = $this->postXmlCurl($xml,$this->url,$this->curl_timeout);
return $this->response;
}
保证xml这个变量格式如下;
<xml><openid><![CDATA[UKqsyD_711nkk2c]]></openid>
<body><![CDATA[pay]]</body>
<out_trade_no>201504101658571802></out_trade_no>
<total_fee>120</total_fee>
<notify_url><![CDATA[http://www.hao123.com/weixin/notify_url.php]]></notify_url>
<trade_type><![CDATA[JSAPI]]></trade_type>
<appid><![CDATA[wxfd3c4asdf]]></appid>
<mch_id>123334333102</mch_id>
<spbill_create_ip><![CDATA[192.168.0.1]]></spbill_create_ip>
<nonce_str><![CDATA[imsdasdcmlkhfa]]></nonce_str>
<sign><![CDATA[CBE62F36806A3E1]]></sign></xml>
参数正确,postXmlCurl才能正确提交,提交后就能得到正确的prepay_id,就能弹出支付框了
五:使用jsapi调起支付
根据prepay_id生成jsapi支付参数
$jsApi->setPrepayId($prepay_id);
$jsApiParameters = $jsApi->getParameters();
//调用微信JS api 支付
function jsApiCall() {
WeixinJSBridge.invoke(
'getBrandWCPayRequest',
<?php echo $jsApiParameters; ?>,
function(res){
WeixinJSBridge.log(res.err_msg);
if(res.err_msg == "get_brand_wcpay_request:ok") { //支付成功后
window.location.href="<?php echo $return_url;?>" //跳转地址及订单操作,在异步页面也须处理订单,防止同步时失败
}else{
alert("支付失败"+res.err_code+res.err_desc+res.err_msg);
}
}
);
}(每次请求callpay方法时须判断订单状态,防止重复提交)
六:通用通知接口 异步处理微信返回结果
支付完成后,notify.php中获取微信的回调
$xml = $GLOBALS['HTTP_RAW_POST_DATA'];
//须验证签名,并回应微信。
if($notify->checkSign() == TRUE) //签名验证通过并更新订单状态后
$notify->setReturnParameter("return_code","SUCCESS"); //设置返回码,保证支付状态改变后才返回成功
//对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败,
//微信会通过一定的策略(如30分钟共8次)定期重新发起通知,
$returnXml = $notify->returnXml();
echo $returnXml;(将xml数据返回微信 当return_code为SUCCESS时,不会再通知)
//当收到通知进行处理时,首先检查对应业务数据的状态,判断该通知是否已经处理过,如果没有处理过再进行处理,
如果处理过直接返回结果成功。在对业务数据进行状态检查和处理之前,要采用数据锁进行并发控制,
以避免函数重入造成的数据混乱.
//判断是否在微信浏览器打开
function isWeiXin(){
var ua = window.navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i) == 'micromessenger'){
return true;
}else{
return false;
}
}
步骤够详细了吧,我自己实现过,所以写了日志,结合php版本的demo 大致弄得出来了,如果对整个流程不太清楚,仔细的看完微信公众号支付接口文档,你申请微信公众号支付成功了就会有的,
③ 微信支付php sdk怎么使用
它里面集成了微信支付的很多功能函数。
你只需要直接调用这个接口即可,
如果能看的明白代码,你也可以自己根据自己的喜欢封装成类。
具体的用法只能去找api文档。
④ 微信支付接口 php
;;;;;;;;;;;;;;这个 你找找 是不是 有一行没有结束 或者是 单引号 双引号 用的不对
⑤ thinkphp微信h5支付sdk怎么用
主要的支付代码如下:
<?php
namespaceHomeController;
useThinkController;
//微信支付类
{
//获取access_token过程中的跳转uri,通过跳转将code传入jsapi支付页面
publicfunctionjs_api_call(){
$order_sn=I('get.order_sn','');
if(empty($order_sn)){
header('location:'.__ROOT__.'/');
}
vendor('Weixinpay.WxPayPubHelper');
//使用jsapi接口
$jsApi=newJsApi_pub();
//=========步骤1:网页授权获取用户openid============
//通过code获得openid
if(!isset($_GET['code'])){
//触发微信返回code码
$url=$jsApi->createOauthUrlForCode('域名/Wxpay/js_api_call?order_sn='.$order_sn);
//$url=$jsApi->createOauthUrlForCode(WxPayConf_pub::JS_API_CALL_URL);
Header("Location:$url");
}else{
//获取code码,以获取openid
$code=$_GET['code'];
$jsApi->setCode($code);
$openid=$jsApi->getOpenId();
}
$res=array(
'order_sn'=>'20150109113322',
'order_amount'=>255
);
//=========步骤2:使用统一支付接口,获取prepay_id============
//使用统一支付接口
$unifiedOrder=newUnifiedOrder_pub();
//设置统一支付接口参数
//设置必填参数
//appid已填,商户无需重复填写
//mch_id已填,商户无需重复填写
//noncestr已填,商户无需重复填写
//spbill_create_ip已填,商户无需重复填写
//sign已填,商户无需重复填写
$total_fee=$res['order_amount']*100;
//$total_fee=1;
$body="订单支付{$res['order_sn']}";
$unifiedOrder->setParameter("openid","$openid");//用户标识
$unifiedOrder->setParameter("body",$body);//商品描述
//自定义订单号,此处仅作举例
$out_trade_no=$res['order_sn'];
$unifiedOrder->setParameter("out_trade_no",$out_trade_no);//商户订单号
$unifiedOrder->setParameter("total_fee",$total_fee);//总金额
//$unifiedOrder->setParameter("attach","order_sn={$res['order_sn']}");//附加数据
$unifiedOrder->setParameter("notify_url",WxPayConf_pub::NOTIFY_URL);//通知地址
$unifiedOrder->setParameter("trade_type","JSAPI");//交易类型
//非必填参数,商户可根据实际情况选填
//$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商户号
//$unifiedOrder->setParameter("device_info","XXXX");//设备号
//$unifiedOrder->setParameter("attach","XXXX");//附加数据
//$unifiedOrder->setParameter("time_start","XXXX");//交易起始时间
//$unifiedOrder->setParameter("time_expire","XXXX");//交易结束时间
//$unifiedOrder->setParameter("goods_tag","XXXX");//商品标记
//$unifiedOrder->setParameter("openid","XXXX");//用户标识
//$unifiedOrder->setParameter("proct_id","XXXX");//商品ID
$prepay_id=$unifiedOrder->getPrepayId();
//=========步骤3:使用jsapi调起支付============
$jsApi->setPrepayId($prepay_id);
$jsApiParameters=$jsApi->getParameters();
$wxconf=json_decode($jsApiParameters,true);
if($wxconf['package']=='prepay_id='){
$this->error('当前订单存在异常,不能使用支付');
}
$this->assign('res',$res);
$this->assign('jsApiParameters',$jsApiParameters);
$this->display('jsapi');
}
//异步通知url,商户根据实际开发过程设定
publicfunctionnotify_url(){
vendor('Weixinpay.WxPayPubHelper');
//使用通用通知接口
$notify=newNotify_pub();
//存储微信的回调
$xml=$GLOBALS['HTTP_RAW_POST_DATA'];
$notify->saveData($xml);
//验证签名,并回应微信。
//对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败,
//微信会通过一定的策略(如30分钟共8次)定期重新发起通知,
//尽可能提高通知的成功率,但微信不保证通知最终能成功。
if($notify->checkSign()==FALSE){
$notify->setReturnParameter("return_code","FAIL");//返回状态码
$notify->setReturnParameter("return_msg","签名失败");//返回信息
}else{
$notify->setReturnParameter("return_code","SUCCESS");//设置返回码
}
$returnXml=$notify->returnXml();
//==商户根据实际情况设置相应的处理流程,此处仅作举例=======
//以log文件形式记录回调信息
//$log_name="notify_url.log";//log文件路径
//$this->log_result($log_name,"【接收到的notify通知】: ".$xml." ");
$parameter=$notify->xmlToArray($xml);
//$this->log_result($log_name,"【接收到的notify通知】: ".$parameter." ");
if($notify->checkSign()==TRUE){
if($notify->data["return_code"]=="FAIL"){
//此处应该更新一下订单状态,商户自行增删操作
//$this->log_result($log_name,"【通信出错】: ".$xml." ");
//更新订单数据【通信出错】设为无效订单
echo'error';
}
elseif($notify->data["result_code"]=="FAIL"){
//此处应该更新一下订单状态,商户自行增删操作
//$this->log_result($log_name,"【业务出错】: ".$xml." ");
//更新订单数据【通信出错】设为无效订单
echo'error';
}
else{
//$this->log_result($log_name,"【支付成功】: ".$xml." ");
//我这里用到一个process方法,成功返回数据后处理,返回地数据具体可以参考微信的文档
if($this->process($parameter)){
//处理成功后输出success,微信就不会再下发请求了
echo'success';
}else{
//没有处理成功,微信会间隔的发送请求
echo'error';
}
}
}
}
//订单处理
privatefunctionprocess($parameter){
//此处应该更新一下订单状态,商户自行增删操作
/*
*返回的数据最少有以下几个
*$parameter=array(
'out_trade_no'=>xxx,//商户订单号
'total_fee'=>XXXX,//支付金额
'openid'=>XXxxx,//付款的用户ID
);
*/
returntrue;
}
}
?>
⑥ PHP调用微信支付接口
不一定,看你业务需要。这些步骤只是描述微信系统会发出和接收什么数据,商户需要发送和会接收到什么数据,用户需要执行什么操作。回调的URL是用来接收数据的,至于发送并没有要求。
⑦ 微信支付服务商申请怎么弄
微信支付服务商申请条件:
1、 微信认证的企业类型服务号,微信支付服务商目前只面对企业认证的服务号才能开发申请。
2、 申请资料
A、 公司联系方式:包含联系人姓名、联系电话和联系邮箱
B、 客服电话
C、 公司对公账户信息:包含开户行省市信息,开户账号
微信支付商户平台申请步骤:
一、 资料填写
1、
登录微信支付服务商平台(MP),网址为https://pay.weixin.qq.com/index.php/partner/public/home。点击“微信支付”,然后“服务商申请”
2、 按照页面的指引,填写申请资料
3、 资料提交后,将等待审核,同时微信支付会向填写的对公账户打一笔金额随机的验证款。
如果资料审核通过,则进行下一步账户验证,如果资料没有审核通过,申请人从新提交资料,可以根据驳回的理由重新修改提交。
二、 账户验证
1、 登录服务商平台,查收开户邮件,获取商户平台登录账号和密码
2、 登录商户平台,网址: https://pay.weixin.qq.com
3、 在商户平台中,输入验证款金额数字,通过商户身份验证
通过账户验证后,就进入协议签约
三、 协议签约
1、 确认商户信息无误后,在线阅览协议后,签约
2、 签约完成后,支付服务商申请流程完成,则服务商功能开放。