【问题标题】:Call c# function on code behind from Ajax function在 Ajax 函数后面的代码上调用 c# 函数
【发布时间】:2017-07-31 17:21:45
【问题描述】:

我一直在尝试获取函数背后的代码,以获取加密的两个变量以作为查询字符串返回。但我一直没有成功。第一次尝试 Ajax。

所以,在后面的代码中我有这个方法:

[WebMethod]
public static string EncritaDados(string str, string str2)
{
    return  Verificacoes.EncryptString(str)+";"+ Verificacoes.EncryptString(str2);
}

在我的 ASP 中,我有这个(实现 facebook 登录):

function testAPI() {
        console.log('Welcome!  Fetching your information.... ');
        FB.api('/me?fields=name,email', function (response) {
            console.log('Successful login for: ' + response.name);
            Ajax(response.email, response.name)
        });
    }

    function Ajax(expressao1, expressao2) {
        $.ajax({
            url: 'login.aspx/EncritaDados',
            method: 'post',
            contentType:'application/json',
            data: '{str: ' + expressao1 + ', str2: ' + expressao2 + '}',
            dataType:'json',
            success: function (resp) {
                var strings = resp.d.split(";");
                window.location.href = 'login.aspx?email=' + strings[0] + '&nome=' + strings[1];
            },
            error: function () { }
        })
    }

在尝试 Ajax 之前,它可以工作,而无需尝试了解背后的代码。我是这样的:

    function testAPI() {
        console.log('Welcome!  Fetching your information.... ');
        FB.api('/me?fields=name,email', function (response) {
            console.log('Successful login for: ' + response.name);
            window.location.href = 'login.aspx?email=' + response.email+ '&nome=' + response.name;
        });
    }

我现在正在挠头。谁能帮我这个?我会很感激的。

编辑:我是这样理解的:

function testAPI() {
            console.log('Welcome!  Fetching your information.... ');
            FB.api('/me?fields=name,email', function (response) {
                console.log('Successful login for: ' + response.name);
                Ajax(response.email, response.name);
            });
        }

        function Ajax(expressao1, expressao2) {
            var request = { email: expressao1, nome: expressao2 }
            $.ajax({
                url: 'login.aspx/EncritaDados',
                method: 'post',
                contentType: 'application/json',
                data: JSON.stringify(request),
                dataType: 'json',
                success: function (resp) {
                    var strings = resp.d.split(";");
                    window.location.href = 'login.aspx?email=' + strings[0] + '&nome=' + strings[1];
                },
                error: function (error) { alert(error.status); }
            })

在后面的代码中:

[WebMethod]
public static string EncritaDados(string email, string nome)
{
    return Verificacoes.EncryptString(email) + ";" + Verificacoes.EncryptString(nome);
}

所以,基本上,我做了一些小改动,但由于数据字符串的格式不正确,它并没有做它应该做的事情。但我按照建议使用 JSON.stringify 对其进行了格式化,并且它起作用了。

【问题讨论】:

    标签: javascript c# jquery asp.net ajax


    【解决方案1】:

    您的 javascript 中有错误。 resp.d 而不是 resp.data:

    function testAPI() {
            console.log('Welcome!  Fetching your information.... ');
            FB.api('/me?fields=name,email', function (response) {
                console.log('Successful login for: ' + response.name);
                Ajax(response.email, response.name)
            });
        }
    
        function Ajax(expressao1, expressao2) {
            var requestObject = { str : expressao1, str2 : expressao2 }
            $.ajax({
                url: 'login.aspx/EncritaDados',
                method: 'post',
                contentType:'application/json',
                data: JSON.stringify(requestObject),
                dataType:'json',
                success: function (resp) {
                    var strings = resp.data.split(";");
                    window.location.href = 'login.aspx?email=' + strings[0] + '&nome=' + strings[1];
                },
                error: function () { }
            })
        }
    

    【讨论】:

    • RequestObject 对象在哪里?问题是,我希望将这两个名称和电子邮件传递给 c# 方法进行加密,然后返回它们。所以,我确实没有要传递的对象。
    • 编辑了我的回复以包含 RequestObject 类。您可以随意命名您的两个属性,只要确保在 C# 类和 javascript 对象中将它们命名为相同即可。
    • 我似乎无法让它工作。我知道它涉及到 Ajax 函数。我在那里放了一个警报,它就到了。但它似乎就止步于此。它似乎没有进入 $.ajax 函数...... :(
    • 它确实进入了函数,毕竟。但我得到一个内部服务器错误......我相信这是错误 500
    • 我一直在搞乱,我似乎无法用一个对象得到它。但是像我一样使用字符串,我做到了。基本上,它是 'resp.data.split(";");'那必须是'resp.d.split(";");'和你建议的'JSON.stringify(requestObject)'。我在主帖中发布了代码。请进行必要的更改,以便我接受您的回答。谢谢,顺便说一句。 :)
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-06-13
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多