第三方類庫指除了 ThinkPHP 框架、應用項目類庫以外的其餘類庫,通常由第三方系統或產品提供,如 Smarty、Zend 等系統的類庫等。php
前面使用自動加載或 import 方法導入的類庫,ThinkPHP 約定是以 .class.php 爲後綴的,非這類的後綴,須要經過 import 的參數來控制。html
但對第三類庫,因爲不會有此約定,其後綴只能認爲是 php 。爲了方便的引入其餘框架和系統的類庫,ThinkPHP 特地提供了導入第三方類庫的功能。第三方類庫統一放置在 ThinkPHP系統目錄/Vendor 下面,而且使用 vendor 方法導入。數組
語法:服務器
boolen vendor(class, baseUrl, ext)
參數說明:框架
參數 說明 class 必須,表示要導入的類庫,採用命名空間的方式。 baseUrl 可選,表示導入的基礎路徑,省略的話系統採用 ThinkPHP系統目錄/Vendor 目錄。 ext 可選,表示導入的類庫後綴,默認是 .php 。
與 import 方法的區別在於,vendor 方法默認的導入路徑爲 ThinkPHP系統目錄/Vendor 目錄,默認後綴爲 .php 。異步
當咱們想在ThinkPHP中引入第三方擴展,而第三方擴展又沒有按照ThinkPHP的規範在編寫的時候時,就須要將第三方擴展放置到Library/Vendor目錄下,固然,這是針對ThinkPHP 3.2而言,低版本則根據狀況來看了。函數
而後須要在Controller或function中使用第三方擴展時,就能夠直接使用vendor()方法來進行引用了。測試
第三方類庫目錄結構:網站
第一種方法:ui
Vendor('Phpqrcode.phpqrcode');
/** * 生成二維碼 * @param string $url url鏈接 * @param integer $size 尺寸 純數字 */ function qrcode($url,$size=4){ Vendor('Phpqrcode.phpqrcode'); if (strpos($url, 'http')===false) { $url='http://'.$url; } QRcode::png($url,false,QR_ECLEVEL_L,$size,2,false,0xFFFFFF,0x000000); }
require './ThinkPHP/Library/Org/Nx/class.phpmailer.php'; require './ThinkPHP/Library/Org/Nx/class.smtp.php';
/** * 發送郵件 * @param string $address 須要發送的郵箱地址 發送給多個地址須要寫成數組形式 * @param string $subject 標題 * @param string $content 內容 * @return boolean 是否成功 */ function send_email($address,$subject,$content){ $email_smtp=C('EMAIL_SMTP'); $email_username=C('EMAIL_USERNAME'); $email_password=C('EMAIL_PASSWORD'); $email_from_name=C('EMAIL_FROM_NAME'); if(empty($email_smtp) || empty($email_username) || empty($email_password) || empty($email_from_name)){ return array("error"=>1,"message"=>'郵箱配置不完整'); } require './ThinkPHP/Library/Org/Nx/class.phpmailer.php'; require './ThinkPHP/Library/Org/Nx/class.smtp.php'; $phpmailer=new \Phpmailer(); // 設置PHPMailer使用SMTP服務器發送Email $phpmailer->IsSMTP(); // 設置爲html格式 $phpmailer->IsHTML(true); // 設置郵件的字符編碼' $phpmailer->CharSet='UTF-8'; // 設置SMTP服務器。 $phpmailer->Host=$email_smtp; // 設置爲"須要驗證" $phpmailer->SMTPAuth=true; // 設置用戶名 $phpmailer->Username=$email_username; // 設置密碼 $phpmailer->Password=$email_password; // 設置郵件頭的From字段。 $phpmailer->From=$email_username; // 設置發件人名字 $phpmailer->FromName=$email_from_name; // 添加收件人地址,能夠屢次使用來添加多個收件人 if(is_array($address)){ foreach($address as $addressv){ $phpmailer->AddAddress($addressv); } }else{ $phpmailer->AddAddress($address); } // 設置郵件標題 $phpmailer->Subject=$subject; // 設置郵件正文 $phpmailer->Body=$content; // 發送郵件。 if(!$phpmailer->Send()) { $phpmailererror=$phpmailer->ErrorInfo; return array("error"=>1,"message"=>$phpmailererror); }else{ return array("error"=>0); } }
第三種方法:
支付寶類庫目錄結構
vendor('Alipay.AlipaySubmit','','.class.php');
注意說明:Vendor加載的默認後綴是.php的
參數一:必須,表示要導入的類庫,採用命名空間的方式
參數二:可選,表示導入的基礎路徑,省略的話系統採用 ThinkPHP系統目錄/Vendor 目錄。
參數三:可選,表示導入的類庫後綴,默認是 .php 。
支付寶第三方案例代碼:
/** * 跳向支付寶付款 * @param array $order 訂單數據 必須包含 out_trade_no(訂單號)、price(訂單金額)、subject(商品名稱標題) */ function alipay($order){ vendor('Alipay.AlipaySubmit','','.class.php'); // 獲取配置 $config=C('ALIPAY_CONFIG'); $data=array( "_input_charset" => $config['input_charset'], // 編碼格式 "logistics_fee" => "0.00", // 物流費用 "logistics_payment" => "SELLER_PAY", // 物流支付方式SELLER_PAY(賣家承擔運費)、BUYER_PAY(買家承擔運費) "logistics_type" => "EXPRESS", // 物流類型EXPRESS(快遞)、POST(平郵)、EMS(EMS) "notify_url" => $config['notify_url'], // 異步接收支付狀態通知的連接 "out_trade_no" => $order['out_trade_no'], // 訂單號 "partner" => $config['partner'], // partner 從支付寶商戶版我的中心獲取 "payment_type" => "1", // 支付類型對應請求時的 payment_type 參數,原樣返回。固定設置爲1便可 "price" => $order['price'], // 訂單價格單位爲元 // "price" => 0.01, // // 調價用於測試 "quantity" => "1", // price、quantity 能代替 total_fee。 即存在 total_fee,就不能存在 price 和 quantity;存在 price、quantity, 就不能存在 total_fee。 (沒繞明白;好吧;那無視這個參數便可) "receive_address" => '1', // 收貨人地址 即時到帳方式無視此參數便可 "receive_mobile" => '1', // 收貨人手機號碼 即時到帳方式無視便可 "receive_name" => '1', // 收貨人姓名 即時到帳方式無視便可 "receive_zip" => '1', // 收貨人郵編 即時到帳方式無視便可 "return_url" => $config['return_url'], // 頁面跳轉 同步通知 頁面路徑 支付寶處理完請求後,當前頁面自 動跳轉到商戶網站裏指定頁面的 http 路徑。 "seller_email" => $config['seller_email'], // email 從支付寶商戶版我的中心獲取 "service" => "create_direct_pay_by_user", // 接口名稱 固定設置爲create_direct_pay_by_user "show_url" => $config['show_url'], // 商品展現網址,收銀臺頁面上,商品展現的超連接。 "subject" => $order['subject'] // 商品名稱商品的標題/交易標題/訂單標 題/訂單關鍵字等 ); $alipay=new \AlipaySubmit($config); $new=$alipay->buildRequestPara($data); $go_pay=$alipay->buildRequestForm($new, 'get','支付'); echo $go_pay; }
不過當我將PHPMailer放在Vendor目錄下後,在本機運行得好好得,最近將程序上傳到服務器上時,直接提示Class ‘PHPMailer’ not found而後又在本機運行,仍是正確!經過前面這片博客能夠知道,我是經過vendor(
'PHPMailer.class#PHPMailer'
);
這行代碼將PHPMailer引入的。既然提示找不到PHPMailer類,說明沒有被正確引入。這是爲何呢?
就粗略看了一下vendor()方法的源碼,這才發現其實vendor()方法也就是對import()方法進行了一次參數組裝,而後仍是交給了import()方法處理。查看import()方法的源碼又發現,在import()方法中,對於上面傳入參數的解析其實就是將’.’替換成’/’,將’#’替換成了’.’,baseurl則由vendor()方法自動補充上了,指向Vendor目錄。因此上面vendor()方法中的參數最終仍是被解析成了以下目錄:
Library/Vendor/PHPMailer/class.PHPMailer.php
而PHPMailer的入口文件的實際目錄地址爲:
Library/Vendor/phpmailer/class.phpmailer.php
內容都同樣的嘛!不過我用的是Linux的服務器,因此對大小寫是嚴格區分的,這樣固然不能成功導入這個類。而解決辦法就是將vendor()引入改成:
vendor(‘phpmailer.class#phpmailer’)
另外對於PHPMailer使用時還要注意一點,PHPMailer若是使用SMTP方式發送郵件,須要PHP對fsockopen的支持,因此咱們須要修改php.ini中disable_functions中將fscokopen刪除,不然會出現運行錯誤:
fsockopen() has been disabled
經過PHPMailer的ErrorInfo屬性能夠獲取到!