前端图片上传的处理与后端的接收(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("未选择数据");
            }
相关推荐
爱勇宝2 小时前
我给自己做了一个新标签页:不登录、不打扰、打开就能用
前端·html·浏览器
Ausra无忧3 小时前
记录在公司把单服务器升级成多服务器架构流程
前端·后端·架构
极客密码4 小时前
来看看我用Codex两周时间vibe coding的这款轻量级的剪贴板管理应用,win/mac系统均可用
前端·ai编程·vibecoding
前端双越老师4 小时前
Agent 实战: 智语 + baoyu-skills 自动发布文章到公众号
前端·agent·全栈
hunterandroid4 小时前
Jetpack Compose 入门:用声明式 UI 写 Android 页面
前端
以和为贵4 小时前
前端手写 RAG 踩坑实录:四个让检索"翻车"的坑
前端·人工智能·面试
用户2136610035724 小时前
Redux异步方案与React性能优化Hooks
前端
假如让我当三天老蒯4 小时前
TypeScript 继续学习(学习用)
前端·面试·typescript
玄玄子4 小时前
CSS 浮动引起父元素高度塌陷
前端·css
竹林8184 小时前
从 ethers.js 到 viem:我在一个 DeFi 看板项目中踩过的所有坑与最终方案
前端·javascript