jQuery跨域调用WebService

jQuery跨域调用WebService举例
html:

<!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>jquery跨域调用WebService(getJson)</title>
    <style type="text/css">
        *
        {
            font: 12px 宋体;
            margin: 0px;
            padding: 0px;
        }
        body
        {
            padding: 5px;
        }
        #container .search
        {
            height: 20px;
        }
        #container .result
        {
            margin-top: 5px;
        }
        #txtUserName
        {
            float: left;
        }
        #btnSearch
        {
            float: left;
            margin: 0px 0px 0px 5px;
            width: 78px;
            height: 16px;
            text-align: center;
            line-height: 16px;
            background-color: #eee;
            border: solid 1px #BABABA;
            cursor: pointer;
        }
        #btnSearch:hover
        {
            width: 76px;
            height: 14px;
            line-height: 14px;
            background-color: #fff;
            border-width: 2px;
        }
        .mark
        {
            color: Blue;
        }
    </style>
    <script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
    <script type="text/javascript">
        //用户信息(全局)
        var userData = {
            //WebServices地址(GetUserList=方法名称,?jsoncallback=?--必须包含)
            requestUrl: "http://localhost:54855/PersonalServices.asmx/GetUserList?jsoncallback=?",
            //方法参数(用户名可用","分隔开来查询多个用户信息)
            requestParams: { userName: null },
            //回调函数
            requestCallBack: function (json) {
                if (json.ResponseStatus == 1) {//成功获取数据
                    var addRow = function (key, value) {
                        return "<span>" + key + ":</span><span class=\"mark\">" + value + "</span><br/>";
                    }
                    userData.resultData = json.ResponseData;
                    var resultHtml = "";
                    $(userData.resultData).each(function () {
                        resultHtml += addRow("姓名", this.Name);
                        resultHtml += addRow("年龄", this.Age);
                        resultHtml += addRow("性别", this.Sex);
                        resultHtml += addRow("备注", this.Remark);
                        resultHtml += "<br/>";
                    });
                    $(".result").html(resultHtml);
                } else $(".result").html(json.ResponseDetails); //无数据或者后台处理失败!
            },
            //查询得到的数据
            resultData: null
        };
        $(function () {
            //绑定文本框的键盘事件
            $("#txtUserName").keyup(function () {
                if ($.trim($(this).val()) == "") {
                    $(".result").html("请输入查询用户名!");
                } else {
                    userData.requestParams.userName = $(this).val();
                    $(".result").html("");
                }
            });
            //绑定查询按钮单机事件
            $("#btnSearch").click(function () {
                if (userData.requestParams.userName) {
                    $.getJSON(userData.requestUrl, userData.requestParams, userData.requestCallBack);
                }
            });
        });
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div id="container">
        <div class="search">
            <input type="text" id="txtUserName" /><div id="btnSearch">
                查 询</div>
        </div>
        <div class="result">
        </div>
    </div>
    </form>
</body>
</html>

WebServices.cs

using System;
using System.Collections.Generic;
using System.Web;
using System.Web.Services;
#region 命名空间

using Newtonsoft.Json;

#endregion

namespace WebService
{
    /// <summary>
    /// PersonalServices 的摘要说明
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    [System.ComponentModel.ToolboxItem(false)]
    public class PersonalServices : System.Web.Services.WebService
    {
        #region 获取用户信息

        [WebMethod]
        public void GetUserList(string userName)
        {
            List<Personal> m_PersonalList = new List<Personal>();
            string[] strArr = userName.Split(‘,‘);
            foreach (string item in strArr)
            {
                Personal m_Personal = GetUserByName(item);
                if (m_Personal != null)
                {
                    m_PersonalList.Add(m_Personal);
                }
            }
            ResponseResult responseResult = new ResponseResult();
            if (m_PersonalList.Count == 0)
            {
                responseResult.ResponseDetails = "没有查到该用户!";
                responseResult.ResponseStatus = 0;
            }
            else
            {
                responseResult.ResponseData = m_PersonalList;
                responseResult.ResponseDetails = "查询用户信息成功!";
                responseResult.ResponseStatus = 1;
            }
            string jsoncallback = HttpContext.Current.Request["jsoncallback"];
            //返回数据的方式
            //  其中将泛型集合使用了Json库(第三方序列json数据的dll)转变成json数据字符串
            string result = jsoncallback + "(" + JsonConvert.SerializeObject(responseResult, Formatting.Indented) + ")";
            HttpContext.Current.Response.Write(result);
            HttpContext.Current.Response.End();
        }

        #endregion

        #region 模拟数据库处理结果

        /// <summary>
        /// 根据用户名查询用户
        /// </summary>
        /// <param name="userName">用户名</param>
        /// <returns></returns>
        Personal GetUserByName(string userName)
        {
            List<Personal> m_PersonalList = new List<Personal>();
            m_PersonalList.Add(new Personal()
            {
                Id = "01",
                Name = "liger_zql",
                Sex = "男",
                Age = 21,
                Remark = "你猜......"
            });
            m_PersonalList.Add(new Personal()
            {
                Id = "02",
                Name = "漠然",
                Sex = "女",
                Age = 22,
                Remark = "猜不透......"
            });
            foreach (Personal m_Personal in m_PersonalList)
            {
                if (m_Personal.Name == userName)
                {
                    return m_Personal;
                }
            }
            return null;
        }

