【问题标题】:Error 404 in working with post actions on asp.net mvc 5 in IIS 8.5在 IIS 8.5 中处理 asp.net mvc 5 上的发布操作时出现错误 404
【发布时间】:2015-05-10 13:20:38
【问题描述】:

我对具有 POST 属性的操作有疑问。 当我使用 IIS Express Server 时,一切正常,但是当我使用本地 IIS 时,GET 操作工作正常,当在我的 Web 应用程序中调用 post 操作时,出现以下错误:

HTTP 错误 404.0 - 未找到 您要查找的资源已被删除、名称已更改或暂时不可用。

例如 CallController 中的这个动作:

[HttpPost]
    public PartialViewResult Connecting(FarakhanModels fara)
    {
        try
        {
            fara.IP = fara.IP.Trim();
            IPAddress IP = IPAddress.Parse(fara.IP);

            socket = new Socket(AddressFamily.InterNetwork,
            SocketType.Stream,
            ProtocolType.Tcp);

            socket.Connect(IP, fara.Port);

            fara.IsConnected = true;
        }
        catch (Exception ex)
        {
            fara.ErrorMessage = ex.Message;
            fara.IsConnected = false;
        }

        return (PartialView(viewName: "_Partial_Connect", model: fara));
    }

用这种观点:

<h4>Call group</h4>
<hr />
<div id="connect">
    <div id="loading">
        <img src="~/Images/ajax-loader.gif" title="loading" />
        Loading... Please Wati !
</div>

<br />

<div class="col-md-9 col-sm-9">
    <span class="col-md-3">Connect to server:</span>
    <input type="search" id="ip" />
</div>

<br />
<br />

<div class="col-md-9 col-sm-10">
    <span class="col-md-3 col-sm-3">Port:</span>
    <input type="search" id="port" />
</div>

<br />
<br />
<br />

<div class="col-md-2 col-md-offset-3">
    <button type="button" class="btn-primary" id="btnConnect">Connect</button>
    @*<input type="button" id="btnConnect" name="btnConnect" value="Connect" style="width:120px" />*@
</div>
<div class="col-md-12" id="message">

</div>


<br />
<br />

@section Scripts {
<script>
    $(document).ready(function () {
        $("div#loading").hide();
        $("div#call").hide();

        $("button#btnConnect").click(function () {
            $("div#message").html("");

            $("div#loading").show();
            $("button#btnConnect").hide();

            var varIp = $("input#ip").val();
            var varPort = $("input#port").val();

            var varData =
                {
                    ip: varIp,
                    port: varPort,
                };

            $.ajax({
                type: "POST",
                dataType: "html",
                data: varData,
                url: "/Call/Connecting",
                error: function (response) {
                    $("div#message").html(response.error.toString());
                },

                success: function (response) {
                    $("input#ip").val("");
                    $("input#port").val("");

                    $("div#call").show();
                    $("div#connect").hide();
                    $("div#partialView").html(response);
                },

                complete: function (response) {
                    $("div#loading").hide();
                    $("button#btnConnect").show();
                }

            })
        })
    })
</script>

    }

当我点击连接按钮时,Ajax 没有找到 Url:/Call/Connecting

【问题讨论】:

    标签: c# asp.net asp.net-mvc iis


    【解决方案1】:

    我怀疑是 ajax 调用中使用的 url:

    url: "/Call/Connecting" 
    

    它来自根路径。如果您将应用程序部署在“/Call”不是根的环境中,您会得到 404。例如,如果您将应用程序部署在 http://example.com/my_cool_app。那么 url 应该是“/my_cool_app/Call/Connecting”。我建议使用 Url.Action 帮助器来动态构建您的操作端点,而不是硬编码。

    【讨论】:

    • 谢谢,非常有帮助。我使用了 '@Url.Action("Connecting","Call")' 并且成功了!
    猜你喜欢
    • 1970-01-01
    • 2015-06-07
    • 2016-07-27
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-09-11
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多