ASP.NET MVC-异步发送post请求+文件下载

环境:

win10, .NET 6.0


前端向后台传递string型变量

前端:

javascript 复制代码
    function PasteSubmit() {
    	// 获取某个input的值
        var inName = document.getElementById("xx").value;
        // 获取某个元素的属性值
        var inSeq = document.getElementById("xxx").getAttribute("xxx");
        $.ajax({
            type: 'POST',
            url: "/Home/PasteSubmit",
            data: {
                inName: inName,
                inSeq: inSeq,
            },
            success: function (resp) {
            	console.log(resp);
            }
        });
    }

后台:(HomeController)

csharp 复制代码
[HttpPost]
public ActionResult PasteSubmit() {
    // 获取数据
    string name = Request.Form["inName"]; 
    string seq = Request.Form["inSeq"];
    System.Diagnostics.Trace.WriteLine(name);
    System.Diagnostics.Trace.WriteLine(seq);
    // do something
    // 返回的内容
    return Content("test");
}

前台向后台传递多个List

说明:先传递三个List,后台接收后做一些处理,然后回传字符串,将字符串写入文件,生成下载文件,自动下载。

前端:

html 复制代码
@{
// 定义
List<int> cstarts = new List<int>() { 1, 2, 3};
List<int> cends = new List<int>() { 4, 5, 6 };
List<string> cstrs = new List<string>() { "", "sss", "x"};
}

<!-- html内容略 -->

<button id="exportSeqBtn" onclick="exportSeq()" type="button">
    导出序列
</button>

<!-- js -->
<script>
    // 导出序列
    function exportSeq() {
        var starts = @Html.Raw(Json.Encode(cstarts));
        var ends = @Html.Raw(Json.Encode(cends));
        var strs = @Html.Raw(Json.Encode(cstrs));
        $.ajax({
            url: "/Home/ExportSeq",
            method: 'POST',
            data: JSON.stringify({
                vid: @Model.Id,
                cstarts: starts,
                cends: ends,
                cstrs: strs,
            }),
            contentType: 'application/json; charset=utf-8',
            success: function (data) {
                var blob = new Blob([data], { type: 'text/plain' });
                var link = document.createElement('a');
                link.href = window.URL.createObjectURL(blob);
                link.download = 'sequence.fa'; // 下载文件的文件名
                link.click();
            },
            error: function (xhr, status, error) {
                alert('An error occurred while generating the file: ' + error);
            }
        });
    }
</script>

后端:

csharp 复制代码
[HttpPost]
public ActionResult ExportSeq(string vid, List<int> cstarts, List<int> cends, List<string> cstrs) {
	var txtContent = new StringBuilder();
    // do something
    txtContent.AppendLine(string.Join(",", cstarts));
    // 可以打印其他的看看
    return Content(txtContent.ToString(), "text/plain");
}
相关推荐
Victor3565 小时前
https://editor.csdn.net/md/?articleId=139321571&spm=1011.2415.3001.9698
后端
Victor3565 小时前
Hibernate(89)如何在压力测试中使用Hibernate?
后端
灰子学技术6 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
Gogo8167 小时前
BigInt 与 Number 的爱恨情仇,为何大佬都劝你“能用 Number 就别用 BigInt”?
后端
fuquxiaoguang7 小时前
深入浅出:使用MDC构建SpringBoot全链路请求追踪系统
java·spring boot·后端·调用链分析
毕设源码_廖学姐8 小时前
计算机毕业设计springboot招聘系统网站 基于SpringBoot的在线人才对接平台 SpringBoot驱动的智能求职与招聘服务网
spring boot·后端·课程设计
野犬寒鸦10 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
逍遥德10 小时前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
MX_935911 小时前
Spring的bean工厂后处理器和Bean后处理器
java·后端·spring
程序员泠零澪回家种桔子12 小时前
Spring AI框架全方位详解
java·人工智能·后端·spring·ai·架构