之前做微信登錄開發(fā)時(shí)候,發(fā)現(xiàn)微信頭像圖片沒有后綴名,傳統(tǒng)的圖片抓取方式不奏效,需要特殊的抓取處理。所以,后來(lái)將各種情況結(jié)合起來(lái),封裝成一個(gè)類,分享出來(lái)。
創(chuàng)建項(xiàng)目
作為演示,我們?cè)趙ww根目錄創(chuàng)建項(xiàng)目grabimg,創(chuàng)建一個(gè)類GrabImage.php和一個(gè)index.php。
編寫類代碼
我們定義一個(gè)和文件名相同的類:GrabImage
class GrabImage{}
屬性
接下來(lái)定義幾個(gè)需要使用的屬性。
1、首先定義一個(gè)需要抓取的圖片地址:$img_url
2、再定義一個(gè)$file_name用來(lái)存儲(chǔ)文件的名稱,但是不攜帶拓展名,因?yàn)榭赡苌婕暗酵卣姑鼡Q,所以這里拆開定義
3、緊接著就是拓展名$extension
4、然后我們定義一個(gè)$file_dir,該屬性的作用是,遠(yuǎn)程圖片抓取到本地后所存儲(chǔ)的目錄,一般相對(duì)于PHP入口文件所在的位置作為起始。但是該路徑一般不保存到數(shù)據(jù)庫(kù)。
5、最后我們定義一個(gè)$save_dir,顧名思義,該路徑是用來(lái)直接保存的數(shù)據(jù)庫(kù)的目錄。這里說(shuō)明下,我們不直接存儲(chǔ)文件保存路徑到數(shù)據(jù)庫(kù),一般是為了之后如果系統(tǒng)遷移,方便更換路徑做準(zhǔn)備。我們這里的$save_dir一般為日期 + 文件名,如果需要使用時(shí)候取出,在前方拼上所需要的路徑。
方法
屬性弄完了,接下來(lái)我們正式開始抓取工作。
首先我們定義一個(gè)對(duì)外開放的方法getInstances用來(lái)獲取一些數(shù)據(jù),比如抓取圖片地址,和本地保存路徑。同時(shí)將其放入屬性中。
public function getInstances($img_url , $base_dir) { $this->img_url = $img_url; $this->save_dir = date("Ym").'/'.date("d").'/'; // 比如:201610/19/ $this->file_dir = $base_dir.'/'.$this->save_dir.'/'; // 比如:./uploads/image/2016/10/19/ }
圖片保存路徑拼接完成,下面我們要注意一個(gè)問(wèn)題,目錄是否存在。日期在一天天走,但是目錄并不會(huì)自動(dòng)創(chuàng)建。所以,在保存圖片之前,首先需要檢查一下,如果當(dāng)前目錄不存在我們需要即時(shí)創(chuàng)建。
我們創(chuàng)建設(shè)置目錄方法setDir。屬性我們?cè)O(shè)置了private,安全
/** * 檢查圖片需要保持的目錄是否存在 * 如果不存在,則立即創(chuàng)建一個(gè)目錄 * @return bool */ private function setDir() { if(!file_exists($this->file_dir)) { mkdir($this->file_dir,0777,TRUE); } $this->file_name = uniqid().rand(10000,99999);// 文件名,這里只是演示,實(shí)際項(xiàng)目中請(qǐng)使用自己的唯一文件名生成方法 return true; }
接下來(lái)就是抓取核心代碼
第一步,解決一個(gè)問(wèn)題,我們需要抓取的圖片可能沒有后綴名。按照傳統(tǒng)的抓取方法,先抓取圖片,然后截取后綴名的方案不可行。
我們必須通過(guò)其它方法來(lái)獲得圖片類型。辦法就是從文件流信息中獲取文件頭信息,從而判斷文件mime信息,就可以知道文件后綴名。
為了方便,先定義一個(gè)mime和文件拓展名映射。
$mimes=array( 'image/bmp'=>'bmp', 'image/gif'=>'gif', 'image/jpeg'=>'jpg', 'image/png'=>'png', 'image/x-icon'=>'ico' );
這樣,當(dāng)我獲取了類型是image/gif的時(shí)候,我就可以知道是.gif圖片了。
利用php函數(shù)get_headers,獲取文件流頭信息。當(dāng)其值不為false時(shí)候我們將其賦值給變量$headers
取出Content-Type的值即為mime的值。
if(($headers=get_headers($this->img_url, 1))!==false){ // 獲取響應(yīng)的類型 $type=$headers['Content-Type']; }
使用上面我們定義的映射表,我們可以很輕松的獲取后綴名。
$this->extension=$mimes[$type];
當(dāng)然上面獲取的$type,可能不存在我們的映射表中,說(shuō)明這種類型文件并不是我們想要的,直接拋棄就好了,不用管它。
下面的步驟就和傳統(tǒng)抓取文件一樣。
$file_path = $this->file_dir.$this->file_name.".".$this->extension; // 獲取數(shù)據(jù)并保存 $contents=file_get_contents($this->img_url); if(file_put_contents($file_path , $contents)) { // 這里返回出去的值是直接保存到數(shù)據(jù)庫(kù)的路徑 + 文件名,形如:201610/19/57feefd7e2a7aY5p7LsPqaI-lY1BF.jpg return $this->save_dir.$this->file_name.".".$this->extension; }
首先獲取本地保圖片存完整路徑$file_path,接下來(lái)使用file_get_contents抓取數(shù)據(jù),然后使用file_put_contents保存到剛剛的文件路徑。
最后我們返回一個(gè)可以直接保存到數(shù)據(jù)庫(kù)中的路徑,而不是文件存儲(chǔ)路徑。
該抓取方法完整版是:
private function getRemoteImg() { // mime 和 擴(kuò)展名 的映射 $mimes=array( 'image/bmp'=>'bmp', 'image/gif'=>'gif', 'image/jpeg'=>'jpg', 'image/png'=>'png', 'image/x-icon'=>'ico' ); // 獲取響應(yīng)頭 if(($headers=get_headers($this->img_url, 1))!==false) { // 獲取響應(yīng)的類型 $type=$headers['Content-Type']; // 如果符合我們要的類型 if(isset($mimes[$type])) { $this->extension=$mimes[$type]; $file_path = $this->file_dir.$this->file_name.".".$this->extension; // 獲取數(shù)據(jù)并保存 $contents=file_get_contents($this->img_url); if(file_put_contents($file_path , $contents)) { // 這里返回出去的值是直接保存到數(shù)據(jù)庫(kù)的路徑 + 文件名,形如:201610/19/57feefd7e2a7aY5p7LsPqaI-lY1BF.jpg return $this->save_dir.$this->file_name.".".$this->extension; } } } return false; }
最后,為了簡(jiǎn)單,我們想在其他地方只要調(diào)用其中一個(gè)方法就可以完成抓取。所以,我們將抓取動(dòng)作直接放入到getInstances中,在配置完路徑后,直接抓取,所以,在初始化配置方法getInstances里新增代碼。
if($this->setDir()) { return $this->getRemoteImg(); } else { return false; }
測(cè)試
我們?nèi)倓倓?chuàng)建的index.php文件內(nèi)試試。
<?php require_once 'GrabImage.php'; $object = new GrabImage(); $img_url = "http://www.bidianer.com/img/icon_mugs.jpg"; // 需要抓取的遠(yuǎn)程圖片 $base_dir = "./uploads/image"; // 本地保存的路徑 echo $object->getInstances($img_url , $base_dir); ?>
惹,的確抓取過(guò)來(lái)了
完整代碼
* @link bidianer.com */ class GrabImage{ /** * @var string 需要抓取的遠(yuǎn)程圖片的地址 * 例如:http://www.bidianer.com/img/icon_mugs.jpg * 有一些遠(yuǎn)程文件路徑可能不帶拓展名 * 形如:http://www.xxx.com/img/icon_mugs/q/0 */ private $img_url; /** * @var string 需要保存的文件名稱 * 抓取到本地的文件名會(huì)重新生成名稱 * 但是,不帶拓展名 * 例如:57feefd7e2a7aY5p7LsPqaI-lY1BF */ private $file_name; /** * @var string 文件的拓展名 * 這里直接使用遠(yuǎn)程圖片拓展名 * 對(duì)于沒有拓展名的遠(yuǎn)程圖片,會(huì)從文件流中獲取 * 例如:.jpg */ private $extension; /** * @var string 文件保存在本地的目錄 * 這里的路徑是PHP保存文件的路徑 * 一般相對(duì)于入口文件保存的路徑 * 比如:./uploads/image/201610/19/ * 但是該路徑一般不直接存儲(chǔ)到數(shù)據(jù)庫(kù) */ private $file_dir; /** * @var string 數(shù)據(jù)庫(kù)保存的文件目錄 * 這個(gè)路徑是直接保存到數(shù)據(jù)庫(kù)的圖片路徑 * 一般直接保存日期 + 文件名,需要使用的時(shí)候拼上前面路徑 * 這樣做的目的是為了遷移系統(tǒng)時(shí)候方便更換路徑 * 例如:201610/19/ */ private $save_dir; /** * @param string $img_url 需要抓取的圖片地址 * @param string $base_dir 本地保存的路徑,比如:./uploads/image,最后不帶斜杠"/" * @return bool|int */ public function getInstances($img_url , $base_dir) { $this->img_url = $img_url; $this->save_dir = date("Ym").'/'.date("d").'/'; // 比如:201610/19/ $this->file_dir = $base_dir.'/'.$this->save_dir.'/'; // 比如:./uploads/image/2016/10/19/ return $this->start(); } /** * 開始抓取圖片 */ private function start() { if($this->setDir()) { return $this->getRemoteImg(); } else { return false; } } /** * 檢查圖片需要保持的目錄是否存在 * 如果不存在,則立即創(chuàng)建一個(gè)目錄 * @return bool */ private function setDir() { if(!file_exists($this->file_dir)) { mkdir($this->file_dir,0777,TRUE); } $this->file_name = uniqid().rand(10000,99999);// 文件名,這里只是演示,實(shí)際項(xiàng)目中請(qǐng)使用自己的唯一文件名生成方法 return true; } /** * 抓取遠(yuǎn)程圖片核心方法,可以同時(shí)抓取有后綴名的圖片和沒有后綴名的圖片 * * @return bool|int */ private function getRemoteImg() { // mime 和 擴(kuò)展名 的映射 $mimes=array( 'image/bmp'=>'bmp', 'image/gif'=>'gif', 'image/jpeg'=>'jpg', 'image/png'=>'png', 'image/x-icon'=>'ico' ); // 獲取響應(yīng)頭 if(($headers=get_headers($this->img_url, 1))!==false) { // 獲取響應(yīng)的類型 $type=$headers['Content-Type']; // 如果符合我們要的類型 if(isset($mimes[$type])) { $this->extension=$mimes[$type]; $file_path = $this->file_dir.$this->file_name.".".$this->extension; // 獲取數(shù)據(jù)并保存 $contents=file_get_contents($this->img_url); if(file_put_contents($file_path , $contents)) { // 這里返回出去的值是直接保存到數(shù)據(jù)庫(kù)的路徑 + 文件名,形如:201610/19/57feefd7e2a7aY5p7LsPqaI-lY1BF.jpg return $this->save_dir.$this->file_name.".".$this->extension; } } } return false; } }

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

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

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

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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

Kaedah teras untuk membina fungsi perkongsian sosial dalam PHP adalah untuk menghasilkan pautan perkongsian secara dinamik yang memenuhi keperluan setiap platform. 1. Mula -mula dapatkan halaman semasa atau URL dan maklumat artikel yang ditentukan; 2. Gunakan urlencode untuk menyandikan parameter; 3. Sambutan dan menjana pautan perkongsian mengikut protokol setiap platform; 4. Pautan paparan di hujung depan untuk pengguna mengklik dan berkongsi; 5. Dinamik menghasilkan tag OG pada halaman untuk mengoptimumkan paparan kandungan perkongsian; 6. Pastikan untuk melepaskan input pengguna untuk mencegah serangan XSS. Kaedah ini tidak memerlukan pengesahan yang kompleks, mempunyai kos penyelenggaraan yang rendah, dan sesuai untuk kebanyakan keperluan perkongsian kandungan.

Untuk merealisasikan pembetulan ralat teks dan pengoptimuman sintaks dengan AI, anda perlu mengikuti langkah -langkah berikut: 1. Pilih model AI atau API yang sesuai, seperti Baidu, Tencent API atau perpustakaan NLP sumber terbuka; 2. Panggil API melalui curl atau Guzzle PHP dan memproses hasil pulangan; 3. Maklumat pembetulan ralat paparan dalam aplikasi dan membenarkan pengguna memilih sama ada untuk mengadopsinya; 4. Gunakan php-l dan php_codesniffer untuk pengesanan sintaks dan pengoptimuman kod; 5. Secara berterusan mengumpul maklum balas dan mengemas kini model atau peraturan untuk meningkatkan kesannya. Apabila memilih AIAPI, fokus pada menilai ketepatan, kelajuan tindak balas, harga dan sokongan untuk PHP. Pengoptimuman kod harus mengikuti spesifikasi PSR, gunakan cache yang munasabah, elakkan pertanyaan bulat, mengkaji semula kod secara berkala, dan gunakan x

1. Memaksimumkan nilai komersil sistem komen memerlukan menggabungkan pengiklanan pengiklanan asli, perkhidmatan nilai tambah pengguna (seperti memuat naik gambar, komen top-up), mempengaruhi mekanisme insentif berdasarkan kualiti komen, dan pematuhan data pengewangan data tanpa nama; 2. Strategi audit harus mengadopsi gabungan penapisan kata kunci dinamik pra-audit dan mekanisme pelaporan pengguna, ditambah dengan penarafan kualiti komen untuk mencapai pendedahan hierarki kandungan; 3. Anti-brushing memerlukan pembinaan pertahanan berbilang lapisan: Recaptchav3 Pengesahan tanpa sensor, Honeypot Honeypot Field Robot, IP dan Had Frekuensi Timestamp menghalang penyiraman, dan pengiktirafan corak kandungan menandakan komen yang mencurigakan, dan terus berurusan dengan serangan.

Input suara pengguna ditangkap dan dihantar ke backend PHP melalui API Mediarecorder JavaScript front-end; 2. PHP menjimatkan audio sebagai fail sementara dan memanggil STTAPI (seperti Pengiktirafan Suara Google atau Baidu) untuk mengubahnya menjadi teks; 3. PHP menghantar teks kepada perkhidmatan AI (seperti Openaigpt) untuk mendapatkan jawapan pintar; 4. PHP kemudian memanggil TTSAPI (seperti sintesis Baidu atau Google Voice) untuk menukar balasan ke fail suara; 5. PHP mengalir fail suara kembali ke bahagian depan untuk bermain, menyelesaikan interaksi. Seluruh proses dikuasai oleh PHP untuk memastikan hubungan lancar antara semua pautan.

PHP tidak secara langsung melaksanakan pemprosesan imej AI, tetapi mengintegrasikan melalui API, kerana ia adalah baik pada pembangunan web dan bukannya tugas-tugas intensif pengkomputeran. Integrasi API boleh mencapai pembahagian profesional buruh, mengurangkan kos, dan meningkatkan kecekapan; 2. Mengintegrasikan teknologi utama termasuk menggunakan Guzzle atau Curl untuk menghantar permintaan HTTP, pengekodan data JSON dan penyahkodan, pengesahan keselamatan utama API, pemprosesan giliran yang memakan masa yang memakan masa, pengendalian ralat yang teguh dan mekanisme semula, penyimpanan imej dan paparan; 3. Cabaran umum termasuk kos API daripada kawalan, hasil generasi yang tidak terkawal, pengalaman pengguna yang lemah, risiko keselamatan dan pengurusan data yang sukar. Strategi tindak balas menetapkan kuota dan cache pengguna, menyediakan panduan propt dan pemilihan multi-gambar, pemberitahuan asynchronous dan kemajuan kemajuan, penyimpanan pembolehubah persekitaran utama dan audit kandungan, dan penyimpanan awan.

PHP memastikan pemotongan inventori atomik melalui urus niaga pangkalan data dan kunci baris forupdate untuk mengelakkan overselling serentak yang tinggi; 2. Konsistensi inventori pelbagai platform bergantung kepada pengurusan berpusat dan penyegerakan yang didorong oleh peristiwa, menggabungkan pemberitahuan API/webhook dan beratur mesej untuk memastikan penghantaran data yang boleh dipercayai; 3. Mekanisme penggera harus menetapkan inventori rendah, sifar/inventori negatif, jualan yang tidak dapat dilepaskan, kitaran penambahan dan strategi turun naik yang tidak normal dalam senario yang berbeza, dan pilih DingTalk, SMS atau orang yang bertanggungjawab e -mel mengikut urgensi, dan maklumat penggera mesti lengkap dan jelas untuk mencapai penyesuaian perniagaan dan tindak balas yang cepat.

PHP menyediakan asas input untuk model AI dengan mengumpul data pengguna (seperti sejarah pelayaran, lokasi geografi) dan pra-pemprosesan; 2. Gunakan curl atau GRPC untuk berhubung dengan model AI untuk mendapatkan keputusan ramalan kadar klik dan penukaran kadar; 3. Secara dinamik menyesuaikan kekerapan paparan pengiklanan, populasi sasaran dan strategi lain berdasarkan ramalan; 4. Uji varian pengiklanan yang berbeza melalui A/B dan data rekod, dan menggabungkan analisis statistik untuk mengoptimumkan kesannya; 5. Gunakan PHP untuk memantau sumber lalu lintas dan tingkah laku pengguna dan mengintegrasikan dengan API pihak ketiga seperti Googleads untuk mencapai penghantaran automatik dan pengoptimuman maklum balas yang berterusan, akhirnya meningkatkan CTR dan CVR dan mengurangkan CPC, dan melaksanakan sepenuhnya sistem pengiklanan yang didorong oleh AI-Driven.

Phpisstillrelevantinmodernenterpriseenvironments.1.modernphp (7.xand8.x) Menawarkan Perpaduan Perlengkapan, ketegangan, jitcompilation, danmodernsyntax, makeitsuatableforlarge-scaleapplications.2.phpintegratefective
