慢慢的你会发现除了获取参数的地方不一样,登录流程都差不多,可能是接口路径啥的不太一致
但是获取用户信息,**出奇的一至**:`https://api.weixin.qq.com/sns/userinfo`
**获取openid的却不一样**
小程序的是:`https://api.weixin.qq.com/sns/jscode2session`
扫码的、公众号的、app的是:`https://api.weixin.qq.com/sns/oauth2/access_token`
## pc扫码
开始解说
先来个公共的curl函数
```php
function geturl($url){
$headerArray =array("Content-type:application/json;","Accept:application/json");
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch,CURLOPT_HTTPHEADER,$headerArray);
$output = curl_exec($ch);
curl_close($ch);
$output = json_decode($output,true);
return $output;
}
```
1、获取二维码
```php
$appid="wx1e1275cb2e70e359";
//扫码后回调地址
$url=urlencode("http://www.taianyuannongmu.com/business/login/weixin2");
$headerurl="https://open.weixin.qq.com/connect/qrconnect?appid=".$appid;
$headerurl.="&redirect_uri=".$url;
$headerurl.="&response_type=code&scope=snsapi_login&state=wechat_redirect"
header("Location:".$headerurl);
```
2、成功回调获取openid
```php
$appid="";
$AppSecret="";
$url=urlencode("http://www.taianyuannongmu.com/business/login/weixin2");
$weixinurl= "https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$appid;
$weixinurl.="&secret=".$AppSecret;
$weixinurl.="&code=".$_GET["code"];
$weixinurl.="&grant_type=authorization_code";
//这里是curl
$res=$this->geturl($weixinurl);
$_SESSION["access_token"]=$res['access_token'];
$_SESSION["openid"]=$res['openid'];
```
3.获取用户信息
```php
$access_token=$_SESSION["access_token"];
$openid=$_SESSION["openid"];
/*获取用户信息*/
$get_user_info_url='https://api.weixin.qq.com/sns/userinf';
$get_user_info_url.='?access_token='.$access_token;
$get_user_info_url.='&openid='.$openid.'&lang=zh_CN';
$weixin3res= $this->geturl($get_user_info_url);
```
剩下的就是逻辑代码处理
## app登录
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210415141316813.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd6aGFl,size_16,color_FFFFFF,t_70)
前端调取授权
后端根据前端的code获取OPENID和身份信息
先来个公共的curl函数
```php
function geturl($url){
$headerArray =array("Content-type:application/json;","Accept:application/json");
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch,CURLOPT_HTTPHEADER,$headerArray);
$output = curl_exec($ch);
curl_close($ch);
$output = json_decode($output,true);
return $output;
}
```php
$appid = ""; //开发平台申请
$appsecret = ""; //开发平台申请
$code = $_GET['code']; //安卓端提供用户同意登入后的code
//认证
$url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$appid."&secret=".$appsecret."&code=".$code ."&grant_type=authorization_code";
//调用微信api
$rs = $this -> geturl($url);
if(!$rs)$this -> error('获取OPENID失败');
$rt = json_decode($rs, 1);
if($rt['errcode'])$this -> error('授权失败:'.$rt['errmsg']);
// 拉取用户信息
$url = "https://api.weixin.qq.com/sns/userinfo?access_token=".$rt['access_token']."&openid=".$rt['openid']."&lang=zh_CN ";
$wechat_info = $this -> geturl($url);
if(!$wechat_info)$this -> error('获取用户资料失败:CURL '.$http -> errmsg);
$wechat_info = json_decode($wechat_info, 1);
if($wechat_info['errcode']){
$this -> error("获取用户资料失败".$wechat_info['errmsg']);
}
$user_info = array(
"headimg"=>$wechat_info['headimgurl'], //头像
"nickname"=>$wechat_info['nickname'], //昵称
"sex"=>$wechat_info['sex'], //性别
"openid"=>$wechat_info['openid'], //app唯一
"unionid"=>$wechat_info['unionid'] //微信内部唯一,小程序, 公众号, web, 移动应用都是一致的
);
```
## 小程序
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210415140958556.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd6aGFl,size_16,color_FFFFFF,t_70)
1、前端获取到code后传给后端
2、通过code获取openid 接口路径https://api.weixin.qq.com/sns/jscode2session?
3、通过openid获取用户信息 接口路径 https://api.weixin.qq.com/sns/userinfo?
整合代码
```php
<?php
namespace real;
/**
* 小程序登录类
*/
class WeChatMiniProgram
{
public $APPID="";
public $SECRET="";
// 1、前端获取到 code 后传给后端
// 2、通过 code 获取 openid
public function getOpenid($code){
$httpcurl="https://api.weixin.qq.com/sns/jscode2session?";
$httpcurl.="appid=".$this->APPID;
$httpcurl.="&secret=".$this->SECRET;
$httpcurl.="&js_code=".$code;
$httpcurl.="&grant_type=authorization_code";
$zz=$this->geturl($httpcurl);
return $zz;
}
//3、通过openid获取用户信息
public function getUserinfo($access_token,$openid){
$get_user_info_url='https://api.weixin.qq.com/sns/userinfo';
$get_user_info_url.='?access_token='.$access_token;
$get_user_info_url.='&openid='.$openid.'&lang=zh_CN';
$data=$this->geturl($get_user_info_url);
return $data;
}
//getcurl
public function geturl($url){
$headerArray =array("Content-type:application/json;","Accept:application/json");
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch,CURLOPT_HTTPHEADER,$headerArray);
$output = curl_exec($ch);
//关闭URL请求
if($output === FALSE ){
echo "CURL Error:".curl_error($ch);
}
curl_close($ch);
$output = json_decode($output,true);
return $output;
}
}
```
## 公众号
**写代码前先得服务器配置**
服务器配置验证用
```php
$timestamp = $_GET['timestamp'];
$nonce = $_GET['nonce'];
$token = 'weixuegu';
$signature = $_GET['signature'];
$array = array($timestamp,$nonce,$token);
sort($array);
//将排序后的三个参数拼接之后参数拼接之后进行sha1加密
$tmpstr = implode('',$array);
$tmpstr = sha1($tmpstr);
// $file_write = file_put_contents("./".time().'.text',$signature.",".json_encode($tmpstr));
//将加密后的字符串与signature进行对比;
if($tmpstr == $signature && isset($_GET['echostr'])){
echo $_GET['echostr'];
exit;
}else{
$this->responseMsg();
}
```
**去权限设置,授权登录,设置域名**
![在这里插入图片描述](https://img-blog.csdnimg.cn/2020061717411070.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd6aGFl,size_16,color_FFFFFF,t_70)
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210415141227508.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd6aGFl,size_16,color_FFFFFF,t_70)
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210415141239731.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd6aGFl,size_16,color_FFFFFF,t_70)
来我们解释代码了
**微信公众号第一步:获取code**
```php
$appid= $this->appid;
$url="https://open.weixin.qq.com/connect/oauth2/authorize?appid=";
//appid
$url.=$appid;
$url.="&redirect_uri=";
// 这里是回调的域名和地址
$url.="http://".$_SERVER['SERVER_NAME']."/api/Weixinlogin";
//下面的都是固定参数
$url.="&response_type=code";
$url.="&scope=snsapi_userinfo";
$url.="&state="."123";
$url.="#wechat_redirect";
header("location: ".$url) ; exit();
```
**微信公众号第二步:根据code获取openid**
```php
$appid= $this->appid;
$secret= $this->secret;
//第一步返回的code
$code = $_GET['code'];
$get_token_url='https://api.weixin.qq.com/sns/oauth2/access_token?appid=';
$get_token_url.=$appid;
$get_token_url.='&secret=';
$get_token_url.=$secret;
$get_token_url.='&code=';
$get_token_url.=$code;
$get_token_url.='&grant_type=authorization_code';
//通过curl获取到数据access_token和openid
$curl = curl_init(); // 启动一个CURL会话
curl_setopt($curl, CURLOPT_URL, $get_token_url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);// 跳过证书检查
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$res = curl_exec($curl);
if($res === FALSE ){
echo "CURL Error:".curl_error($curl);
}
$json_obj=json_decode($res,true);
$_SESSION["access_token"]=$json_obj['access_token'];
$_SESSION["openid"]=$json_obj['openid'];
```
**微信公众号第四步:根据openid获取用户信息**
这里不用第三步,没必要哈
```php
$access_token=$_SESSION['access_token'];
$openid=$_SESSION["openid"];
$get_user_info_url='https://api.weixin.qq.com/sns/userinfo?access_token='.$access_token.'&openid='.$openid.'&lang=zh_CN';
$curl1 = curl_init(); // 启动一个CURL会话
curl_setopt($curl1, CURLOPT_URL, $get_user_info_url);
curl_setopt($curl1, CURLOPT_RETURNTRANSFER, 1);// 跳过证书检查
curl_setopt($curl1, CURLOPT_SSL_VERIFYPEER, false);
$res1 = curl_exec($curl1); //返回api的json对象
//关闭URL请求
if($res1 === FALSE ){
echo "CURL Error:".curl_error($curl1);
}
////解析json
$user_obj=json_decode($res1,true);
$data=$user_obj;
```
**然后我们可以根据openid,进行登录,如果没有账户,让客户绑定手机或者进行注册**
```php
<?php
namespace app\api\controller;
header('Access-Control-Allow-Origin:*');
// 响应类型
header('Access-Control-Allow-Methods:*');
// 响应头设置
header('Access-Control-Allow-Headers:*');
header('Access-Control-Allow-Credentials: true');
use app\common\controller\Api;
use app\common\library\Ems;
use app\common\library\Sms;
use fast\Random;
use think\Validate;
use think\Db;
use think\Config;
use \app\common\model\User;
use app\common\model\UserRule;
use app\common\library\Token;
use think\Exception;
use think\Hook;
use think\Request;
/**
* 会员接口
*/
class Weixinlogin extends Api
{
public $appid="";
public $secret="";
protected $noNeedLogin = ['*'];
protected $noNeedRight = '*';
public function index(){
if(isset($_GET)&&!empty($_GET)){
$this->weiixnhuidiao();
}else{
$this->weilogin();
}
}
public function weilogin(){
$appid= $this->appid;
$url="https://open.weixin.qq.com/connect/oauth2/authorize?appid=";
$url.=$appid;
$url.="&redirect_uri=";
// $url.="http://admin.weixuegu.cn/api/Weixinlogin";
$url.="http://".$_SERVER['SERVER_NAME']."/api/Weixinlogin";
$url.="&response_type=code";
$url.="&scope=snsapi_userinfo";
$url.="&state="."123";
$url.="#wechat_redirect";
header("location: ".$url) ; exit();
}
public function weiixnhuidiao(){
//第二步
if(!isset($_SESSION["openid"]) || empty($_SESSION["openid"])){
$appid= $this->appid;
$secret= $this->secret;
$code = $_GET['code'];
$get_token_url='https://api.weixin.qq.com/sns/oauth2/access_token?appid=';
$get_token_url.=$appid;
$get_token_url.='&secret=';
$get_token_url.=$secret;
$get_token_url.='&code=';
$get_token_url.=$code;
$get_token_url.='&grant_type=authorization_code';
$curl = curl_init(); // 启动一个CURL会话
curl_setopt($curl, CURLOPT_URL, $get_token_url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);// 跳过证书检查
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$res = curl_exec($curl);
if($res === FALSE ){
echo "CURL Error:".curl_error($curl);
}
$json_obj=json_decode($res,true);
// var_dump($json_obj);die;
$_SESSION["access_token"]=$json_obj['access_token'];
$_SESSION["openid"]=$json_obj['openid'];
}
//第四步
$access_token=$_SESSION['access_token'];
$openid=$_SESSION["openid"];
$get_user_info_url='https://api.weixin.qq.com/sns/userinfo?access_token='.$access_token.'&openid='.$openid.'&lang=zh_CN';
$curl1 = curl_init(); // 启动一个CURL会话
curl_setopt($curl1, CURLOPT_URL, $get_user_info_url);
curl_setopt($curl1, CURLOPT_RETURNTRANSFER, 1);// 跳过证书检查
curl_setopt($curl1, CURLOPT_SSL_VERIFYPEER, false);
$res1 = curl_exec($curl1); //返回api的json对象
//关闭URL请求
if($res1 === FALSE ){
echo "CURL Error:".curl_error($curl1);
}
////解析json
$user_obj=json_decode($res1,true);
$data=$user_obj;
$url =" http://swa.weixuegu.cn";
$i=0;
foreach ($data as $key=>$value) {
if($i==0&&!is_array($value)){
$i++;
$url.="?".$key."=".urldecode($value);
}else if(!is_array($value)){
$i++;
$url.="&".$key."=".urldecode($value);
}
}
echo " <script>";
echo ' window.open("'.$url.'");';
echo " </script>";
echo ' <script src="https://cdn.bootcss.com/vConsole/3.3.0/vconsole.min.js"></script>
<script>
// init vConsole
var vConsole = new VConsole();
console.log(res);
</script>
';
//die;
}
public function login($openid,$password=""){
//username mobile
$user = User::get(['weixinopenid' => $openid]);
if (!$user) {
$this->error("没有账户");
}
if ($user['status'] == 'hidden') {
$this->error("用户被禁用");
}
if ($user) {
$ret = $this->auth->weixinopenid_login($user->username);
if ($ret) {
$data = ['userinfo' => $this->auth->getUserinfo()];
$this->success(__('Logged in successful'), $data);
} else {
$this->error($this->auth->getError());
}
}else {
$this->error("失败2");
}
}
/**
* 设置错误信息
*
* @param $error 错误信息
* @return Auth
*/
public function setError($error)
{
$this->_error = $error;
return $this;
}
public function Binding_user(){
//username mobile
$mobile = $this->request->request("mobile");
$password = $this->request->request("password");
$openid = $this->request->request("openid");
$headimgurl = $this->request->request("headimgurl");
if (!$password ) {
$this->error(__('密码不能为空'));
}
if (!Validate::regex($mobile, "^1\d{10}$")) {
$this->error(__('账户格式错误'));
}
$user = \app\common\model\User::getByMobile($mobile);
if (!$user) {
// 检测用户名或邮箱、手机号是否存在
$this->error(__('你还没有账号哦,请在pc端注册并绑定微信'));
}
if ($user->password != md5(md5($password) . $user->salt)) {
$this->error(__('密码错误'));
}
$user->weixinopenid = $openid;
$user->avatar = $headimgurl;
$user->save();
// $ret = $this->auth->login($mobile, $password);
$this->login($openid);
//$this->success(__('Logged in successful'), $ret);
}
}
```
- 服务器购买到搭建宝塔
- 结构规范
- php基础
- php简介
- php是什么
- PHP 能做什么
- PHP 如何运行
- 如何了解弱语言
- 安装环境
- 安装LNMP
- 宝塔
- phpstudy
- PHP基本语法
- PHP 标记
- 从 HTML 中分离
- 指令分隔符
- 注释
- php 数据类型
- 类型检测
- 四种标量类型
- boolean(布尔型)
- Integer 整型
- Float 浮点型
- String 字符串类型
- 两种复合类型
- array(数组)
- object(对象)
- 两种特殊类型
- resource(资源)
- NULL(无类型)
- 类型转换
- 变量
- 变量定义和命名规范
- 传值和引用
- 预定义变量
- php预定义变量
- $_SERVER详解
- 变量范围
- 全局变量
- 静态变量
- 可变变量
- 常量
- 常量简介
- 常量定义
- 相比变量
- 魔术常量
- 运算符
- 运算符简介
- 算术运算符
- 赋值运算符
- 位运算符
- 比较运算符
- 错误控制运算符
- 执行运算符
- 递增(减)运算符
- 逻辑运算符
- 字符串运算符
- 数组运算符
- 新增操作符
- 控制结构
- 控制简介
- if 语句
- while 语句
- for 语句
- foreach 语句
- break 语句
- continue 语句
- switch 语句
- declare 语句
- return 语句
- include 语句
- PHP 函数
- 函数简介
- 用户自定义函数
- 函数的参数
- 返回值
- 可变函数
- 内部函数
- 匿名函数
- PHP 的类和对象
- PHP 的类和对象简介
- 基本概念
- 对象继承
- 属性
- 类常量
- 自动加载对象
- 构造和析构函数
- 访问控制
- 范围解析操作符(::)
- 静态static
- Static 关键字
- 抽象类
- 接口
- 匿名类
- 面向对象其他特性
- const关键字
- final关键字
- abstract用于定义抽象方法和抽象类。
- self、$this、parent::关键字
- 接口(interface)
- trait关键字
- instanceof关键字
- 魔术方法
- 构造函数和析构函数
- 私有属性的设置获取
- __toString()方法
- __clone()方法
- __call()方法
- 类的自动加载
- 会话控制
- cookie
- PHP 操作 cookie
- 项目实战
- SESSION
- Session 的初步介绍与实验准备
- PHP 操作 session
- 项目实战2
- http
- 特点
- 工作过程
- request
- response
- HTTP状态码
- URL
- GET和POST的区别
- HTTPS
- 常用函数
- 常用的字符串函数
- 常用的数组函数
- 常用文件函数
- 常用时间函数
- 常用日历函数
- 常用url函数
- 面试题常见
- 时间戳
- 技术类文档
- 技术开发文档
- 开发环境
- 开发规范
- 注释规范
- 开发目录结构
- 数据库字典
- 路由
- 定时任务
- 获取系统配置
- 系统常用函数
- 后台表单
- 消息队列
- 第三方类库标注
- 需求文档
- 数据库
- MYSQL
- 事务(重点)
- 索引
- 存储过程
- 触发器
- 视图
- 导入导出数据库
- 优化mysql数据库的方法
- MyISAM与InnoDB区别
- 外连接、内连接的区别
- 物理文件结构
- MongoDB
- Redis
- 运用场景和实例
- pgsql
- 服务器
- Nginx
- 正向代理和反向代理
- 负载均衡
- Linux常用命令
- 基本目录和命令
- php开发工具
- phpStorm编辑器
- 安装和汉化
- 链接ftp
- 常用操作
- 常用快捷键
- 自定义快捷键
- 使用快捷键新建目录和文件
- 使用快捷键快速查找文件、类、方法
- 多文件切换
- 快速搜索设置项
- 多点编辑
- 方法重构
- 自定义文件模板和代码片段
- 自定义文件模板
- 自定义代码片段
- Xdebug 调试插件
- 安装Xdebug 调试插件
- 在PHPStorm 中使用 Xdebug 插件调试代码
- Vi Box虚拟机
- Vi Box 虚拟机 Oracle VM VirtualBox
- 虚拟机辅助工具一-Vagrant
- 华硕主板BIOS设置中VT虚拟化技术选项怎么开启 Oracle VM VirtualBox
- 沟通工具
- 文档分享
- 流程图
- 任务分配
- 代码托管
- 缺陷管理
- 设计图
- gitLab
- 安装
- 汉化
- Gitlab 用户和项目管理
- Gitlab 持续集成与自动构建实践
- PHP进阶
- 大流量解决方案
- PSR规范
- RESTFUL规范
- 设计模式
- 单例模式
- 策略模式
- 工厂模式
- 简单工厂模式
- 工厂方法模式
- 抽象工厂模式
- 外观模式
- 享元模式
- 代理模式
- 命令模式
- 中介者模式
- 观察者模式
- 状态模式
- 建筑者模式
- 适配器模式
- 桥接模式
- 装饰器模式
- 排序算法
- 冒泡排序算法
- 二分查找算法
- 直接插入排序算法
- 希尔排序算法
- 选择排序算法
- 快速排序算法
- 常见网络攻击类型
- CSRF攻击
- XSS攻击
- SQL注入
- Cookie攻击
- thinkphp
- thinkphp5命令行
- git
- Git 常用命令操作和基础学习
- 傻瓜与白痴的笔记本
- 学习
- 一、Git 与 GitHub 的来历
- 二、在 GitHub 上创建仓库
- 三、安装
- Windows 上安装 Git
- 安装2
- 四、克隆 GitHub 上的仓库到本地
- 五、GIT基本操作哦
- 六、Git 分支操作
- 一、添加SSH关联授权
- 二、为 Git 命令设置别名
- 三、Git 分支管理
- 七、多人协作 GitHub 部分
- 八、多人协作 Git 部分
- 九、Git tag 和 GitHub releases
- composer
- Composer 基础使用
- 安装和使用
- 在项目中集成PHPmailer
- 认识composer.json和composer.lock文件
- composer的其他命令操作
- 本地创建composer包
- 提交自己的依赖包到composer Packagist
- crontab计划任务
- Linux任务计划crontab
- php 的 计划任务——Crontab
- bootstrap前端框架
- 入门
- 实战技巧
- 后台模板样式——admin
- 第三方接口对接
- 微信
- 敏感词过滤
- 微信图片检测
- 短信类型
- 阿里云短信
- 容联云短信
- 飞鸽短信
- 媒体
- 新闻接口测试
- 免费新闻
- 免费视频
- nba赛事,未测试
- 豆瓣电影接口
- 音乐接口
- 网易短视频接口
- 知乎微信接口
- 百度ai
- 百度语音
- 图片识别
- 腾讯
- 腾讯im
- 腾讯云直播
- 腾讯滑动验证
- 物流快递
- 快递鸟、快递100
- 推送
- 极光推送
- 地图&天气
- 获取城市和天气预报
- 地址获取和定位
- 地址转换经纬度
- 图片类型
- 360新闻图片
- 多平台翻译
- 实名认证
- 七牛云
- 云合同
- 多站点收录查询接口
- 打印机
- 第三方登录
- 微信登录
- 支付
- 支付宝app支付
- 微信提现+退款
- 微信app支付
- 微信支付公式
- 类库
- 图片类
- phpqrcode实战:生成二维码
- 图片处理类
- 验证码类
- 消息类
- PHPMailer
- 分词类
- ik
- PHPAnalysis
- 自己封装的方法
- GD库
- 自动获取图片主题颜色
- 图片转素描
- 生成海报
- 图片转字符
- 验证码
- 图片转黑白灰
- GD库实现图片水印与缩略图
- Imagick扩展
- 将一张image图片转化为字符串的形式
- 基本方法
- 图片路径转base64
- 生成文件后缀图片
- url路径判断拼接
- 防篡改入口文件
- php中文姓名判断
- 可控抽奖
- 特殊截取
- 银行卡位(特殊卡号不支持)
- 微信红包计算
- 数组和对象互转
- php批量更新修改数据库
- base64_img上传
- 删库删目录————跑路
- 字符串特殊符号过滤
- 首字母转成默认头像
- 生成随机字符串
- 根据id转 邀请码
- 日志写入
- 字符串截取,超出显示省略号
- 清除html标签+清除html标签,字符串截取
- 计算时间差的函数和演示
- php判断路径是否是绝对路径,如果不是拼接至绝对路径
- sql 参数过滤
- php敏感词过滤
- 省市区分别截取
- 生成csv
- 无限极分类
- api接口返回封装的方法函数
- xml和数组互转
- 获取thinkph5下控制器和方法名
- 过滤
- 获取服务器信息
- php随机颜色
- 创建多级目录
- 推广码
- 跨域检测
- 二维码
- 文档类
- word
- PHPWord
- tcPdf
- MPDF
- dompdf
- FPDF、Fpdi类库
- excel
- PhpSpreadsheet导入
- phpExcel
- 时间
- PHP-农历+节气+节日等类库
- 时间类库
- 最好用的是人性化时间差
- 文件管理类
- 文件操作类
- 文件夹操作
- php操作ftp的类库
- curl
- 数据库操作类
- Db扩展函数
- 数据库备份
- 仿tp5的Db库
- 不常用mysql
- 自动生成数据库字典
- 字符串
- 字符串操作helper/Str
- 随机生成姓名
- 随机生成类
- php字符串类
- 中文转拼音的类库
- 分类
- 缓存
- 数据验证
- 身份证相关操作
- 安全类
- 表单生成类
- 自动生成表单,未完待续中