导航:首页 > 编程语言 > php开源项目wechat

php开源项目wechat

发布时间:2022-12-19 08:32:14

1. b2c开源免费php商城系统哪家好

shopex 、ecshop、pageadmin这些都是不错的、简单、方便,直接。

2. 怎么调用wechat.class.php

wechat.class.php 调用官方API,具有更灵活的消息分类响应方式,支持链式调用操作 ; 主要功能 接入验证 (初级权限) 自动回复(文本、图片、语音、视频、音乐、图文)(初级权限) 我学习的大概过程就是这样的,我认为这样还是不错的,具体的...

3. 如何用PHP实现微信支付,求教。新手!说明详细点

以PHP语言为例,对微信支付的开发流程进行一下说明:

1.获取订单信息。

2.根据订单信息和支付相关的账号生成sign,并且生成支付参数。

3.将支付参数信息POST到微信服务器,获取返回信息。

4.根据返回信息生成相应的支付代码(微信内部)或是支付二维码(非微信内),完成支付。

4. 微信支付lavel是什么

Laravel 微信开发组件-WeChat 微信支付
一、介绍
本教程是LAMP开发环境下基于larvel5.1LTS版进行的开发实例。
由于现在国内有很多优秀且具备开源精神的php开发者,因此出于节约时间成本和维护成本的考虑,微信开发采用组件化开发,我们没必要重复造轮子。本教程采用 overtrue 团队的 easywechat 组件进行微信的支付功能开发和实现。

由于这个组件功能过多 本篇博客主要介绍“扫码支付”的主要流程和思路。

二、composer安装
默认大家已经在自己的开发环境上已经安装了composer,并会一些简单的操作,安装命令

composer require "overtrue/laravel-wechat:~3.0"
* 如果你用了 laravel-debugbar,请禁用或者关掉,否则这模块别想正常使用!!! * (但是composer提示是否可以关闭x-debug,会影响安装之类的提示,可以不去管它)

三、在laravel中进行配置
1.注册 ServiceProvider (找到 config/app.php 配置文件中,key为 providers 的数组,在数组中添加服务提供者):

Overtrue\LaravelWechat\ServiceProvider::class,
2.(可选)添加 * 外观 * 在app/config/app.php 的 aliases 数组里,添加 * 别名 * :

'wechat' =>Overtrue\LaravelWechat\ServiceProvider::class,
3.创建配置文件(在项目根目录中运行 artisan 命令,发布配置文件到你的项目中):

php artisan vendor:publish
此时在/config目录下会生成配置文件wechat.php,在里面输入你的微信商家信息,这里请注意保护隐私。

四、 微信支付飞起
1.配置微信商家信息,laravel根目录下的.ENV文件支持以下配置:
WECHAT_APPID
WECHAT_SECRET
WECHAT_TOKEN
WECHAT_AES_KEY

WECHAT_LOG_LEVEL
WECHAT_LOG_FILE

WECHAT_OAUTH_SCOPES
WECHAT_OAUTH_CALLBACK

WECHAT_PAYMENT_MERCHANT_ID
WECHAT_PAYMENT_KEY
WECHAT_PAYMENT_CERT_PATH
WECHAT_PAYMENT_KEY_PATH
WECHAT_PAYMENT_DEVICE_INFO
WECHAT_PAYMENT_SUB_APP_ID
WECHAT_PAYMENT_SUB_MERCHANT_ID
WECHAT_ENABLE_MOCK
你可以在/config/wechat.php中进行相关参数配置,也可以写在.ENV文件中,然后,wechat.php具体读取方法:

'notify_url' => env('NOTIFY_URL', 'http://www.XXXXX.com/notify_url'), // 回调地址
env()默认读取.env文件中常量的值,如果.env中没有定义该常量,则返回env()的第二个参数的值。

2.wechat.php文件中需要注意的地方
(1).'log'数组内是日志配置。
(2).'payment'数组是主要配置的数组,主要配置商户的信息和证书。

3.(重点)创建订单
(1).引入命名空间

use EasyWeChat\Foundation\Application;
use EasyWeChat\Payment\Order;
(2).填写订单信息

