AJAX Call returning 404(Local) in IIS 7.5 but same works in other IIS

后端 未结 4 1838
傲寒
傲寒 2021-01-31 10:39

Am having the AJAX calls to my controller in my MVC Application

Controller/FunctionName



$.ajax({
        type: \"GET\",
        contentType: \"application/jso         


        
相关标签:
4条回答
  • 2021-01-31 11:14

    Just a complement of Darin's answer that if "the AJAX call is in a separate javascript file where you cannot use server side helpers", use a hidden field to store the url endpoint in the view:

    @Html.Hidden("URLEndpointName", Url.Action("FunctionName", "Controller"))
    

    and read that hidden field in your js:

    url: $("#URLEndpointName").val(),
    
    0 讨论(0)
  • 2021-01-31 11:20

    What I'd found on my setup of IIS7.5 is that the 'Handler Mapping' has a resource named 'OPTIONSVerbHandler' is not set in the right order hence return back as Unknown.

    This work for me where my localhost ajax was calling my network server, which has a different name, that it shouldn't give me a CORS issue, but it did and this was my solution.

    Open IIS and click on your server name on the left pane. On the right pane double-click 'Handler Mappings' in the middle pane. On the right pane, select 'View Ordered List'. From there find 'OPTIONSVerbHandler' and 'svc-ISAPI-4.0_32bit', move 'OPTIONSVerbHandler' up until it is above 'svc-ISAPI-4.0_32bit'.

    Make sure your 'handler' inside your ajax call does not have 'Access-Control-Allow-Origin' in it.

    0 讨论(0)
  • 2021-01-31 11:30

    You can use double dot in the url:

    $.ajax({
       url: '../ControllerName/ActionName',
       .......
    });
    
    0 讨论(0)
  • 2021-01-31 11:34

    That's normal. You have hardcoded the url to your controller action:

    url: '/Controller/FunctionName',
    

    If you deploy your application in a virtual directory in IIS the correct url should be:

    url: '/YourAppName/Controller/FunctionName',
    

    That's the reason why you should absolutely never hardcode urls in an ASP.NET MVC application but ALWAYS use url helpers to generate it:

    url: '@Url.Action("FunctionName", "Controller")',
    

    and if this AJAX call is in a separate javascript file where you cannot use server side helpers, then you could read this url from some DOM element that you are AJAXifying.

    For example let's suppose that you had an anchor:

    @Html.ActionLink("click me", "FunctionName", "Controller", null, new { id = "myLink" })
    

    that you AJAXify:

    $('#myLink').click(function() {
        $.ajax({
            url: this.href,
            contentType: 'application/json; charset=utf-8',
            type: 'GET',
            .
            .
            .
        )};    
        return false;
    });
    

    Notice how we are reading the url from the DOM element which was generated by a helper.

    Conclusion and 2 rules of thumb:

    • NEVER EVER hardcode an url in an ASP.NET MVC application
    • ABSOLUTELY ALWAYS use url helpers when dealing with urls in an ASP.NET MVC application
    0 讨论(0)
提交回复
热议问题