Analisis dan ringkasan 5 petua Pelanggan HTTP Laravel
Artikel ini membawakan anda pengetahuan yang berkaitan tentang Laravel. Ia terutamanya berkongsi dengan anda 5 petua Pelanggan HTTP Laravel yang berminat boleh lihat di bawah.
Sebagai web
pembangun, kami selalunya perlu berinteraksi dengan Laravel
daripada api
aplikasi. Laravel HTTP
pembalut perpustakaan yang mudah dan intuitif disediakan dalam 7
versi klienGuzzle HTTP
. Dalam artikel ini, kami akan meneroka lima petua berharga untuk menggunakan Laravel HTTP Client
yang boleh menjadikan pengalaman pembangunan anda lebih cekap dan menyeronokkan.
Petua ini termasuk menggunakan HTTP
makro, mengkonfigurasi HTTP
klien untuk perkhidmatan kontena, konfigurasi asas mudah alih URL
, mencegah permintaan palsu dalam ujian dan mendengar acara HTTP
. Dengan menguasai teknik ini, anda boleh memudahkan API
interaksi dan mencipta aplikasi Laravel
yang lebih mantap dan boleh diselenggara.
Makro HTTP
Banyak perkhidmatan Laravel mempunyai ciri 宏
yang membolehkan anda menentukan kaedah tersuai untuk aplikasi anda. Anda boleh menambahkan makro ini pada kaedah boot()
pembekal perkhidmatan dan bukannya melanjutkan kelas teras daripada rangka kerja Laravel.
Dokumentasi HTTP menunjukkan contoh makro yang anda boleh gunakan untuk mentakrifkan tetapan biasa:
public function boot(): void { Http::macro('github', function () { return Http::withHeaders([ 'X-Example' => 'example', ])->baseUrl('https://github.com'); }); } // Usage response = Http::github()->get('/');
Makro boleh mentakrifkan apa sahaja yang anda mahukan dalam aplikasi anda Kaedah mudah ditakrifkan dan digunakan semula dalam . Contoh makro dalam dokumentasi melibatkan petua lain untuk mengkonfigurasi klien HTTP untuk digunakan dengan perkhidmatan lain.
Dalam bahagian seterusnya kami akan menyemak semula kaedah menggabungkan makro dengan menghantar pelanggan kepada perkhidmatan kontena lain.
Mengkonfigurasi klien HTTP untuk perkhidmatan kontena
Apabila berinteraksi dengan API dalam aplikasi Laravel anda, anda mungkin mahu mengkonfigurasi pelbagai tetapan boleh dikonfigurasikan untuk klien. Contohnya, jika API anda mempunyai berbilang persekitaran, anda perlu mengkonfigurasi URL asas, token, tetapan tamat masa, dsb.
Kami boleh menggunakan makro untuk mentakrifkan pelanggan, mewakili pelanggan sebagai perkhidmatannya sendiri dan kemudian menyuntiknya ke dalam perkhidmatan lain atau kedua-duanya.
Mula-mula, mari lihat cara mentakrifkan tetapan klien dalam kaedah register()
pembekal perkhidmatan:
public function register(): void { $this->app->singleton(ExampleService::class, function (Application $app) { $client = Http::withOptions([ 'base_uri' => config('services.example.base_url'), 'timeout' => config('services.example.timeout', 10), 'connect_timeout' => config('services.example.connect_timeout', 2), ])->withToken(config('services.example.token')); return new ExampleService($client); }); }
Dalam definisi perkhidmatan tunggal, kami merangkai beberapa Dipanggil untuk mengkonfigurasi klien. Hasilnya ialah contoh PendingRequest
yang boleh kami hantar kepada pembina perkhidmatan kami seperti ini:
class ExampleService { public function __construct( private PendingRequest $client ) {} public function getWidget(string $uid) { $response = $this->client ->withUrlParameters(['uid' => $uid]) ->get('widget/{uid}'); return new Widget($response->json()); } }
Perkhidmatan menggunakan kaedah withOptions()
untuk mengkonfigurasi pilihan Guzzle secara langsung, tetapi kami juga boleh menggunakan Beberapa kaedah kemudahan disediakan oleh pelanggan HTTP:
$this->app->singleton(ExampleService::class, function (Application $app) { $client = Http::baseUrl(config('services.example.base_url')) ->timeout(config('services.example.timeout', 10)) ->connectTimeout(config('services.example.connect_timeout', 2)) ->withToken(config('services.example.token')); return new ExampleService($client); });
Sebagai alternatif, jika anda ingin menggabungkan makro dengan perkhidmatan anda, anda boleh menggunakan makro yang anda tentukan dalam kaedah AppServiceProvider
boot()
anda:
$this->app->singleton(ExampleService::class, function (Application $app) { return new ExampleService(Http::github()); });
Konfigurasi URL Pangkalan Mudah Alih
Anda mungkin telah melihat bahawa URL asas lalai mengandungi /
pengekoran, yang memberikan kemudahalihan maksimum. Ambil konfigurasi perkhidmatan berikut sebagai contoh (perhatikan base_url lalai):
return [ 'example' => [ 'base_url' => env('EXAMPLE_BASE_URI', 'https://api.example.com/v1/'), 'token' => env('EXAMPLE_SERVICE_TOKEN'), 'timeout' => env('EXAMPLE_SERVICE_TIMEOUT', 10), 'connect_timeout' => env('EXAMPLE_SERVICE_TIMEOUT', 2), ], ];
; Menggunakan garis miring mengekor menjadikan URL berfungsi seperti yang diharapkan tanpa mengubah kod. Semasa mengkonfigurasi jejak /v1/
, sila ambil perhatian bahawa semua panggilan API dalam kod saya menggunakan laluan relatif: https://stg-api.example.com/
/
$this->client ->withUrlParameters(['uid' => $uid]) // 例子: // 测试环境 - https://stg-api.example.com/widget/123 // 生产环境 - https://api.example.com/v1/widget/123 ->get('widget/{uid}');
Guzzle untuk mengetahui lebih lanjut Bagaimana gaya base_uri yang berbeza mempengaruhi Penghuraian URI. Halang permintaan sesat dalam ujian
Klien HTTP Laravel menyediakan alat ujian yang sangat baik yang menjadikan ujian penulisan mudah. Apabila saya menulis kod yang berinteraksi dengan API, saya berasa tidak senang bahawa dalam beberapa cara ujian saya mempunyai permintaan rangkaian sebenar berlaku. Masukkan
untuk mengelakkan permintaan sesat Pada pendapat saya, cara terbaik untuk menggunakanHttp::preventStrayRequests(); Http::fake([ 'github.com/*' => Http::response('ok'), ]); // Run test code // If any other code triggers an HTTP call via Laravel's client // an exception is thrown.
dalam . Mungkin anda juga boleh menambahkan ini pada kelas preventStrayRequests()
asas apl anda. setUp()
TestCase
namespace Tests; use Illuminate\Foundation\Testing\TestCase as BaseTestCase; use Illuminate\Support\Facades\Http; abstract class TestCase extends BaseTestCase { use CreatesApplication; public function setUp(): void { parent::setUp(); Http::preventStrayRequests(); } }
Pengendali log untuk acara HTTP
Pelanggan HTTP Laravel mempunyai banyak peristiwa berharga yang boleh anda gunakan untuk menyelidiki peringkat penting dalam kitaran hayat permintaan/tindak balas. Semasa artikel ini ditulis, tiga peristiwa telah dicetuskan:
Illuminate\HttpClient\Events\RequestSending
IlluminateHttpClient\Events\ResponseReceived
IlluminateHttpClient\EventsConnectionFailed
比方说,你想把你的应用程序发出请求的每个 URL 都可视化。我们可以很容易地接入 RequestSending
事件,并记录出每个请求。
namespoace App/Listeners; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Support\Facades\Log; class LogRequestSending { public function handle(object $event): void { Log::debug('HTTP请求正在发送。', ['url' => $event->request->url() 'url' => $event->request->url(), ]); } }
为了使事件处理程序工作,在 EventServiceProvider
类中添加以下内容。
use App\Listeners\LogRequestSending; use Illuminate\Http\Client\Events\RequestSending; // ... protected $listen = [ Registered::class => [ SendEmailVerificationNotification::class, ], RequestSending::class => [ LogRequestSending::class, ], ];
一旦它被连接起来,你就会在你的日志中看到类似于 HTTP 客户端尝试的每个请求的内容。
[2023-03-17 04:06:03] local.DEBUG: HTTP请求正在被发送。{"url": "https://api.example.com/v1/widget/123"}
了解更多
官方的Laravel HTTP 文档有你需要的一切,可以开始了。我希望这个教程能给你一些灵感和技巧,你可以在你的 Laravel 应用程序中使用。
原文地址:https://laravel-news.com/laravel-http-cl...
译文地址:https://www.php.cn/link/bac346f4c260a59fde0b1546e8a025aa
Atas ialah kandungan terperinci Analisis dan ringkasan 5 petua Pelanggan HTTP Laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Operasi pangkalan data dalam PHP dipermudahkan menggunakan ORM, yang memetakan objek ke dalam pangkalan data hubungan. EloquentORM dalam Laravel membolehkan anda berinteraksi dengan pangkalan data menggunakan sintaks berorientasikan objek Anda boleh menggunakan ORM dengan mentakrifkan kelas model, menggunakan kaedah Eloquent atau membina sistem blog dalam amalan.

