Asp.NET调用百度翻译的方法

所属分类: 网络编程 / ASP.NET 阅读数: 1107
收藏 0 赞 0 分享

本文实例讲述了Asp.NET调用百度翻译的方法。分享给大家供大家参考。具体分析如下:

Asp.NET调用百度翻译,如下图所示:

HTML代码如下:

复制代码 代码如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="baidu.aspx.cs" Inherits="FanYi_baidu" %> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head runat="server"> 
    <title>OA翻译</title> 
</head> 
<body> 
    <form id="form1" runat="server"> 
    <div> 
        <asp:TextBox ID="sourceWord" runat="server" Columns="50" Rows="15" style="width:100%;" 
            TextMode="MultiLine"></asp:TextBox> 
        <br /> 
        源语言:<asp:DropDownList ID="ddlFrom" runat="server"> 
            <asp:ListItem Value="auto">自动检测</asp:ListItem> 
            <asp:ListItem Value="zh">中文</asp:ListItem> 
            <asp:ListItem Value="en">英文</asp:ListItem> 
            <asp:ListItem Value="jp">日文</asp:ListItem> 
        </asp:DropDownList> 
        目标语言:<asp:DropDownList ID="ddlTo" runat="server"> 
            <asp:ListItem Value="auto">自动检测</asp:ListItem> 
            <asp:ListItem Value="zh">中文</asp:ListItem> 
            <asp:ListItem Value="en">英文</asp:ListItem> 
            <asp:ListItem Value="jp">日文</asp:ListItem> 
        </asp:DropDownList> 
        <asp:Button ID="Translate" 
            runat="server" Text="翻译" onclick="Translate_Click" /> 
        <br /> 
        <asp:TextBox ID="resultText" runat="server" TextMode="MultiLine" Rows="15" Columns="50" style="width:100%;"></asp:TextBox> 
    </div> 
    </form> 
</body> 
</html>

C#代码如下:

复制代码 代码如下:
using System; 
using System.Collections.Generic; 
using System.IO; 
using System.Net; 
using System.Runtime.Serialization; 
using System.Runtime.Serialization.Json; 
using System.Text; 
using System.Web; 
 
public partial class FanYi_baidu : System.Web.UI.Page 

    string url = @"http://openapi.baidu.com/public/2.0/bmt/translate"; 
    string requestDetail = "client_id=申请的ID"; 
    protected void Page_Load(object sender, EventArgs e) 
    { 
 
    } 
    [DataContract] 
    public class AdmAccessToken 
    { 
        [DataMember] 
        public string from { get; set; } 
        [DataMember] 
        public string to { get; set; } 
        [DataMember] 
        public string error_code { get; set; } 
        [DataMember] 
        public string error_msg { get; set; } 
        [DataMember] 
        public string query { get; set; } 
        [DataMember] 
        public List<TokenResult> trans_result { get; set; } 
    } 
 
    [DataContract] 
    public class TokenResult 
    { 
        [DataMember] 
        public string src { get; set; } 
        [DataMember] 
        public string dst { get; set; } 
    } 
 
    //百度翻译返回数据结构 
    //{ 
    //"from": "en", 
    //"to": "zh", 
    //"trans_result": [ 
    //    { 
    //        "src": "today", 
    //        "dst": "今天" 
    //    }, 
    //    { 
    //        "src": "tomorrow", 
    //        "dst": "明天" 
    //    } 
    //], 
    //"error_code": "52001", 
    //"error_msg": "TIMEOUT", 
    //"query": "he's" 
    //} 
 
    /// <summary> 
    /// 采用Post方式提交数据 
    /// </summary> 
    /// <param name="DatamarketAccessUri">目标网址</param> 
    /// <param name="requestDetails">参数字符串</param> 
    /// <returns></returns> 
    private AdmAccessToken HttpPost(string DatamarketAccessUri, string requestDetails) 
    { 
        //Prepare OAuth request  
        WebRequest webRequest = WebRequest.Create(DatamarketAccessUri); 
        webRequest.ContentType = "application/x-www-form-urlencoded"; 
        webRequest.Method = "POST"; 
        byte[] bytes = Encoding.ASCII.GetBytes(requestDetails); 
        webRequest.ContentLength = bytes.Length; 
        using (Stream outputStream = webRequest.GetRequestStream()) 
        { 
            outputStream.Write(bytes, 0, bytes.Length); 
        } 
        using (WebResponse webResponse = webRequest.GetResponse()) 
        { 
            DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(AdmAccessToken)); 
            //Get deserialized object from JSON stream 
            AdmAccessToken token = (AdmAccessToken)serializer.ReadObject(webResponse.GetResponseStream()); 
            return token; 
        } 
    } 
 
    protected void Translate_Click(object sender, EventArgs e) 
    { 
        resultText.Text = ""; 
        if (sourceWord.Text.Trim() != "") 
        { 
            string requestStr = requestDetail + "&from=" + ddlFrom.SelectedValue 
                + "&to=" + ddlTo.SelectedValue 
                + "&q=" + HttpUtility.UrlEncode(sourceWord.Text); 
 
            AdmAccessToken token = HttpPost(url, requestStr); 
            if (token.error_code != null) 
            { 
                resultText.Text = token.error_msg; 
            } 
            else 
            { 
                int n = token.trans_result.Count; 
                for (int i = 0; i < n; i++) 
                { 
                    resultText.Text += token.trans_result[i].dst + (i < n-1 ? "\n" : ""); 
                } 
            } 
        } 
        else 
        { 
            resultText.Text = "请输入要翻译的内容"; 
        } 
    } 
}

