laravel-weapp

A weapp login logic Laravel warpper

本仓库从 wafer2开发套件 中提取并封装了微信小程序的登陆逻辑并转移到Laravel中,不仅降低开发者的学习成本,而且能快速完成小程序的登陆功能 甚至连数据库都不需要担心,因为插件已经包装好数据库的操作了。您只需要导入相关的表到数据库中即可。 若需要使用自己的数据库和用户的逻辑操作,只需要继承相应的接口和提供 Facade 类就可以了。详情可以查看使用自己的数据库和逻辑

特点

使用了 Guzzlehttp 来发送请求 使用了 Laravel 的 Eloquent ORM 封装了数据库操作,只需要导入表到数据库中即可。当然了,您也可以使用您自己的逻辑

注意

请配合开发者工具和js-sdk使用

安装

只需要五步即可完成安装部署。

通过 composer 安装: composer require jmluang/weapp:2.*

添加 Provider 到config/app.php

'providers' =>[ // Laravel Framework Service Providers // ... jmluangweappWeappLoginServiceProvider::class, ] 发布配置文件

php artisan vendor:publish --provider="jmluangweappWeappLoginServiceProvider"

参数如下:

参数 说明
appid 你的 AppID 必须
secret 你的 AppSecret 必须
code2session_url 默认url 不用改变
WxLoginExpires 7200(秒) 选填,填写前先取消备注
NetworkTimeout 3000(毫秒) 选填,填写前先取消备注

配置参数有两种方法,一种是直接写到weapp.php文件中,另一种是写到.env文件中,使用哪种方法都可以。但是有一点需要注意,若你的项目会发布到开源社区,则不推荐使用第一种方法,因为这样做存在泄露信息的风险。

WxLoginExpiresNetworkTimeout 都使用了默认的参数,如果你有特殊的需求需要改这两个参数,只要取消备注并填写即可。

添加数据库 Facade 到config/app.php

'aliases' => [ // Laravel Framework Facades // ... 'WeappUserRepository' => jmluangweappFacadesWeappUserRepository::class, 'WeappUser' => jmluangweappFacadesWeappUser::class, ]

若重写了数据库逻辑,则这里应该使用你自己的 Facade 类:

'aliases' => [ // Laravel Framework Facades // ... 'WeappUserRepository' => yournamespaceFacadeClass::class, 'WeappUser' => yournamespaceModelClass::class, 迁移数据库

php artisan migrate

若重写了数据库逻辑,则可以忽略这一步

使用方法

Laravel 配置 安装完成后,下面创建一个控制器和路由规则 路由文件:

// filepath routes/web.php <?php Route::get('/weapp/login',"LoginController@login"); Route::get('/weapp/user',"LoginController@user");

控制器:

// filepath app/Http/Controllers/LoginController.php <?php namespace AppHttpControllers; use jmluangweappConstants; use jmluangweappWeappLoginInterface as LoginInterface; class LoginController extends Controller { /** * 首次登陆 * @param LoginInterface $login * @return array */ public function login(LoginInterface $login) { $result = $login::login(); if ($result['loginState'] === Constants::S_AUTH) { return [ 'code' => 0, 'data' => $result['userinfo'] ]; } else { return [ 'code' => -1, 'error' => $result['error'] ]; } } /** * 登陆过就使用这个接口 * @param LoginInterface $login * @return array */ public function user(LoginInterface $login) { $result = $login::check(); if ($result['loginState'] === Constants::S_AUTH) { return [ 'code' => 0, 'data' => $result['userinfo'] ]; } else { return [ 'code' => -1, 'data' => [] ]; } } } 微信小程序中 首先在小程序中引入 js-skd,然后就可以写相关的逻辑了

// 目录结构 project ├── app.js ├── app.json ├── app.wxss ├── ... └── vendor └── weapp-login ├── lib │ ├── constants.js │ ├── login.js │ ├── request.js │ ├── session.js │ └── utils.js        └── weapp.js

// filepath app.js var login = require('./vendor/weapp-login/weapp') App({ onLaunch: function(){ // 设置登陆url,对应上面Controll的Login方法 login.setLoginUrl("https://localhost/weapp/login") login.login({ success(result) { if (result) { // 首次登陆 console.log("登陆成功", result) } else { // 二次登陆,请求Controller的User方法 login.request({ url: "https://localhost/weapp/user", login: true, success(result) { console.log("登陆成功", result.data.data) }, fail(error) { console.log("登录失败", error) } }) } }, fail(error) { console.log("登录失败", error) } }) } })

使用自己的数据库和逻辑

要使用自己的数据库逻辑,只需要简单的三步操作

继承接口类jmluangweappWeappUserInterface 并实现storeUserInfofindUserBySKey方法 创建Facade类 在 configapp.phpaliases数组中使用您的Facade类覆盖jmluangweappFacadesWeappUser::class

'aliases' => [ // Laravel Framework Facades // ... // 'WeappUserRepository' => jmluangweappFacadesWeappUser::class, 'WeappUserRepository' => pathtoyourFacadeClass::class, ]

Done!


若本仓库对您有所帮助,欢迎Start

若发现问题或需要帮助,欢迎提交Issue

感谢!

LICENSE

MIT

Written with StackEdit.

版权声明:

1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。
2、网站不提供资料下载,如需下载请到原作者页面进行下载。
3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考学习用!
4、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。