简单配置IIS 以及web service 实现js跨域

因为浏览器的安全模型,js 是不能跨域的。

解决的方法有以下几种:

1. 使用代理服务转发

2. 目前服务器添加:Access-Control-Allow-Origin

3. 使用jsonp

4. 使用iframe

。。。。。。。

其中使用代理服务器进行转发以及 服务器添加Access-Control-Allow-Origin 是比较方便的。

代理服务器一般选择nginx 或者类似的,可以在网上找到对应的配置。

目的服务器添加Access-Control-Allow-Origin  对于现有的应用时比较方便的,直接在目的服务器中添加对应的信息即可。

例子如下:

复制代码
public class App1 : System.Web.Services.WebService
{

[WebMethod]

public void HelloWorld()
{

Context.Response.ContentType = "application/json";
var text = "{\"name\":\"dalong\"}";
Context.Response.Write(text);

Context.Response.End();


}
}
复制代码

web service 站点的配置如下:

复制代码
<configuration>
<system.web>
<compilation debug="true" targetFramework="4.0" />

<webServices >

<protocols >

<add name="HttpGet"/>
<add name="HttpPost"/>
</protocols>
</webServices>
</system.web>

</configuration>
复制代码

IIS 服务器的配置如下:

Access-Control-Allow-Origin : *

对于 web service的方式可能会有其他的错误,需要在此添加以下信息:

Access-Control-Allow-Headers : Origin, X-Requested-With, Content-Type, Accept

上述配置也可以再 web.config 中配置

使用ajax 调用跨域的web  service 如下:

复制代码
 $.ajax({
                type: "GET",    
                
                url: "http://XXXXXXXXXXX/app.asmx/HelloWorld",  
                data: null,
                dataType: 'json',
                success: function (result) {     
                    alert(result.name);
                }
            });   
复制代码
 <system.webServer>
        <httpProtocol>
            <customHeaders>
                <add name="Access-Control-Allow-Origin" value="*" />
                <add name="Access-Control-Allow-Headers" value="Origin, X-Requested-With, Content-Type, Accept" />
            </customHeaders>
        </httpProtocol>
    </system.webServer>

希望对大家有帮助。

 

 

 

 

posted on   荣锋亮  阅读(862)  评论(0编辑  收藏  举报

编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2014-04-27 Linux 'XXXXXX' "is not in the sudoers file. This incident will be reported" 解决方法

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示