首頁  >  文章  >  php框架  >  Thinkphp翻譯介面的使用及其最佳化

Thinkphp翻譯介面的使用及其最佳化

咔咔
咔咔原創
2020-08-19 16:53:442603瀏覽

本文提供大家一個免費的翻譯接口,有空時可以試試還是很秀的哈!

前言

專案中必要的資料是需要寫語言包的,就像那種幾百年不變的數據,但是有一類數據就是在專案的運作的過程中就一直在變化。

對於這樣的資料我們寫成語言包顯然是不合適的,所以我們就需要藉助翻譯介面來實現我們的需求了。

一、翻譯介面簡單介紹

#先看一張圖吧!看一下這個翻譯介面在我們的專案中如何運用。

Thinkphp翻譯介面的使用及其最佳化
在這裡插入圖片描述

這個介面總共有4個參數,分別為a、f、t、w。

這四個參數分別的意思為,a是固定的值就是fy。

f指的是翻譯的語種。

t指的是需要翻譯成我們需要的語種。

w指的是需要翻譯的資料。

二、專案實戰

#專案需求就是把左邊的框出來的在切換語言後跟隨這語言變動。 先說明一下,在上邊的這些文字不是手動寫上去的,html檔案也是不存在的。是在資料庫註解裡邊配置的。

下圖就是我們的資料庫建立。 為什麼這麼創建,這樣創建有什麼好處,我就不提了,每個團隊都有自己的想法哈!

接著我們來到正題

使用的程式碼也就這點,介面位址就是上邊postman裡邊的位址,後邊只需要傳送一個需要翻譯的資料即可。

本文實現的資料就是上圖左側的文字,也就是我們從資料庫中把註解讀出來然後根據一定的規則把這個名字就直接作為添加或修改時的列即可。

那麼就只需要把這個註解直接給追加到翻譯介面後邊即可。 提供一個php發起curl請求的程式碼

public function translateRequest($url, $data=array()){

$ch = curl_init();//初始化
//curl_setopt();//设置
//设置
curl_setopt($ch,CURLOPT_URL,$url); //需要获取的 URL 地址
curl_setopt($ch,CURLOPT_HEADER,0); //启用时会将头文件的信息作为数据流输出, 此处禁止输出头信息
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); //获取的信息以字符串返回,而不是直接输出
curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,30); //连接超时时间
curl_setopt($ch, CURLOPT_ENCODING, 'gzip');

//避免https 的ssl验证
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt($ch, CURLOPT_SSLVERSION, false);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);

if($data){
curl_setopt($ch, CURLOPT_POST, 1); //post请求
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);//post参数
}

//执行
$data = curl_exec($ch);//执行 不输出 内容返回给它
//判断是否请求成功

if(curl_errno($ch)){//错误码
echo 'curl error: '.curl_error($ch);//错误信息
}

$response = curl_getinfo($ch);

switch($response['http_code']){
case 200:
return $data;
break;
default:
exit('程序异常');
}

curl_close($ch);//关闭
}

經過測試後看看效果,效果是實現了,但是你們可以私下試試哈!翻譯一組資料時速度還行,但是翻譯幾個資料時就有點慢了。

新增頁面開啟的時間大概需要3-5S,這肯定是不行的,所以我們需要想一個辦法來解決這個問題。 Thinkphp翻譯介面的使用及其最佳化

三、最佳化翻譯速度

#在第二步中,咔喀做到最後是發現翻譯的速度是有點慢的,碰到字段多的更是慢的離譜。於是咔咔就想了一個辦法。

這些資料是之前是一個一個翻譯出來的,那我們是不是也可以一次給翻譯出來,然後我們在來自己組裝資料。 Thinkphp翻譯介面的使用及其最佳化

帶著這個想法我們開始實作。

這幾行程式碼最終實現的就是把所有的字段註解放在一起,並且用“,”隔開Thinkphp翻譯介面的使用及其最佳化打印出來的數據可以看一下,out字段就是翻譯出來的數據,其實想都不用想一次翻譯肯定比6次翻譯速度快。

然後拿著這組資料在轉換成數組在重新組裝到原始資料裡就ok了。 Thinkphp翻譯介面的使用及其最佳化這裡有個小問題,可以一起關註一下。中文印出來的是原始資料裡邊的,英文是資料經過處理的。

很明顯可以看到回傳的英文結果跟原始資料對不上。 Thinkphp翻譯介面的使用及其最佳化這裡的處理也是比較簡單,如果你有更好的方案評論區見

處理方式在取得資料庫欄位中文註解之前把對應的索引儲存到$needkey

然後重新定義一個變數fanal,讓fanal的索引等於needkey的v,而對應的值就是result[needkey的k]

四、總結

這樣一個翻譯介面的使用就完成了,專案截圖就不給大家展示了哈!

把多次翻譯改為一次翻譯,提升翻譯速度,畢竟是請求別人的東西,肯定沒有我們自己重組資料快。

堅持學習、堅持寫博、堅持分享是咔咔從業以來一直所秉持的信念。希望在諾大互聯網中咔咔的文章能帶給你一絲絲幫助。

#

以上是Thinkphp翻譯介面的使用及其最佳化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn