Kuinka ladata kuvia toiselle palvelimelle FTP: n kautta Laravelissa
Haluatko ladata tiedostosi Laravel-sovelluksestasi toiselle palvelimelle FTP: n kautta? Laravelin mukana tulee sisäänrakennettu tuki tiedostojen lataamiseen ulkoiselle palvelimelle tai pilveen. Tässä oppaassa näytämme, kuinka tiedostoja (kuvia) lähetetään toiselle palvelimelle LTP-palvelun kautta Laravel-verkkosivustolla.
Kuvien isännöinti toisella palvelimella voi auttaa parantamaan sivustosi nopeutta. Tämä tekniikka on eräänlainen rinnakkainen yhteys verkkoselaimen ja palvelinten välillä. Se vähentää yhden palvelimen kuormitusta, sillä kuvaselain soittaa toiselle palvelimelle.
Laravel-tiedostojärjestelmä tarjoaa kätevän tavan hallita tiedostoja pilvessä tai ulkoisella palvelimella. Käyttäjä voi valita erilaisia Laravel-tallennuspalveluntarjoajia, kuten S3, Rackspace, FTP tai SFTP. Katsotaanpa Laravel-tiedostojen lataamista FTP-ohjaimella.
Lähetä tiedostoja toiselle palvelimelle FTP-ohjaimen kautta
Aloittamiseksi sinun on tiedettävä FTP-isännän, FTP-käyttäjänimen ja FTP-salasanan tiedot. Kun olet valmis, yksityiskohdat avaa .env
tiedostot ja lisää tiedot seuraavasti:
FTP_HOST=YOUR_FTP_HOST_VALUE
FTP_USERNAME=YOUR_FTP_USERNAME_VALUE
FTP_PASSWORD=YOUR_FTP_PASSWORD_VALUE
Muista korvata paikkamerkit todellisilla arvoilla. Seuraavaksi avaa config/filesystems.php
tiedosto ja lisää ftp-kokoonpano levyihin.
config / filesystems.php
<?php
return [
......
'disks' => [
......
'ftp' => [
'driver' => 'ftp',
'host' => env('FTP_HOST'),
'username' => env('FTP_USERNAME'),
'password' => env('FTP_PASSWORD'),
'root' => 'DIR_PATH_TO_WHERE_IMAGE_STORE' // for example: /var/www/html/dev/images
],
],
];
Korvaa DIR_PATH_TO_WHERE_IMAGE_STORE todellisella polulla, johon sinun on tallennettava kuvia. Esimerkiksi, jos meillä on kansio nimeltä ‘kuvat’ ja polku tähän kansioon on / var / www / html / dev / images, tämä polku tulee olemaan arvon ‘root’ edellisessä taulukossa.
Tiedostojen lataamiseen FTP: n kautta tarvitaan lomake, johon käyttäjä voi lähettää kuvan. Lisää alla oleva koodi näkymätiedostoon.
<form action="{{ url('PASS_ACTION_URL_HERE') }}" method="post" enctype="multipart/form-data">
<div class="form-group">
<label for="exampleInputFile">File input</label>
<input type="file" name="profile_image" id="exampleInputFile" multiple />
</div>
{{ csrf_field() }}
<button type="submit" class="btn btn-default">Submit</button>
</form>
Korvaa PASS_ACTION_URL_HERE todellisella reitilläsi. Koska tiedostojen lataamiseen käytetään Laravel-tallennustilaa, käyttäjän on lisättävä julkisivu ohjaintiedostoon seuraavasti:
use IlluminateSupportFacadesStorage;
Lopuksi ohjaimen toimintakoodi olisi seuraava:
public function store(Request $request)
{
if($request->hasFile('profile_image')) {
//get filename with extension
$filenamewithextension = $request->file('profile_image')->getClientOriginalName();
//get filename without extension
$filename = pathinfo($filenamewithextension, PATHINFO_FILENAME);
//get file extension
$extension = $request->file('profile_image')->getClientOriginalExtension();
//filename to store
$filenametostore = $filename.'_'.uniqid().'.'.$extension;
//Upload File to external server
Storage::disk('ftp')->put($filenametostore, fopen($request->file('profile_image'), 'r+'));
//Store $filenametostore in the database
}
return redirect('images')->with('status', "Image uploaded successfully.");
}
‘profile_image’ on tiedostotiedostomme nimi. Rakennamme tiedostomme yksilöllisen nimen ja lataamme sen sitten ulkoiselle palvelimelle. Huomaa, että olemme käyttäneet Storage :: disk (‘ftp’) -menetelmää. Tämä toiminto tallentaa tiedostomme polulle, joka on määritelty kokoonpanossa. Käyttäjän tulisi tallentaa arvo ‘$ filenametostore’ tietokantaan.
Hae tai poista kuva
Käsittelemme kuvia niin ilmeisesti, että meidän on näytettävä nämä kuvat verkkosivustolla. Kun tallennamme näitä kuvia tunnetulle ulkoiselle palvelimelle, käyttäjän tulisi tietää sen kansion HTTP-polku, johon tallennamme kuvat. Se voi olla jotain sellaista kuin YOUR_DOMAIN_URL / images /. Ohjainmenetelmässä meidän tulisi tallentaa kuvan nimi tietokantaan. Joten HTML img -tagimme on seuraava:
<img src="YOUR_DOMAIN_URL/images/FILE_NAME" />
Tässä FILE_NAME on kuvasi nimi, joka on tallennettu tietokantaan. Käyttäjä voi poistaa tiedoston seuraavalla tavalla:
Storage::disk('ftp')->delete('FILE_NAME');