JQuery ajax 永远不会成功 运行

JQuery ajax success never run

我有这个 jquery 代码,将项目发送到控制器并从控制器下载,一切正常 下载没问题,我检查 Chrome 网络选项卡中的响应没问题。但成功函数在过程完成后永远不会 运行 。 (我已经在使用 async:false;

 $(document).on('click', '#baslat', function (e) {
    var token = $("#token").val();
    var islemler = [];
    var secililer = [];

    $.each($("input[class='cc']:checked"), function () {
        var islem = {};
        islem.IslemTuru = $(this).attr("id");
        islemler.push(islem);
    });
    $.each($("tr[class='sec']"), function () {
        if ($(this).children('td:eq(1)').children("input[type='checkbox']").prop('checked')) {
            var beyan = {};
            beyan.Id = $(this).attr("id");
            beyan.TahakkukId = $(this).data("id");
            beyan.KisaKod = $(this).children('td:eq(2)').html();
            beyan.BeyannameTuru = $(this).children('td:eq(4)').html();
            beyan.Ay = $(this).children('td:eq(5)').html().substring(8, 10);
            beyan.Yil = $(this).children('td:eq(5)').html().substring(11, 16);
            secililer.push(beyan);
        }
    });
    $.ajax({
        url: '/Ebeyan/BeyanAl',
        type: "POST",
        dataType: "string",
        async: false,
        contentType: 'application/json; charset=utf-8',            
        data: JSON.stringify({ secililer, islemler, token }),
        success: function (data) {
            $("#mesaj").html(data);
            alert("done.");
        }
    });
});

控制器来了。我必须在方法中使用 Thread.Sleep (1000)。因为我要下载文件的服务器希望在每个请求之间传递 1 秒。

 public async Task<string> BeyanAl(List<Beyanname> secililer, List<Islem> islemler, string token)
    {
        bool indir = true;
        bool yazdir = false;
        bool gonder = false;
        foreach (var islem in islemler)
        {
            if (islem.IslemTuru =="cbyazdir")
            {
                yazdir = true;
            }
            if (islem.IslemTuru  == "cbgonder")
            {
                gonder= true;
            }
        }
        foreach (var GelenBeyan in secililer)
        {
            string YolAdi = YolHazirla(GelenBeyan);
            string DosyaAdi = DosyaAdiHazirla(GelenBeyan);
            await dosyaindir(token, YolAdi + "/" + DosyaAdi, "Beyan", GelenBeyan.Id, "");
            await dosyaindir(token, YolAdi + "/" + DosyaAdi, "Tahakkuk", GelenBeyan.Id, GelenBeyan.TahakkukId);
        }
        return "İndirildi";
    }

这里是 chrome 响应屏幕 r1 r2

ajax 数据类型中没有 'string' 数据类型使其成为 json 或文本

$.ajax({
    url: '/Ebeyan/BeyanAl',
    type: "POST",
    dataType: "string", <-- make it json or text
    async: false,
    contentType: 'application/json; charset=utf-8',            
    data: JSON.stringify({ secililer, islemler, token }),
    success: function (data) {
        $("#mesaj").html(data);
        alert("done.");
    }
});