$attributes = [
'trade_type' => 'JSAPI', // JSAPI,NATIVE,APP...
'body' => 'iPad mini 16G 白色',
'detail' => 'iPad mini 16G 白色',
'out_trade_no' => '1217752501201407033233368018',
'total_fee' => 5388,
'notify_url' => 'http://xxx.com/order-notify', // 支付结果通知网址,如果不设置则会使用配置里的默认地址,我就没有在这里配,因为在.env内已经配置了。
// ...
];
// 创建订单
$order = new Order($attributes);
$result = $payment->prepare($order);
if ($result->return_code == 'SUCCESS' && $result->result_code == 'SUCCESS')
{
//生产那个订单后的逻辑
\Log::info('生成订单号..'.$data->order_guid);
//这一块是以ajax形式返回到页面上。
//用户的体验就是点击【确认支付】,验证码以弹层页面出来了(没错,还需要一个好用的弹层js)。
$ajax_data=[
'html' => json_encode(\QrCode::size(250)->generate($result['code_url'])),
'out_trade_no' => $data->order_guid,
'price' => $data->price
];
return $ajax_data;
}else{
return back()->withErrors('生成订单错误!');
}
五、渲染页面
这里创建了订单,需要生成二维码图片,可以参考一下这个二维码图片组件。

Composer 设置
首先,添加 QrCode 包添加到你的 composer.json 文件的 require 里:

composer require "simplesoftwareio/simple-qrcode"
添加 Service Provider
注册 SimpleSoftwareIO\QrCode\QrCodeServiceProvider::class 至 config/app.php 的 providers 数组里.

添加 Aliases
最后,注册 'QrCode' => SimpleSoftwareIO\QrCode\Facades\QrCode::class 至 config/app.php 的 aliases 数组里.

pay.blade.php内容
<script type="text/javascript" src="{{ asset('vendor/jquery.js') }}"></script>
<script type="text/javascript" src="{{ asset('layer/layer.js') }}"></script>
<input class="wechat_btn" type="button" value="确认支付"/>
{!-- 这个页面需要有一些js代码,才能使支付功能更加美观可用无bug,比如ajax轮询,点击支付后的btn失效,放弃支付时关闭弹层等等 --}
js内容
$('.wechat_btn').click(function() {
$('.my_order_guid').val('');
$('#code').val('');
//ajax生成二维码
data={
'_token':$(".token").val(),//令牌
'money':$(".money").val(),//商品价格
}
sendAjax(data, "/order", function (data) {
//发送二维码过来(此处使用优美的layer弹层库)
layer.open({
type: 1,
title:'微信支付',
skin: 'layui-layer-rim', //加上边框
area: ['270px', '340px'], //宽高
content: "<p style='color:red;text-align: center;'>支付金额:"+data['price']
+"元</p> <input type='hidden' class='my_order_guid' value='"+data['out_trade_no']
+"'/><div id='code' style='text-align: center;'>"+JSON.parse(data['html'])+
"</div><p style='text-align: center;'>请使用微信扫码支付</p><script> $('.layui-layer-close').click(function() { layer.msg('您已放弃本次支付');setTimeout('window.location.reload()',3000); });</script>"
//这里我把弹层库有关的一点点js写到content里面去了。
});

getInfo();
//这里写一个轮询,可以异步查询订单是否支付完成的信息,从而进行逻辑处理(比如轮询支付状态,成功了跳转页面),仅仅提点一下我的想法,轮询的代码不用找,没有贴。

});

});
六、回调函数
先放上主要代码再说:

public function notifyUrl(Request $request)
{
$app = new Application(config('wechat'));
$response = $app->payment->handleNotify(function($notify, $successful){
if ($successful) {
$order_arr=json_decode($notify,true);
$order_guid=$order_arr['out_trade_no'];//订单号
//回调成功的逻辑
}
});
}
注意
(1).wechat发送回调是通过post方式,在路由处定义了之后,还需要在laravel项目中排除token验证,我建议在中间件中VerifyCsrfToken.php进行排除路由。