Versi terkini Laravel 9 dan CodeIgniter 4 menyediakan ciri dan penambahbaikan yang dikemas kini. Laravel9 menggunakan seni bina MVC dan menyediakan fungsi seperti migrasi pangkalan data, pengesahan dan enjin templat. CodeIgniter4 menggunakan seni bina HMVC untuk menyediakan penghalaan, ORM dan caching. Dari segi prestasi, corak reka bentuk berasaskan pembekal perkhidmatan Laravel9 dan rangka kerja ringan CodeIgniter4 memberikannya prestasi cemerlang. Dalam aplikasi praktikal, Laravel9 sesuai untuk projek kompleks yang memerlukan fleksibiliti dan fungsi berkuasa, manakala CodeIgniter4 sesuai untuk pembangunan pesat dan aplikasi kecil.

Bandingkan keupayaan pemprosesan data Laravel dan CodeIgniter: ORM: Laravel menggunakan EloquentORM, yang menyediakan pemetaan hubungan kelas-objek, manakala CodeIgniter menggunakan ActiveRecord untuk mewakili model pangkalan data sebagai subkelas kelas PHP. Pembina pertanyaan: Laravel mempunyai API pertanyaan berantai yang fleksibel, manakala pembina pertanyaan CodeIgniter lebih ringkas dan berasaskan tatasusunan. Pengesahan data: Laravel menyediakan kelas Pengesah yang menyokong peraturan pengesahan tersuai, manakala CodeIgniter mempunyai kurang fungsi pengesahan terbina dalam dan memerlukan pengekodan manual peraturan tersuai. Kes praktikal: Contoh pendaftaran pengguna menunjukkan Lar

