❝本文给大家提供一个免费的翻译接口,有空时可以试试还是很秀的哈!
❞
项目中必要的数据是需要写语言包的,就像那种几百年不变的数据,但是有一类数据就是在项目的运行的过程中就在一直变化。
对于这样的数据我们写成语言包显然是不合适的,所以我们就需要借助翻译接口来实现我们的需求了。
先看一张图吧!看一下这个翻译接口在我们的项目中如何运用。
这个接口总共有4个参数,分别为a、f、t、w。
这四个参数分别的意思为,a是固定的值就是fy。
f指的是翻译的语种。
t指的是需要翻译成我们需要的语种。
w指的是需要翻译的数据。
项目需求就是把左边的框出来的在切换语言后跟随这语言变动。首先说明一下,在上边的这些文字不是手动写上去的,html文件也是不存在的。是在数据库注释里边配置的。
下图就是我们的数据库创建。为什么这么创建,这样创建有什么好处,我就不提了,每个团队都有自己的想法哈!
接着我们来到正题
使用的代码也就这点,接口地址就是上边postman里边的地址,后边只需要传输一个需要翻译的数据即可。
本文实现的数据就是上图左侧的文字,也就是我们从数据库中把注释读出来然后根据一定的规则把这个名字就直接作为添加或者修改时的列即可。
那么就只需要把这个注释直接给追加到翻译接口后边即可。给你提供一个php发起curl请求的代码
<span style="display: block; background: url(https://my-wechat.mdnice.com/point.png); height: 30px; width: 100%; background-size: 40px; background-repeat: no-repeat; background-color: #272822; margin-bottom: -7px; border-radius: 5px; background-position: 10px 10px;"></span><span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">public</span> <span class="hljs-function" style="line-height: 26px;"><span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">function</span> <span class="hljs-title" style="color: #a6e22e; font-weight: bold; line-height: 26px;">translateRequest</span><span class="hljs-params" style="line-height: 26px;">($url, $data=array<span class="hljs-params" style="line-height: 26px;">()</span>)</span></span>{<br/><br/> $ch = curl_init();<span class="hljs-comment" style="color: #75715e; line-height: 26px;">//初始化</span><br/> <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//curl_setopt();//设置</span><br/> <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//设置</span><br/> curl_setopt($ch,CURLOPT_URL,$url); <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//需要获取的 URL 地址</span><br/> curl_setopt($ch,CURLOPT_HEADER,<span class="hljs-number" style="line-height: 26px;">0</span>); <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//启用时会将头文件的信息作为数据流输出, 此处禁止输出头信息</span><br/> curl_setopt($ch,CURLOPT_RETURNTRANSFER,<span class="hljs-number" style="line-height: 26px;">1</span>); <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//获取的信息以字符串返回,而不是直接输出</span><br/> curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,<span class="hljs-number" style="line-height: 26px;">30</span>); <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//连接超时时间</span><br/> curl_setopt($ch, CURLOPT_ENCODING, <span class="hljs-string" style="color: #a6e22e; line-height: 26px;">'gzip'</span>);<br/><br/> <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//避免https 的ssl验证</span><br/> curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">false</span>);<br/> curl_setopt($ch, CURLOPT_SSLVERSION, <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">false</span>);<br/> curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">false</span>);<br/><br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">if</span>($data){<br/> curl_setopt($ch, CURLOPT_POST, <span class="hljs-number" style="line-height: 26px;">1</span>); <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//post请求</span><br/> curl_setopt($ch, CURLOPT_POSTFIELDS, $data);<span class="hljs-comment" style="color: #75715e; line-height: 26px;">//post参数</span><br/> }<br/><br/> <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//执行</span><br/> $data = curl_exec($ch);<span class="hljs-comment" style="color: #75715e; line-height: 26px;">//执行 不输出 内容返回给它</span><br/> <span class="hljs-comment" style="color: #75715e; line-height: 26px;">//判断是否请求成功</span><br/><br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">if</span>(curl_errno($ch)){<span class="hljs-comment" style="color: #75715e; line-height: 26px;">//错误码</span><br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">echo</span> <span class="hljs-string" style="color: #a6e22e; line-height: 26px;">'curl error: '</span>.curl_error($ch);<span class="hljs-comment" style="color: #75715e; line-height: 26px;">//错误信息</span><br/> }<br/><br/> $response = curl_getinfo($ch);<br/><br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">switch</span>($response[<span class="hljs-string" style="color: #a6e22e; line-height: 26px;">'http_code'</span>]){<br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">case</span> <span class="hljs-number" style="line-height: 26px;">200</span>:<br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">return</span> $data;<br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">break</span>;<br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">default</span>:<br/> <span class="hljs-keyword" style="color: #f92672; font-weight: bold; line-height: 26px;">exit</span>(<span class="hljs-string" style="color: #a6e22e; line-height: 26px;">'程序异常'</span>);<br/> }<br/><br/> curl_close($ch);<span class="hljs-comment" style="color: #75715e; line-height: 26px;">//关闭</span><br/> }<br/>
经过测试后看看效果,效果是实现了,但是你们可以私下试试哈!翻译一组数据时速度还行,但是翻译几个数据时就有点慢了。
添加页面打开的时间大概需要3-5S,这肯定是不可以的,所以我们需要想一个办法来解决这个问题。
在第二步中,咔咔做到最后是发现翻译的速度是有点慢的,碰到字段多的更是慢的离谱。于是咔咔就想了一个办法。
这些数据是之前是一个一个翻译出来的,那么我们是不是也可以一次性给翻译出来,然后我们在来自己组装数据。
带着这个想法我们开始实施。
这几行代码最终实现的就是把所有的字段注释放在一起,并且用“,”隔开打印出来的数据可以看一下,out字段就是翻译出来的数据,其实想都不用想一次翻译肯定比6次翻译速度快。
然后拿着这组数据在转化成数组在重新组装到原数据里就ok了。这里有个小问题,可以一起关注一下。中文打印出来的是原始数据里边的,英文是数据经过处理的。
很明显可以看到返回的英文结果跟原始数据对不上。这里的处理也是比较简单,如果你有更好的方案评论区见
处理方式在获取数据库字段中文注释之前把对应的索引保存到$needkey
然后重新定义一个变量fanal,让fanal的索引等于needkey的v,而对应的值就是result[needkey的k]
这样一个翻译接口的使用就完成了,项目截图就不给大家展示了哈!
把多次翻译改为一次翻译,提升翻译速度,毕竟是请求别人的东西,肯定没有我们自己重组数据快。
❝坚持学习、坚持写博、坚持分享是咔咔从业以来一直所秉持的信念。希望在诺大互联网中咔咔的文章能带给你一丝丝帮助。
❞
前言一、翻译接口简单介绍二、项目实战三、优化翻译速度四、总结