protected $except = [
//
'/pay_success_notify',
'/To_rule_out_route'
];
(2). * 重点!重点!重点! * 回调这里的处理可以说是重中之重,这里出岔子,可能会造成 用户支付成功后,微信的 * 回调没有进来 * ,后台回调的逻辑就没有执行,导致用户钱花了,东西没买上(即你的服务器上没有执行给付费用户修改支付状态等数据库操作)。另一种后果,如果没有正确返回微信参数,微信会多次发送回调信息来提醒你支付成功了,导致你的服务器 * 接受回调函数多遍 * 。而此时你也马马虎虎,没有在支付成功的逻辑上对用户的支付状态进行判断,导致逻辑用户充一次钱,在数据库却重复执行了好几次相关数据库操作。前者坑了付费用户,后者坑了你的公司,这里如果不注意的话,后果只会很严重,涉及到钱的地方要倍加小心。
(2).在回调路由指向的方法内,如果你的支付成功的逻辑成功运行了,需要return true;如果没有成功进行数据库操作,需要返回false;或不返回,微信会再一次发送回调信息(post方式)。

七、一些easywechat官方的建议:
这里需要注意的有几个点:

1.handleNotify 只接收一个 callable 参数,通常用一个匿名函数即可。

2.该匿名函数接收两个参数,这两个参数分别为:
$notify 为封装了通知信息的 EasyWeChat\Support\Collection 对象,前面已经讲过这里就不赘述了,你可以以对象或者数组形式来读取通知内容,比如:$notify->totalfee 或者 $notify['totalfee']。
$successful 这个参数其实就是判断 用户是否付款成功了(result_code == ‘SUCCESS’)

3.该函数返回值就是告诉微信 “我是否处理完成”,如果你返回一个 false 或者一个具体的错误消息,那么微信会在稍后再次继续通知你,直到你明确的告诉它:“我已经处理完成了”,在函数里 return true; 代表处理完成。

4.handleNotify 返回值 $response 是一个 Response 对象,如果你要直接输出,使用 $response->send(), 在一些框架里不是输出而是返回:return $response。

5.注意:请把 “支付成功与否” 与 “是否处理完成” 分开,它俩没有必然关系。
比如:微信通知你用户支付完成,但是支付失败了(result_code 为 ‘FAIL’),你应该更新你的订单为支付失败,但是要告诉微信处理完成。

后记
1.在微信开发中,大量用到了laravel自带的Log查错的方法,当var_mp(),echo(),dd()等方法不能查看错误信息是,使用日志查错就可以解决了。怎样使用laravel的log服务,这个以后会讲。
2.本项目开发可以说是组件化开发,有开发速度快,代码质量高,维护成本低等优点,本例的微信开发是一个缩影。

