0

我在 asp.net 中有一个带有几个文本框的表单。我正在尝试使用 jquery ajax 将其中的值发布到服务器,但是遇到了问题。我使用 javascript encodeURIComponent 作为文本框的值,然后发布,但我看到 url 是自动编码的:

wanted result:
mylefturl/first%20name/last%20name

this is what's actually happenning:
mylefturl/first name/last name

所以我得到一个asp.net错误......

我的 JavaScript 代码:

var firstName = $("#SignupFirstName").val();
            var lastName = $("#SignupLastName").val();
            var email = $("#SignupEmail").val();
            var password = $("#SignupPassword").val();

            var url = '/Ajax/GetSignup/' + encodeURIComponent(firstName) + '/' + encodeURIComponent(lastName) + '/' + encodeURIComponent(email) + '/' + encodeURIComponent(password);
$.ajax({
                    url: u,
...

解决方案是什么?

4

1 回答 1

3

我建议您data在发送 AJAX 调用时使用该参数:

var firstName = $("#SignupFirstName").val(),
    lastName = $("#SignupLastName").val(),
    email = $("#SignupEmail").val(),
    password = $("#SignupPassword").val();

$.ajax({
    url: '/Ajax/GetSignup/',
    type: 'POST',
    data: { 
        firstName: firstName, 
        lastName: lastName, 
        email: email, 
        password: password 
    },
    success: function(result) {
        // TODO: process the results from the AJAX call
    }
});

现在 jQuery 将负责正确地对发送到服务器的值进行 url 编码。这些值将作为 POST 有效负载的一部分而不是 url 发送。这是确保它们正确到达服务器的最安全方法。我建议您避免使用用户输入的值作为 url 路径的一部分。看看下面的问题,了解如果你走这条路可能会遇到什么困难。

于 2011-11-06T13:18:58.233 回答