日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

  第三方類庫

  第三方類庫指除了ThinkPHP框架、應用項目類庫之外的其他類庫,一般由第三方系統或產品提供,如Smarty、Zend等系統的類庫等。

  前面使用自動加載或import方法導入的類庫,ThinkPHP約定是以.class.php為后綴的,非這類的后綴,需要通過import的參數來控制。

  但對第三類庫,由于不會有此約定,其后綴只能認為是php。為了方便的引入其他框架和系統的類庫,ThinkPHP特意提供了導入第三方類庫的功能。第三方類庫統一放置在ThinkPHP系統目錄/Vendor下面,并且使用vendor方法導入。

  vendor方法

  語法:

  boolenvendor(class,baseUrl,ext)

  參數說明:

  參數說明

  class必須,表示要導入的類庫,采用命名空間的方式。

  baseUrl可選,表示導入的基礎路徑,省略的話系統采用ThinkPHP系統目錄/Vendor目錄。

  ext可選,表示導入的類庫后綴,默認是.php。

  與import方法的區別在于,vendor方法默認的導入路徑為ThinkPHP系統目錄/Vendor目錄,默認后綴為.php。

  個人經驗分享:

  當我們想在ThinkPHP中引入第三方擴展,而第三方擴展又沒有按照ThinkPHP的規范在編寫的時候時,就需要將第三方擴展放置到Library/Vendor目錄下,當然,這是針對ThinkPHP3.2而言,低版本則根據情況來看了。

  然后需要在Controller或function中使用第三方擴展時,就可以直接使用vendor()方法來進行引用了。

  第三方類庫目錄結構:

  在function函數中使用:

  第一種方法:

  Vendor(‘Phpqrcode.phpqrcode’);

  復制代碼

  復制代碼

  /**

  *生成二維碼

  *@paramstring$urlurl連接

  *@paraminteger$size尺寸純數字

  */

  functionqrcode($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’;

  復制代碼

  復制代碼

  /**

  *發送郵件

  *@paramstring$address需要發送的郵箱地址發送給多個地址需要寫成數組形式

  *@paramstring$subject標題

  *@paramstring$content內容

  *@returnboolean是否成功

  */

  functionsend_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)){

  returnarray(“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($addressas$addressv){

  $phpmailer->AddAddress($addressv);

  }

  }else{

  $phpmailer->AddAddress($address);

  }

  //設置郵件標題

  $phpmailer->Subject=$subject;

  //設置郵件正文

  $phpmailer->Body=$content;

  //發送郵件。

  if(!$phpmailer->Send()){

  $phpmailererror=$phpmailer->ErrorInfo;

  returnarray(“error”=>1,”message”=>$phpmailererror);

  }else{

  returnarray(“error”=>0);

  }

  }

  復制代碼

  復制代碼

  第三種方法:

  支付寶類庫目錄結構

  vendor(‘Alipay.AlipaySubmit’,”,’.class.php’);

  注意說明:Vendor加載的默認后綴是.php的

  參數一:必須,表示要導入的類庫,采用命名空間的方式

  參數二:可選,表示導入的基礎路徑,省略的話系統采用ThinkPHP系統目錄/Vendor目錄。

  參數三:可選,表示導入的類庫后綴,默認是.php。

  支付寶第三方案例代碼:

  復制代碼

  復制代碼

  /**

  *跳向支付寶付款

  *@paramarray$order訂單數據必須包含out_trade_no(訂單號)、price(訂單金額)、subject(商品名稱標題)

  */

  functionalipay($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’notfound然后又在本機運行,還是正確!通過前面這片博客可以知道,我是通過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()hasbeendisabled

  通過PHPMailer的ErrorInfo屬性可以獲取到!

以上就是ThinkPHP怎么導入第三方類庫的詳細內容,更多請關注www.xfxf.net其它相關文章!

分享到:
標簽:thinkphp
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定