希望本文所述对大家的C#程序设计有所帮助。

更多精彩内容其他人还在看

asp.net 虚方法、抽象方法、接口疑问

asp.net 虚方法、抽象方法、接口疑问等说明。
收藏 0 赞 0 分享

c#  操作符?? null coalescing operator

?? "null coalescing" operator 是c#新提供的一个操作符,这个操作符提供的功能是判断左侧的操作数是否是null,如果是则返回结果是右侧的操作数;非null则返回左侧的操作数。
收藏 0 赞 0 分享

.net 反序题目的详细解答第1/2页

在各种答案,以及平时面试过程中,这道题总归会有一些非常典型的错误发生。其中给老赵的感觉也非常有意思,不知其中的“思路”是否如老赵猜测那样。
收藏 0 赞 0 分享

implicitly convert type 'int' to 'short'的原因与解决方法

implicitly convert type 'int' to 'short'的原因与解决方法
收藏 0 赞 0 分享

比较完整的 asp.net 学习流程

好多朋友想学习后台编程语言,但请注意的事,学习后台是个循序渐进的过程,不可能一下就到位,其实不只是asp.net其它的编程语言都需要下面的一些知识。
收藏 0 赞 0 分享

官网 Ext direct包中.NET版的问题

下载了官网的 Ext direct 包进行研究,发现服务器端返回结果存在一点小问题。
收藏 0 赞 0 分享

C# XML操作 代码大全(读XML,写XML,更新,删除节点,与dataset结合等)第1/2页

C#操作XML(读XML,写XML,更新,删除节点,与dataset结合等),以下就是操作XML的所有方法,相信可以满足很大一部份的使用了。
收藏 0 赞 0 分享

c# 连接字符串数据库服务器端口号 .net状态服务器端口号

正常的数据库连接字符串配置,这是在MSSQL服务器端口是1433(默认)的情况下。
收藏 0 赞 0 分享

ASP.NET 路径问题的解决方法

相对路径和绝对路径在ASP.NET中可以用~/来解决.
收藏 0 赞 0 分享

asp.net TemplateField模板中的Bind方法和Eval方法

在TemplateField模板中为了能够有限制的或者取出数据库中某列的值时,可以用Bind和Eval方法来实现。以下是Bind方法的格式,Eval的格式也是和Bind一样的。 Bind("列的名称","显示的格式文")
收藏 0 赞 0 分享
查看更多