一.实战问题与方案总结
1.SQL查询条件是一组数,传参却是一个字符串导致报错,如下
SQLSTATE[HY093]: Invalid parameter number (SQL: select count(*) as aggregate from `car_video` where `province_id` in (1492) and `city_id` in (1493) and `county_id` in (1) and `company_id` in (?) and `car_video`.`deleted_at` is null)
问题原因:company_id传了一个整型的2,SQL查询却用的whereIn
解决方案:前端修改了传参为一个数组,并且后端加入is_array判断和非数组转化
2.合并数据的时候用了array_merge(),报错,如下
array_combine(): Both parameters should have an equal number of elements
问题原因:合并数据的时候,两部分数据类型不一致,一个整型,一个数组导致
解决方案:都修改成数组类型,问题解决
二.laravel在对接微信小程序时,经验总结如下:
1. 注册小程序并获取 AppID 和 AppSecret
在微信公众平台注册一个小程序账号,获取小程序的 AppID 和 AppSecret。这两个参数将用于后续操作。
2. 安装 EasyWeChat SDK
EasyWeChat 是一款基于 PHP 的微信开发工具包,可以用于 Laravel 项目中对接微信小程序。可以使用 Composer 安装 EasyWeChat SDK。
3. 配置 EasyWeChat
在 Laravel 项目中,可以使用 config 文件夹下的 `wechat.php` 文件来配置 EasyWeChat。在该文件中,需要配置 AppID、AppSecret、Token 等参数。可以根据实际情况进行配置。
4. 创建路由和控制器
在 Laravel 中,可以使用路由和控制器来定义小程序的接口。在 `routes/api.php` 文件中定义路由,并在相应的控制器中编写处理逻辑。
5. 实现登录逻辑
小程序需要用户登录才能使用,因此需要实现登录逻辑。可以在控制器中编写登录方法,调用 EasyWeChat SDK 提供的登录接口,获取用户的 OpenID 和 SessionKey。
6. 实现数据加密和解密
小程序传输的数据需要进行加密和解密,可以使用 EasyWeChat SDK 中提供的加密和解密功能。在控制器中编写相应的方法,对传输的数据进行加密和解密操作。
7. 其他功能实现
除了登录以外,还需要实现其他的小程序功能,如支付、推送、用户信息获取等。可以参考 EasyWeChat SDK 的文档,查找相应的接口并进行实现。
8. 测试和优化
在完成对接小程序的开发后,需要进行测试,并根据实际情况进行优化。可以使用 Postman 等工具进行接口测试,并记录问题和优化点。