Laravel - Perintah Artisan - Laravel 5.7 hadir dengan cara baharu untuk merawat dan menguji arahan baharu. Ia termasuk ciri baharu untuk menguji arahan artisan dan demonstrasi disebut di bawah?

Untuk pemula, CodeIgniter mempunyai keluk pembelajaran yang lebih lembut dan ciri yang lebih sedikit, tetapi meliputi keperluan asas. Laravel menawarkan set ciri yang lebih luas tetapi mempunyai keluk pembelajaran yang lebih curam. Dari segi prestasi, kedua-dua Laravel dan CodeIgniter berprestasi baik. Laravel mempunyai dokumentasi yang lebih luas dan sokongan komuniti yang aktif, manakala CodeIgniter lebih ringkas, ringan dan mempunyai ciri keselamatan yang kukuh. Dalam kes praktikal membina aplikasi blog, EloquentORM Laravel memudahkan manipulasi data, manakala CodeIgniter memerlukan lebih banyak konfigurasi manual.

Apabila memilih rangka kerja untuk projek besar, Laravel dan CodeIgniter masing-masing mempunyai kelebihan mereka sendiri. Laravel direka untuk aplikasi peringkat perusahaan, menawarkan reka bentuk modular, suntikan pergantungan dan set ciri yang berkuasa. CodeIgniter ialah rangka kerja ringan yang lebih sesuai untuk projek kecil hingga sederhana, menekankan kelajuan dan kemudahan penggunaan. Untuk projek besar dengan keperluan yang kompleks dan bilangan pengguna yang ramai, kuasa dan kebolehskalaan Laravel adalah lebih sesuai. Untuk projek atau situasi mudah dengan sumber terhad, keupayaan pembangunan CodeIgniter yang ringan dan pantas adalah lebih ideal.

Seni bina perkhidmatan mikro menggunakan rangka kerja PHP (seperti Symfony dan Laravel) untuk melaksanakan perkhidmatan mikro dan mengikut prinsip RESTful dan format data standard untuk mereka bentuk API. Perkhidmatan mikro berkomunikasi melalui baris gilir mesej, permintaan HTTP atau gRPC dan menggunakan alatan seperti Prometheus dan ELKStack untuk pemantauan dan penyelesaian masalah.

Untuk projek kecil, Laravel sesuai untuk projek yang lebih besar yang memerlukan fungsi dan keselamatan yang kukuh. CodeIgniter sesuai untuk projek yang sangat kecil yang memerlukan ringan dan mudah digunakan.
