本来是用的WCF,但是服务需要多种方式调用(后台+前端Ajax),最终局面就是我在WCF每个服务中都判断一下↓

            #region 解决接收不到Ajax中传来的参数...
            if (jsonParames == null && HttpContext.Current.Request.QueryString["参数"] != null)
                jsonParames = HttpContext.Current.Request.QueryString["参数"];
            else if (jsonParames == null && HttpContext.Current.Request.QueryString["参数"] == null)
                return JSON.Instance.ToJSON("{\"ret\":\"0\",\"msg\":\"参数为空.\"}");
            #endregion

但是Ajax中用QueryString传输数据的话,有长度限制。

找了下,还有人说可以用form来解决提交的

<form id='form0' method='POST' action='http://localhost:22377/api/Article_/Article_Update/' onsubmit = "set_v()">
<input id='id_v' type='hidden' value='value_default' name='jsonParames'/>
<input type="submit" value="XXX" class=""  />
</form>

不过提交完了之后直接就会将页面跳转到'action'所指向的页面。。。

最后还是决定再发布一个web api,然后用Ajax来解决

    <form id="form1">
        <div>
            ID:<input type="text" id="id_ID" />
            <br />
            <input type="button" value="POST" id="getPersons" />
        </div>
        <div id="ret">

        </div>
    </form>
    <script type="text/javascript">

    function set_v(){
    alert('set value!');
    var v = 'too long data .';
    document.getElementById("id_v").value = v;
    alert(document.getElementById("id_v").val());
    }

        $('#getPersons').click(function () {
            document.getElementById("ret").innerHTML = '';//清楚上次查询内容...
            var ID = $("#id_ID").val();
            $.ajax({
                type: 'POST',
                url: 'http://localhost:22377/api/Article_/Article_Update',//?jsonParames=' + jsonParames,
                //dataType: 'JSONP',//如果这行不注释请求的'type'就是GET,(哪怕第一行就规定了type:'POST')
                //contentType:"application/json; charset=utf-8;",//这行不注释说不允许跨域调用!!!
                data: {
                    "jsonParames": '{"id":"0"}'//jsonParames和web api中的参数名对应;
                },
                success: function (_data) {
                    alert(_data);
                    var info = eval('(' + _data + ')');
                    //alert(data);
                    var list = eval('(' + info.list + ')');
                    var fragment = document.createDocumentFragment();
                    $.each(list, function (i, field_list) {
                        $.each(field_list, function (i, field) {
                            var item = document.createElement("li");
                            item.appendChild(document.createTextNode('[' + i + ']' + '...' + field));
                            fragment.appendChild(item);
                            //alert(i + "...is..." + field);
                        })
                    })
                    $("#ret").append(fragment);
                },
                error: function () { }
            });
        });

    </script>

web api 中;

        [HttpPost, HttpGet]
        public string Article_Update([FromBody]string jsonParames)
        {

            if (string.IsNullOrEmpty(jsonParames) || jsonParames.ToLower() == "jsonparames")
            {

                jsonParames = System.Web.HttpContext.Current.Request.Form["jsonParames"];

            }
            return "xx";
}

用Ajax调用web api,解决URL太长的问题;的更多相关文章

  1. 开发程序过程中遇到的调用Web Api小问题

    在用Umbraco Web Api开发程序时,前端使用React调用Web Api 当时是有一个页面Search.cshtml,把用React产生的脚本代码,在这个页面进行引用 写了一个Api, 调用 ...

  2. ASP.NET MVC4中调用WEB API的四个方法

    http://tech.it168.com/a2012/0606/1357/000001357231_all.shtml [IT168技术]当今的软件开发中,设计软件的服务并将其通过网络对外发布,让各 ...

  3. WebApi系列~通过HttpClient来调用Web Api接口

    回到目录 HttpClient是一个被封装好的类,主要用于Http的通讯,它在.net,java,oc中都有被实现,当然,我只会.net,所以,只讲.net中的HttpClient去调用Web Api ...

  4. 通过HttpClient来调用Web Api接口

    回到目录 HttpClient是一个被封装好的类,主要用于Http的通讯,它在.net,java,oc中都有被实现,当然,我只会.net,所以,只讲.net中的HttpClient去调用Web Api ...

  5. ajax调用.net API项目跨域问题解决

    ajax调用.net API项目,经常提示跨域问题.添加如下节点代码解决:httpProtocol <system.webServer> <handlers> <remo ...

  6. jQuery跨域调用Web API

    我曾经发表了一篇关于如何开发Web API的博客,链接地址:http://www.cnblogs.com/guwei4037/p/3603818.html.有朋友说开发是会开发了,但不知道怎么调用啊? ...

  7. Identity Server 4 从入门到落地(五)—— 使用Ajax访问Web Api

    前面的部分: Identity Server 4 从入门到落地(一)-- 从IdentityServer4.Admin开始 Identity Server 4 从入门到落地(二)-- 理解授权码模式 ...

  8. Http下的各种操作类.WebApi系列~通过HttpClient来调用Web Api接口

    1.WebApi系列~通过HttpClient来调用Web Api接口 http://www.cnblogs.com/lori/p/4045413.html HttpClient使用详解(java版本 ...

  9. React Native教程 - 调用Web API

    react-native官网Fetch介绍:https://facebook.github.io/react-native/docs/network.html#content react-native ...

随机推荐

  1. swfupload 上传控件的配置

    第一:下载swfupload控件,点击下载: 第二,解压缩后,在项目中添加这四个文件,如图: 然后,在你的js文件中添加这段代码: /** * *定义swfupload配置文件对象 **/ var s ...

  2. hdu 1403 Longest Common Substring(最长公共子字符串)(后缀数组)

    http://acm.hdu.edu.cn/showproblem.php?pid=1403 Longest Common Substring Time Limit: 8000/4000 MS (Ja ...

  3. 随机产生字母a--z, A-Z 的任意组合

    VERSION 1.0    引自: http://www.coderanch.com/t/134491/Security/generating-secure-tokens package demo; ...

  4. RWD

    http://webdesignerwall.com/tutorials/responsive-design-with-css3-media-queries http://www.webdesigns ...

  5. eCos驱动分析 之 ISR是如何与硬件中断联系起来的?

    http://keendawn.blog.163.com/blog/static/8888074320116205833478/

  6. SPRING IN ACTION 第4版笔记-第四章ASPECT-ORIENTED SPRING-002-AOP术语解析

    一. 1.Advice Advice是切面的要做的操作,它定义了what.when(什么时候要做什么事) aspects have a purpose—a job they’re meant to d ...

  7. /etc/passwd 结构

    命令:cat /etc/passwd username:password:uid:gid:allname:homedir:shell 用户名:密码:用户ID:组ID:用户全名:主目录:登录shell ...

  8. poj棋盘分割(记忆化)

    http://poj.org/problem?id=1191 黑书上P116 想了挺久 没想出来 想推出一公式来着 退不出来.. 想偏了  正解:递归 #include <iostream> ...

  9. Java 异常类层次结构

    在Java中,异常分为受检查的异常,与运行时异常. 两者都在异常类层次结构中. 下面的图展示了Java异常类的继承关系. 图1 粉红色的是受检查的异常(checked exceptions),其必须被 ...

  10. WPF——文本随滚动条改变而改变

    一.造一个窗体,拖进一个文本框TextBox和滚动条Slider 二.让文本框的内容随滚动条的滚动而改变,即文本框绑定到滚动条上 三.实现效果