Cách download & đọc file csv từ một FPT, SFTP server

Hôm nay mình xin chia sẻ kinh nghiệm cách download file csv từ 1 FPT, SFTP server về local của mình và đọc file csv đó,sau đó sẽ hiển thị ra dữ liệu. Hiện tại trên FPT, SFTP server mình đã uploaded sẵn 1 file csv có tên là SampleCSV.csv, bên dưới đây là các

Hôm nay mình xin chia sẻ kinh nghiệm cách download file csv từ 1 FPT, SFTP server về local của mình và đọc file csv đó,sau đó sẽ hiển thị ra dữ liệu.
Hiện tại trên FPT, SFTP server mình đã uploaded sẵn 1 file csv có tên là SampleCSV.csv,
bên dưới đây là các bước kết nối đến FPT,SFTP server, download về local, hiển thị dữ liệu.
1. Thực hiện kết nối đến FPT server

// 1. Kết nối và login to FTP server$ftp_server="Your host name";$ftp_conn=ftp_connect($ftp_server)ordie("Could not connect to $ftp_server");$login=ftp_login($ftp_conn,'Your user name','Your password');ftp_pasv($ftp_conn,TRUE);// 2.Khái báo 2 biến như bên dưới$local_file=$_SERVER['DOCUMENT_ROOT']."/SampleCSV.csv";// Đường dẫn dến file csv trên local của mình(Ban đầu chưa có file nhé)$server_file="SampleCSV.csv";//tên file csv trên FPT server// 3.Cấp quyền cho file csvif(file_exists($local_file)){chmod($local_file,0777);}// 4. Thực hiện download file về localif(ftp_get($ftp_conn,$local_file,$server_file,FTP_ASCII)){if(file_exists($local_file)){if(($handle=fopen($local_file,"r"))!==FALSE){while(($data=fgetcsv($handle,99999,","))!==FALSE){echo"<pre>";print_r($data);// hiển thị dữ liệu tương ứng với mỗi row trong file csvecho"</pre>";}fclose($handle);}}else{echo"File không tồn tại dưới local";}}else{echo"Xẩy ra lỗi trong quá trình download file về local";}

2. Thực hiện kết nối đến SFTP server
Do mình sẽ dùng libssh2 library để kết nối đến SFTP server, hiện tại trên server local của mình(xampp) chưa cài đặt libssh2 library,
do đó mình sẽ thực hiện download và cài đặt trên server local của mình trước nhé.
Link download: https://pecl.php.net/package/ssh2
Version mới nhất ở thời điểm mình làm ví dụ là 1.3.1 như ảnh bên dưới và click vào icon windows màu xanh có chứ DLL.

Màn hình tiếp theo mình sẽ chọn bản phù hợp với phiên bản php hiện tại mình đang dùng là php 7.4

Giải nén file vừa download về và copy 2 files php_ssh2.dll, php_ssh2.pdb trong folder giải nén vào thư mục xamppphpext trên server local như ảnh bên dưới.

Bước tiếp theo để sử dụng được thư viện này chúng ta phải vào file php.ini để thêm dòng ở ô màu đỏ bên dưới để enable thư viện đó nhé.

Bây giờ mình sẽ khơi động lại xampp để viết code sử dụng thư viện libssh2 nhé!

Source code:

$connection=ssh2_connect('Your host name');// Kiểm tra loginif(!ssh2_auth_password($connection,'Your user name','Your password')){thrownewException('Unable to connect.');}else{echo"connected";}// Tạo kết nối đến SFTP serverif(!$sftp=ssh2_sftp($connection)){thrownewException('Unable to create SFTP connection.');}else{echo"connected2";}//Biến chứa danh sách các files sẽ lấy từ SFTP server$files=array();//Đường dẫn thư mục chứa file csv trên SFTP server$dirHandle=opendir("ssh2.sftp://$sftp/csv/");// Tìm các files trong thư mục, bỏ qua các files có đuôi kiểu (. & ..)while(false!==($file=readdir($dirHandle))){if($file!='.'&&$file!='..'){$files[]=$file;}}// Đường dẫn dến file csv trên local của mình(Ban đầu chưa có file nhé)$local_file=$_SERVER['DOCUMENT_ROOT']."/localDirectory/SampleCSV.csv";if(count($files)){foreach($filesas$fileName){if($fileName=="SampleCSV.csv"){// Remote streamif(!$remoteStream= @fopen("ssh2.sftp://$sftp/csv/$fileName",'r')){thrownewException("Unable to open remote file: $fileName");}// Local streamif(!$localStream= @fopen($_SERVER['DOCUMENT_ROOT']."/localDirectory/$fileName",'w')){thrownewException("Unable to open local file for writing: /localDirectory/$fileName");}// Write from our remote stream to our local stream$read=0;$fileSize=filesize("ssh2.sftp://$sftp/csv/$fileName");while($read<$fileSize&&($buffer=fread($remoteStream,$fileSize-$read))){// Increase our bytes read$read+=strlen($buffer);// Write to our local fileif(fwrite($localStream,$buffer)===FALSE){thrownewException("Unable to write to local file: /localDirectory/$fileName");}else{if(file_exists($local_file)){if(($handle=fopen($local_file,"r"))!==FALSE){while(($branch=fgetcsv($handle,99999,","))!==FALSE){echo"<pre>";print_r($branch);echo"</pre>";}}}}}// Close our streamsfclose($localStream);fclose($remoteStream);}}}

Như vậy là mình đã hoàn thành một ví dụ đơn giản về cách kết nối, download, đọc file csv từ FTP, SFTP server khác,
do kiến thức của mình có hạn,nếu có gì thiếu sót và thắc mắc mọi người hay comment cho mình nhé!

Nguồn: viblo.asia

Bài viết liên quan

WebP là gì? Hướng dẫn cách để chuyển hình ảnh jpg, png qua webp

WebP là gì? WebP là một định dạng ảnh hiện đại, được phát triển bởi Google

Điểm khác biệt giữa IPv4 và IPv6 là gì?

IPv4 và IPv6 là hai phiên bản của hệ thống địa chỉ Giao thức Internet (IP). IP l

Check nameservers của tên miền xem website trỏ đúng chưa

Tìm hiểu cách check nameservers của tên miền để xác định tên miền đó đang dùn

Mình đang dùng Google Domains để check tên miền hàng ngày

Từ khi thông báo dịch vụ Google Domains bỏ mác Beta, mình mới để ý và bắt đầ