Heim >PHP-Framework >Denken Sie an PHP >So importieren Sie Bibliotheken von Drittanbietern in ThinkPHP
Bibliothek von Drittanbietern
Klassenbibliotheken von Drittanbietern beziehen sich auf andere Klassenbibliotheken neben dem ThinkPHP-Framework und den Anwendungsprojektklassenbibliotheken. Sie werden im Allgemeinen von Systemen oder Produkten von Drittanbietern bereitgestellt, z. B. Klassenbibliotheken von Smarty, Zend und anderen Systemen.
Für die Klassenbibliotheken, die zuvor mithilfe des automatischen Ladens oder der Importmethode importiert wurden, besteht die ThinkPHP-Konvention darin, .class.php als Suffix zu verwenden, das über die Importparameter gesteuert werden muss.
Da es jedoch keine solche Vereinbarung für die Bibliothek der dritten Kategorie gibt, kann ihr Suffix nur als PHP betrachtet werden. Um Klassenbibliotheken aus anderen Frameworks und Systemen einfach einzuführen, bietet ThinkPHP speziell die Funktion zum Importieren von Klassenbibliotheken von Drittanbietern. Klassenbibliotheken von Drittanbietern werden einheitlich im ThinkPHP-Systemverzeichnis/Vendor abgelegt und mit der Vendor-Methode importiert.
Anbietermethode
Grammatik:
boolenvendor(class,baseUrl,ext)
Parameterbeschreibung:
Parameterbeschreibung
Die Klasse ist erforderlich und gibt die Klassenbibliothek an, die mithilfe der Namespace-Methode importiert werden soll.
baseUrl ist optional und gibt den Basispfad des Imports an. Wenn es weggelassen wird, verwendet das System das ThinkPHP-Systemverzeichnis/Vendor-Verzeichnis.
ext ist optional und gibt das Suffix der importierten Klassenbibliothek an. Der Standardwert ist .php.
Der Unterschied zur Importmethode besteht darin, dass der Standardimportpfad der Vendor-Methode das ThinkPHP-Systemverzeichnis/Vendor-Verzeichnis ist und das Standardsuffix .php ist.
Persönlicher Erfahrungsaustausch:
Wenn wir eine Drittanbieter-Erweiterung in ThinkPHP einführen möchten und die Drittanbieter-Erweiterung nicht gemäß den ThinkPHP-Spezifikationen geschrieben ist, müssen wir die Drittanbieter-Erweiterung im Verzeichnis „Library/Vendor“ ablegen. Dies gilt natürlich für ThinkPHP3 .2 Mit anderen Worten, die niedrigere Version hängt von der Situation ab.
Wenn Sie dann eine Erweiterung eines Drittanbieters in einem Controller oder einer Funktion verwenden müssen, können Sie direkt die Methode seller() verwenden, um darauf zu verweisen.
Verzeichnisstruktur der Bibliothek von Drittanbietern:
Wird in der Funktionsfunktion verwendet:
Die erste Methode:
Anbieter('Phpqrcode.phpqrcode');
Code kopieren
Code kopieren
/**
*QR-Code generieren
*@paramstring$urlurl-Verbindung
*@paraminteger$size Größe ist eine reine Zahl
*/
functionqrcode($url,$size=4){
Anbieter('Phpqrcode.phpqrcode');
if(strpos($url,'http')===false){
$url='http://'.$url;
}
QRcode::png($url,false,QR_ECLEVEL_L,$size,2,false,0xFFFFFF,0x000000);
}
Code kopieren
Code kopieren
Die zweite Methode:
require'./ThinkPHP/Library/Org/Nx/class.phpmailer.php';
require'./ThinkPHP/Library/Org/Nx/class.smtp.php';
Code kopieren
Code kopieren
/**
*E-Mail senden
*@paramstring$address Die E-Mail-Adresse, die an mehrere Adressen gesendet werden soll, muss in Array-Form geschrieben werden
*@paramstring$Betrefftitel
*@paramstring$content content
*@returnboolean war erfolgreich
*/
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"=>'Die Postfachkonfiguration ist unvollständig');
}
require'./ThinkPHP/Library/Org/Nx/class.phpmailer.php';
require'./ThinkPHP/Library/Org/Nx/class.smtp.php';
$phpmailer=newPhpmailer();
// Richten Sie PHPMailer so ein, dass der SMTP-Server zum Senden von E-Mails verwendet wird
$phpmailer->IsSMTP();
//Auf HTML-Format einstellen
$phpmailer->IsHTML(true);
//Stellen Sie die Zeichenkodierung der E-Mail ein'
$phpmailer->CharSet='UTF-8';
//SMTP-Server einrichten.
$phpmailer->Host=$email_smtp;
//Auf „Verifizierung erforderlich“ setzen
$phpmailer->SMTPAuth=true;
//Benutzernamen festlegen
$phpmailer->Username=$email_username;
//Passwort festlegen
$phpmailer->Password=$email_password;
//Legen Sie das Feld „Von“ des E-Mail-Headers fest.
$phpmailer->From=$email_username;
//Legen Sie den Namen des Absenders fest
$phpmailer->FromName=$email_from_name;
//Fügen Sie die Empfängeradresse hinzu, die mehrmals verwendet werden kann, um mehrere Empfänger hinzuzufügen
if(is_array($address)){
foreach($addressas$addressv){
$phpmailer->AddAddress($addressv);
}
}sonst{
$phpmailer->AddAddress($address);
}
//E-Mail-Titel festlegen
$phpmailer->Subject=$subject;
//Legen Sie den E-Mail-Text fest
$phpmailer->Body=$content;
//E-Mail senden.
if(!$phpmailer->Send()){
$phpmailererror=$phpmailer->ErrorInfo;
returnarray("error"=>1,"message"=>$phpmailererror);
}sonst{
returnarray("error"=>0);
}
}
Code kopieren
Code kopieren
Die dritte Methode:
Verzeichnisstruktur der Alipay-Bibliothek
Vendor('Alipay.AlipaySubmit','','.class.php');
Hinweis: Das vom Anbieter geladene Standardsuffix ist .php
Parameter 1: Erforderlich, gibt die Klassenbibliothek an, die mithilfe der Namespace-Methode
importiert werden soll Parameter 2: Optional, gibt den grundlegenden Importpfad an. Wenn er weggelassen wird, verwendet das System das ThinkPHP-Systemverzeichnis/Vendor-Verzeichnis.
Parameter drei: Optional, gibt das Suffix der importierten Klassenbibliothek an, der Standardwert ist .php.
Alipay-Drittanbieter-Fallcode:
Code kopieren
Code kopieren
/**
* Springen Sie zu Alipay, um
zu bezahlen *@paramarray$order Die Bestelldaten müssen out_trade_no (Bestellnummer), Preis (Bestellmenge) und Betreff (Produktname) enthalten.
*/
functionipay($order){
Vendor('Alipay.AlipaySubmit','','.class.php');
//Konfiguration abrufen
$config=C('ALIPAY_CONFIG');
$data=array(
"_input_charset"=>$config['input_charset'],//Kodierungsformat
"logistics_fee"=>"0.00",//Logistikgebühr
"logistics_zahlung"=>"SELLER_PAY",//Logistik-Zahlungsmethode SELLER_PAY (Verkäufer trägt Fracht), BUYER_PAY (Käufer trägt Fracht)
"logistics_type"=>"EXPRESS",//Logistiktyp EXPRESS (Express), POST (Landpost), EMS (EMS)
"notify_url"=>$config['notify_url'],//Link zum asynchronen Empfang der Zahlungsstatusbenachrichtigung
"out_trade_no"=>$order['out_trade_no'],//Bestellnummer
"partner"=>$config['partner'],//Partner wird vom Alipay Merchant Version Personal Center erhalten
"zahlung_typ"=>"1",//Der Zahlungstyp entspricht dem Parameter payment_type in der Anfrage und wird unverändert zurückgegeben. Setzen Sie es einfach auf 1
"price"=>$order['price'],//Die Bestellpreiseinheit ist Yuan
//"price"=>0.01,////Preisanpassung wird zum Testen verwendet
„quantity“=>“1“,//Preis und Menge können total_fee ersetzen. Das heißt, wenn „total_fee“ vorhanden ist, können Preis und Menge nicht existieren; wenn „price“ und „quantity“ vorhanden sind, kann „total_fee“ nicht existieren. (Ich habe es nicht verstanden; okay; ignoriere einfach diesen Parameter)
"receive_address"=>'1',//Die Empfängeradresse wird sofort gutgeschrieben, ignorieren Sie einfach diesen Parameter
"receive_mobile"=>'1',//Ignorieren Sie einfach die Methode der sofortigen Zahlung der Mobiltelefonnummer des Empfängers
"receive_name"=>'1',//Ignorieren Sie einfach die Methode der sofortigen Zahlung des Namens des Empfängers
"receive_zip"=>'1',//Sie können die Sofortankunftsmethode der Postleitzahl des Empfängers ignorieren
"return_url"=>$config['return_url'], //Seitenpfad für die Benachrichtigung über die Synchronisierung von Seitensprüngen Nachdem Alipay die Anfrage verarbeitet hat, springt die aktuelle Seite automatisch zum http-Pfad der angegebenen Seite auf der Händler-Website.
"seller_email"=>$config['seller_email'], //E-Mail wird vom persönlichen Center der Alipay Merchant Edition abgerufen
"service"=>"create_direct_pay_by_user", //Der Schnittstellenname ist auf create_direct_pay_by_user
festgelegt "show_url"=>$config['show_url'], //Produktanzeige-URL, Hyperlink für die Produktanzeige auf der Checkout-Seite.
"subject"=>$order['subject']//Produktname Produkttitel/Transaktionstitel/Bestelltitel/Bestellschlüsselwort usw.
);
$alipay=newAlipaySubmit($config);
$new=$alipay->buildRequestPara($data);
$go_pay=$alipay->buildRequestForm($new,'get','pay');
echo$go_pay;
}
Code kopieren
Code kopieren
Als ich PHPMailer jedoch im Vendor-Verzeichnis ablegte, lief es auf diesem Computer einwandfrei. Als ich das Programm kürzlich auf den Server hochgeladen habe, wurde mir direkt angezeigt, dass die Klasse „PHPMailer“ nicht gefunden wurde, und es dann erneut auf diesem Computer ausgeführt immer noch richtig! Wie Sie aus dem vorherigen Blog wissen können, verwende ich Vendor('PHPMailer.class#PHPMailer');
Diese Codezeile stellt PHPMailer vor. Da die Eingabeaufforderung die PHPMailer-Klasse nicht finden kann, bedeutet dies, dass sie nicht korrekt eingeführt wurde. Warum ist das so?
Ich habe einen flüchtigen Blick auf den Quellcode der Vendor()-Methode geworfen und herausgefunden, dass die Vendor()-Methode tatsächlich die Parameter der Import()-Methode zusammenstellt und sie dann der Import()-Methode zur Verarbeitung überlässt. Beim Betrachten des Quellcodes der Methode import() haben wir festgestellt, dass die Analyse der oben genannten eingehenden Parameter tatsächlich darin besteht, „.“ durch „/“ und „#“ zu ersetzen ; mit ;.’, baseurl wird automatisch von der Vendor()-Methode hinzugefügt und verweist auf das Vendor-Verzeichnis. Daher werden die Parameter in der obigen Vendor()-Methode schließlich in das folgende Verzeichnis geparst:
Library/Vendor/PHPMailer/class.PHPMailer.php
Die tatsächliche Verzeichnisadresse der Eintragsdatei von PHPMailer lautet:
Library/Vendor/phpmailer/class.phpmailer.php
Der Inhalt ist derselbe! Da ich jedoch einen Linux-Server verwende, wird der Fall streng unterschieden, sodass ich diese Klasse natürlich nicht erfolgreich importieren kann. Die Lösung besteht darin, seller() einzuführen und zu ändern:
Vendor(‘phpmailer.class#phpmailer’)
Darüber hinaus sollten Sie bei der Verwendung von PHPMailer auf eines achten. Wenn PHPMailer SMTP zum Senden von E-Mails verwendet, muss PHP fsockopen unterstützen. Daher müssen wir die Disable_Functions in php.ini ändern, um fscokopen zu löschen. Andernfalls tritt ein Lauffehler auf:
fsockopen()wurdedeaktiviert
Es kann über das ErrorInfo-Attribut von PHPMailer abgerufen werden!
Das obige ist der detaillierte Inhalt vonSo importieren Sie Bibliotheken von Drittanbietern in ThinkPHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!