A利用ASP小偷和Google实现在线翻译功能的代码

代码如下: 有时候想为我们的网页提供多语言支持,如果一种语言用一张网页来做实在太麻烦了,幸好Google提供了语言工具功能,下面介绍如何利用它来实现网页多种语言之间的转换。 lan.htm form selectname='lan' optionvalue='http://www.popasp.com/en|de'英语翻译成德语/option optionvalue='http://www.popasp.com/en|es'英语翻译成西班牙语/option optionvalue='http:/

作者: 来源: 时间: 17-11-23 15:40:08

代码如下:
有时候想为我们的网页提供多语言支持,如果一种语言用一张网页来做实在太麻烦了,幸好Google提供了语言工具功能,下面介绍如何利用它来实现网页多种语言之间的转换。
lan.htm
<form>
<select name="lan">
<option value="http://www.popasp.com/en|de">英语 翻译成 德语</option>
<option value="http://www.popasp.com/en|es">英语 翻译成 西班牙语</option>
<option value="http://www.popasp.com/en|fr">英语 翻译成 法语</option>
<option value="http://www.popasp.com/en|it">英语 翻译成 意大利语</option>
<option value="http://www.popasp.com/en|pt">英语 翻译成 葡萄牙语</option>
<option value="http://www.popasp.com/en|ja">英语 翻译成 日语 BETA</option>
<option value="http://www.popasp.com/en|ko">英语 翻译成 朝鲜语 BETA</option>
<option value="http://www.popasp.com/en|zh-CN" >英语 翻译成 中文(简体) BETA</option>
<option value="http://www.popasp.com/de|en">德语 翻译成 英语</option>
<option value="http://www.popasp.com/de|fr">德语 翻译成 法语</option>
<option value="http://www.popasp.com/es|en">西班牙语 翻译成 英语</option>
<option value="http://www.popasp.com/fr|en">法语 翻译成 英语</option>
<option value="http://www.popasp.com/fr|de">法语 翻译成 德语</option>
<option value="http://www.popasp.com/it|en">意大利语 翻译成 英语</option>
<option value="http://www.popasp.com/pt|en">葡萄牙语 翻译成 英语</option>
<option value="http://www.popasp.com/ja|en">日语 翻译成 英语 BETA</option>
<option value="http://www.popasp.com/ko|en">朝鲜语 翻译成 英语 BETA</option>
<option value="http://www.popasp.com/zh-CN|en">中文(简体) 翻译成 英语 BETA</option>
<input style="FONT-SIZE: 12px" type="button" value="http://www.popasp.com/Go->" name="Button1" onClick="javascript:window.open("translate.asp?urls="+document.location+"&lan="+lan.value,"_self","")">
</select>
</form>



lan.htm中的内容用来选择要翻译的语言包括原来的语言和要翻译成的语言。我们只需要将lan.htm中的内容拷到提供多语言翻译的页面中就可以了。



translate.asp
<html>
<head>
<title>在线翻译</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>



<body>
<%
"on error resume next
" 如果网速很慢的话,可以调整以下时间。单位秒
Server.ScriptTimeout = 999999
"========================================================
"字符编码函数
"========================================================
Function BytesToBstr(body,code) 
dim objstream 
set objstream = Server.CreateObject("adodb.stream") 
objstream.Type = 1 
objstream.Mode =3 
objstream.Open 
objstream.Write body 
objstream.Position = 0 
objstream.Type = 2 
objstream.Charset =code
BytesToBstr = objstream.ReadText 
objstream.Close 
set objstream = nothing 
End Function 



"取行字符串在另一字符串中的出现位置
Function Newstring(wstr,strng) 
Newstring=Instr(lcase(wstr),lcase(strng)) 
if Newstring<=0 then Newstring=Len(wstr) 
End Function 
"替换字符串函数
function ReplaceStr(ori,str1,str2)
ReplaceStr=replace(ori,str1,str2)
end function
"=====================================================
function ReadXml(url,code,start,ends)
set oSend=createobject("Microsoft.XMLHTTP")
SourceCode = oSend.open ("GET",url,false) 
oSend.send()
ReadXml=BytesToBstr(oSend.responseBody,code )
if(start="" or ends="") then
else
start=Newstring(ReadXml,start)
ReadXml=mid(ReadXml,start)
ends=Newstring(ReadXml,ends)
ReadXml=left(ReadXml,ends-1)
end if
end function
dim urlpage,lan
urlpage=request("urls")
lan=request("lan")
%>
<form method="post" action="translate.asp">
<input type="text" name="urls" size="150" value="http://www.popasp.com/">
<input type="hidden" name="lan" value="http://www.popasp.com/">
<input type="submit" value="http://www.popasp.com/submit">
</form>
<%
dim transURL
transURL="http://216.239.39.104/translate_c?hl=zh-CN&ie=UTF-8&oe=UTF-8&langpair="&server.URLEncode(lan)&"&u="&urlpage&"&prev=/language_tools"
if(len(urlpage)>3) then
getcont=ReadXml(transURL,"gb2312","","")
response.Write(getcont)
end if



%>
</body>
</html>
  translate.asp实现翻译功能,这是利用google的语言工具实现的。
  注意,因为提供多语言支持,所以translate.asp文件所用的编码是支持所有字符的"utf-8"  

 

11
22
33
隐藏区块

会员注册

本功能为预留功能,暂不支持注册 ^_^

Login

社交帐号登陆

使用以下任意帐号可登陆本站

Close section
Close

联系我们

关于5UCMS 您有任何需求 均可以留言给我们