Ajax跨域访问wcf服务中所遇到的问题总结。

工具说明:vs2012,sql server 2008R2

1.首先,通过vs2012建立一个wcf服务项目,建立好之后。再新开一个vs2012 建立web项目,通过jQuery的ajax方法访问服务。

   问题:由于web项目和wcf服务,不在同一个端口之中,所以涉及到“跨域”的问题。跨域访问的时候,需要对服务的接口和方法做一定的限定。具体参考:http://www.cnblogs.com/yangbingqi/p/2096197.html

 

2.解决了跨域问题,我们需要把服务部署到IIS。vs2012的部署比较简单,不赘述。

 

3.把wcf服务部署到IIS之后,在web端通过Ajax访问其ip地址,实现服务方法的调用。但是一直调用失败。方法如下:

public class Service1 : IService1

    {

        public string GetData(int value)

        {

            //return string.Format("You entered: {0}", value);

            return "{\"A\":"+"\""+value.ToString()+"\"}";

        }



        public CompositeType GetDataUsingDataContract(CompositeType composite)

        {

            if (composite == null)

            {

                throw new ArgumentNullException("composite");

            }

            if (composite.BoolValue)

            {

                composite.StringValue += "Suffix";

            }

            return composite;

        }



        BLL.UserClass uc = new BLL.UserClass();



        

        public string show_averageSalary_job(string city, string area)

        {

            //return "{\"A\":" + "\"" + city.ToString()+area.ToString() + "\"}";

            

            DataTable dt=new DataTable();

            try

            {

               dt = uc.show_averageSalary_job(city, area);

            }

            catch(Exception e)

            {

                return e.Message;

            }

            return DataTableConvertJson.DataTable3Json(dt);

        }

    }

    S1.起初调用show_averageSalary_job这个方法,一直调用失败。我怀疑可能的问题如下:

        1).wcf配置错误,wcf配置复杂,本人对此也不熟悉,不知其深浅,所以刚开始一致纠结于是否为wcf配置在IIS中有问题。

        2)请求数据和返回数据的格式问题。网上看到别人说,json和jsonp格式不同,远程调用只能用jsonp。我也纠结于此。最后证明:json和jsonp在get请求下都是ok的。

        3)网上求助。一位热心人说:让我看F12下,控制台的输出,通过观察我发现每次请求时,请求都不返回任何的状态码。感觉很是困惑。

        4)查看IIS日志。刚开始没看出什么端倪。但是最后发现,日志记录了很多的信息,日志是可以监测IIS服务状态的非常重要的信息。

 

   S2.经过S1步骤,我还是没有发现任何问题,很是困惑。我随手尝试了远程访问GetData()这个方法,发现竟然是成功的!

        1)因为GetData()刚开始返回的数据为简单字符型(非json),而show_averageSalary_job()这个方法返回的是Json格式的,我又猜想有可能是数据格式的传输出现了问题。

         2)经过把GetData()同样返回Json类型的数据,再次远程调用发现也是ok的。证明数据格式不是出现问题的地方。那么问题很明显了,问题出现在uc.show_averageSalary_job这个方法调用上。

          3)我考虑到这个地方涉及到数据库访问,那么可能就是IIS必须要远程访问数据库吧,然后就把连接字符串从localhost改成了ip,配置了数据库允许远程连接。测试还是不行。

           4)最后,我猜想可能是字符串 是windows身份认证导致的,修改为sql server身份认证(user+pwd)登录。成功!终于抓出了这个深深的bug,折腾了整整一天。

      

 

收获:

  一。一般性收获

      1.熟悉了wcf服务在配置过程中的一些细节问题。

      2.熟悉了ajax跨域调用wcf的注意事项。

  二。.调试方面:

       1.要学会通过IIS日志,分析IIS服务器运行状况,分析程序bug;

       2.要学会控制变量,逐步尝试,最终锁定出现问题关键代码。(如本例在找问题的时候,通过GetData()排除了远程调用通信错误的可能性,通过尝试把GetData()返回json,拍出了传输数据格式错误的可能性,最后锁定了出问题的核心代码。)

       3.充分利用异常捕获机制,如当时在dt = uc.show_averageSalary_job(city, area);这个访问数据库的地方 一开始就添加这样的try catch语句,则可能能更快的定位到是由于数据库访问的问题而造成的。所以,异常捕获使用真的是技巧活。

 

   最后附上实例【我要下载

你可能感兴趣的:(AJAX跨域)