慢慢的你會發現除了獲取參數的地方不一樣,登錄流程都差不多,可能是接口路徑啥的不太一致
但是獲取用戶信息,**出奇的一至**:`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登錄

前端調取授權
后端根據前端的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, 移動應用都是一致的
);
```
## 小程序

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();
}
```
**去權限設置,授權登錄,設置域名**



來我們解釋代碼了
**微信公眾號第一步:獲取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字符串類
- 中文轉拼音的類庫
- 分類
- 緩存
- 數據驗證
- 身份證相關操作
- 安全類
- 表單生成類
- 自動生成表單,未完待續中