        #endregion

        #region json数据序列化所需类

        /// <summary>
        /// 处理信息类
        ///     ResponseData--输出处理数据
        ///     ResponseDetails--处理详细信息
        ///     ResponseStatus--处理状态
        ///         -1=失败,0=没有获取数据,1=处理成功!
        /// </summary>
        class ResponseResult
        {
            public List<Personal> ResponseData { get; set; }
            public string ResponseDetails { get; set; }
            public int ResponseStatus { get; set; }
        }

        /// <summary>
        /// 用户信息类
        /// </summary>
        class Personal
        {
            public string Id { get; set; }
            public string Name { get; set; }
            public int Age { get; set; }
            public string Sex { get; set; }
            public string Remark { get; set; }
        }

        #endregion
    }
}

WebService项目配置文件

<system.web>
    <!--提供Web服务访问方式-->
    <webServices>
      <protocols>
        <add name="HttpSoap"/>
        <add name="HttpPost"/>
        <add name="HttpGet"/>
        <add name="Documentation"/>
      </protocols>
    </webServices>
</system.web>

由于使用jquery.getJson的方式调用Web服务后,传递中文时会造成中文乱码问题:

所以在配置文件中应配置如下内容:

<system.web>
    <!-- 设定传参乱码问题 -->
    <globalization fileEncoding="utf-8" requestEncoding="utf-8" responseEncoding="utf-8"/>
</system.web>

调用截图如下:

最后附上源码:JqCrossDomain.zip

时间: 2024-12-17 02:50:13

jQuery跨域调用WebService的相关文章

jquery跨域调用wcf

使用jquery跨域调用wcf服务的时候会报如下错误 1 $.ajax({ 2 url: 'http://localhost:28207/Service1.svc/GetData', 3 method: 'get', 4 dataType: 'json', 5 data: { value: val }, 6 success: function (data) { 7 $("label").text("success: " + data); 8 }, 9 error:

Jquery跨域调用

今天在项目中须要做远程数据载入并渲染页面,直到开发阶段才意识到ajax跨域请求的问题,隐约记得Jquery有提过一个ajax跨域请求的解决方式,于是即刻翻出Jquery的API出来研究,发现JQuery对于Ajax的跨域请求有两类解决方式,只是都是仅仅支持get方式.各自是JQuery的 jquery.ajax jsonp格式和jquery.getScript方式. 什么是jsonp格式呢?API原文:假设获取的数据文件存放在远程server上(域名不同.也就是跨域获取数据),则须要使用json

Jquery跨域调用后台方法

//前端JS function CallHandlerByJquery() { var url = "http://" + window.location.hostname + "/Helper.ashx?FLAG=2&BIZINST_GUID=276259&callback=?&rand="+Math.random(); $.ajaxSettings.async = false; $.getJSON(url, function (data)

Jquery的跨域调用

JQuery1.2后getJSON方法支持跨域读取json数据,原理是利用一个叫做jsonp的概念.当然,究其本质还是通过script标签动态加载js,似乎这是实现真正跨域的唯一方法. getJSON的用法JQuery手册已经写得很详细,参考手册就可以了,很简单.需要指出的一点是getJSON利用的jsonp需要客户端与服务端作出配合. 客户端传递的URL里要包含callback变量,以形如callback=?的形式结尾.(jquery会随机生成一个字符串替换?传递给服务端) 服务端获取客户端传

jquery ajax跨域请求webservice

有种方式可以通过JSONP方式来请求 这里具体介绍如何通过修改配置文件来实体AJAX跨域请求WEBSERVICE WEBSERVICE的类声名 /// <summary> /// MobileService 的摘要说明 /// </summary> [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)

jquery ajax jsonp跨域调用实例代码

今天研究了AJAX使用JSONP进行跨域调用的方法,发现使用GET方式和POST方式都可以进行跨域调用,这里简单分享下,方便需要的朋友 客户端代码 复制代码 代码如下: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApp.WebForm1" %><!DOCTYPE html P

jquery ajax跨域请求webservice webconfig配置

jquery ajax跨域请求webservice web.config配置 <configuration> <system.web> <compilation debug="true" targetFramework="4.0" /> <webServices> <protocols> <add name="HttpGet"/> <add name="Htt

实现jquery.ajax及原生的XMLHttpRequest跨域调用WCF服务的方法

关于ajax跨域调用WCF服务的方法很多,经过我反复的代码测试,认为如下方法是最为简便的,当然也不能说别人的方法是错误的,下面就来上代码,WCF服务定义还是延用上次的,如: namespace WcfService1 { [ServiceContract] public interface IAddService { [OperationContract] [WebInvoke(Method="GET",RequestFormat=WebMessageFormat.Json, Resp

jquery中的jsonp跨域调用

                                                jquery jsonp跨域调用接口 原文地址:https://www.cnblogs.com/mahmud/p/10131599.html