[原文地址](http://www.blog8090.com/)

5. php代码开发微信公众号二次开发问题-自动回复

6. 使用easywechat完成微信支付

由于工作需要,项目中要实现微信支付功能。项目开发语言为PHP,框架为Laravel 5.4

1,首先安装easywechat组件

composer require “overtrue/laravel-wechat:~3.0”

2,创建控制器WechatController

7. php开源工具哪些比较受欢迎

众所周知,软件行业是一个相对苦逼的行业,特别是遇到赶项目,很多程序猿就只有累成狗了。为了提高开发效率,让开发任务更简便、快捷,开源工具的使用是少不了的。今天小编整理了10款最受欢迎的php开源工具,分享给大家,希望可以帮助大家更便捷的开发php应用。
1、Monsta FTP
如果想在浏览器中设置一个FTP文件管理,你需要有一款像Monsta FTP一样的开源PHP或者Ajax Cloudware。不仅支持屏幕上的文件编辑,而且文件还可以被拖放到浏览器上实现快速上传。经测试Monsta FTP,支持所有主流浏览器,如:火狐,Chrome,IE浏览器,Safari浏览器等,并配备了多语言支持。
2、Pinba
Pinba使用只读格式的MySQL作为实时统计/监督服务器,几乎是一个MySQL存储引擎。它可以生成格式简单的统计报表,处理后通过UDP发送累计数据,并且还可以创建复杂的报表。
3、CaseBox
CaseBox是一个用于管理任务、记录和文档的开源PHP Web应用程序。它允许我们创建大量的目录,并将数据存储在一个类似于桌面界面的首选结构中。通过将指定了期限的任务分配给用户并跟踪性能,CaseBox极大地简化了工作流程。
4、Sylius
Sylius是一个基于Symfony 2的php开源工具,它允许你创建一个电子商务网站,并管理产品和类别复杂的网上商店。同时,Sylius还支持多种功能,如管理不同税率和运输方式。此外,Sylius还与支付网关(payment gateway)OmniPay集成而成为一款完美的电子商务工具。如果你用php开发了一个电子商务商城,不妨可以试试这个工具,它将极大的简化你的工作量。
5、Pico
Pico是一款开源的内容管理程序,使用Flat File文件作为其数据库,无需安装即可使用。使用这个开源工具,可以方便你在你所喜爱的文本编辑器中编辑储存在.md文件中的内容。
6、Munee
全面网站图书馆Munee,作为一款开源的php工具,可以让你优化和操作网站website assets、实现客户端和服务器端的资源缓存。同时Munee也可以集成PHP图像处理库,方便调整或裁剪图像并对它们进行缓存。
7、Phalcon PHP
Phalcon PHP是一款由C语言编写的web框架,提供了低资源消耗和高性能,适用于任何操作系统。
8、phpMyFAQ
phpMyFAQ是PHP FAQ(常见问题解答)的应用程序,同时也是一个优秀的FAQ系统。它可以管理用户、项目、类别和统计数据。phpMyFAQ中还自带一个先进的搜索系统,可帮助用户快速寻找到相关答案。
9、PHPImageWorkshop
PHP Image Workshop使用GD库来管理图像,允许以类似于Photoshop的方式编辑照片。同时,这款php开源工具也非常灵活,允许你叠加大量图像,使用旋转功能甚至缩略图。
10、DebugBar
DebugBar也是php开源应用程序中常用的一款工具,免费提供在线版本,并且可以集成到PHP 项目中。它包括通用库和流行库,支持Ajax请求,并且在页脚有一个JavaScript栏。
不管是什么语言的开发,要提高开发效率,掌握一些开源的工具都是少不了的。熟悉并掌握以上这10款PHP 开源工具,可极大的简化你的开发进程。如果你还没有使用过这些工具,不妨可以试试。

8. ThinkPHP3.2完全开发手册 的WechatAuth怎么是空的

首先你自定义类文件的名字不符合规范,XXX.class.php 其次,你这个是ThinkPHP3.2版本,这个版本导入类库推荐使用的是命名空间的方法,你看一下《ThinkPHP3.2完全开发手册》架构那一章,命名空间和自动加载两节,这样了解更深一些

9. 【开源源码】Discuz!生成微信、QQ、头条抖音及百度多端论坛小程序及APP

使用discuz论坛作为后端生成微信、QQ、支付宝、头条抖音及网络小程序,并支持安卓或苹果APP.

mobile:discuz掌上论坛插件

dzmini:原生小程序源码

dzmini_uni:多端小程序源码

修改配置文件config_oauths.php, 将申请好的小程序 appkey appsecret填入并保存

把mobile目录覆盖discuz网站的source/plugin/mobile目录

进入论坛后台,进入应用,找到掌上论坛插件并启用, 点击更新即可

在discuz后台点击全局——手机访问——开启手机访问及注册登录

修改小程序源码dzmini下的config.js配置文件,将域名换成您网站域名

测试没问题 提交上传审核即可

dzmini_uni需使用uniapp的工具进行编译,目前还有问题

https://github.com/poisonboy/discuz

10. PHP是否可以用做微信小游戏后端开发

当然可以,不过php用作游戏后台的话高并发不是很好,推荐java或go

阅读全文

与php开源项目wechat相关的资料

热点内容
dvd光盘存储汉子算法 浏览:757
苹果邮件无法连接服务器地址 浏览:963
phpffmpeg转码 浏览:672
长沙好玩的解压项目 浏览:145
专属学情分析报告是什么app 浏览:564
php工程部署 浏览:833
android全屏透明 浏览:737
阿里云服务器已开通怎么办 浏览:803
光遇为什么登录时服务器已满 浏览:302
PDF分析 浏览:486
h3c光纤全工半全工设置命令 浏览:143
公司法pdf下载 浏览:382
linuxmarkdown 浏览:350
华为手机怎么多选文件夹 浏览:683
如何取消命令方块指令 浏览:350
风翼app为什么进不去了 浏览:779
im4java压缩图片 浏览:362
数据查询网站源码 浏览:151
伊克塞尔文档怎么进行加密 浏览:893
app转账是什么 浏览:163