前端图片上传的处理与后端的接收(c#)

前端上传图片数据

html 复制代码
                //上传图片的处理方法
                UpdateHeadSculpture() {
                    let self = this;
                    let file = $("#FileImg")[0].files[0];
                    let form = new FormData();
                    form.append("img", file);
                    form.append('context', 'example_context');
                    $.ajax({
                        url: '/UserInfoMation/UpdateHeadSculpture', // 上传文件的服务器端脚本
                        type: 'POST',
                        data: form,
                        processData: false,
                        contentType: false,
                        success: function (res) {
                            //上传成功的回调
                            if (res == "OK") {
                                self.loadData();
                            }
                            else {
                                alert(res);
                            }
                        }, error: function () {
                            // 未访问到服务器
                            alert('Request failed: 访问服务器失败!请稍后访问');
                        }
                    });
                },

c#后端处理前端传输过来的数据保存至服务器中

cs 复制代码
 //1.0得到上传过来的文件
            HttpFileCollectionBase fils = Request.Files;//得到上传过来的文件
            if (fils.Count > 0)
            {
                //文件字节长度
                if (fils[0].ContentLength > 0)
                {
                    //2.0上传图片或要将图片的名称做一个修改(不能重复)
                    string oldName = fils[0].FileName;
                    //得到当前文件名称后缀
                    string exName = Path.GetFileName(oldName);
                    //生成一个永不重复的名称
                    string newName = Guid.NewGuid() + exName;
                    //获取用户ID
                    int Id = (Session["UserInfo"] as UserInfo).Id;
                    using (System.Drawing.Image img = System.Drawing.Image.FromStream(fils[0].InputStream))
                    {
                        img.Save(Server.MapPath("/img/") + newName);
                        //将数据库中数据对应对象的图片名称改为当前图片名称
                        //1.1根据id得到上传图片对象的数据(将修改后的图片数据传输至数据库)
                        if (userInfoBLL.UpdateHeadSculpture(Id, "/img/" + newName))
                        {
                            //修改session中存储的用户信息
                            Session["UserInfo"] = userInfoBLL.SelectId(Id);
                            //上传成功
                            return Content("OK");
                        }
                        else
                        {
                            //上传失败
                            return Content("ON");
                        }
                    }
                }

                else
                {
                    //上传失败
                    return Content("ON");
                }
            }
            else
            {
                //未选择数据
                return Content("未选择数据");
            }
相关推荐
是大强6 分钟前
Electron 打包用 junction 代替 symlink
前端·javascript·electron
哈罗哈皮22 分钟前
trea也很强,我撸一个给你看(附教程)
前端·人工智能·微信小程序
就是个名称32 分钟前
echart绘制天顶图
linux·前端·javascript
福赖1 小时前
《C#反射机制》
开发语言·c#
arvin_xiaoting1 小时前
OpenClaw学习总结_II_频道系统_5:Signal集成详解
java·前端·学习·signal·ai agent·openclaw·signal-cli
向上的车轮1 小时前
熟悉C#如何转TypeScript?
开发语言·typescript·c#
哆啦A梦15881 小时前
统一返回包装类 Result和异常处理
java·前端·后端·springboot
saadiya~1 小时前
从插件冗余到极致流畅:我的 Vue 3 开发环境“瘦身”实录
前端·javascript·vue.js
我是唐青枫2 小时前
C#.NET ReaderWriterLockSlim 深入解析:读写锁原理、升级锁与使用边界
开发语言·c#·.net
Timer@2 小时前
LangChain 教程 03|快速开始:10 分钟创建第一个 Agent
前端·javascript·langchain