前端: 微信开发者工具

后端:.Net

服务器:阿里云

这里介绍微信小程序如何实现上传图片到自己的服务器上

前端代码

  1. data: {
  2. productInfo: {}
  3. },
  4. //添加Banner
  5. bindChooiceProduct: function () {
  6. var that = this;
  7.  
  8. wx.chooseImage({
  9. count: 3, //最多可以选择的图片总数
  10. sizeType: ['compressed'], // 可以指定是原图还是压缩图,默认二者都有
  11. sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
  12. success: function (res) {
  13. // 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
  14. var tempFilePaths = res.tempFilePaths;
  15. //启动上传等待中...
  16. wx.showToast({
  17. title: '正在上传...',
  18. icon: 'loading',
  19. mask: true,
  20. duration: 10000
  21. })
  22. var uploadImgCount = 0;
  23. for (var i = 0, h = tempFilePaths.length; i < h; i++) {
  24. wx.uploadFile({
  25. url: util.getClientSetting().domainName + '/home/uploadfilenew',
  26. filePath: tempFilePaths[i],
  27. name: 'uploadfile_ant',
  28. formData: {
  29. 'imgIndex': i
  30. },
  31. header: {
  32. "Content-Type": "multipart/form-data"
  33. },
  34. success: function (res) {
  35. uploadImgCount++;
  36. var data = JSON.parse(res.data);
  37. //服务器返回格式: { "Catalog": "testFolder", "FileName": "1.jpg", "Url": "https://test.com/1.jpg" }
  38. var productInfo = that.data.productInfo;
  39. if (productInfo.bannerInfo == null) {
  40. productInfo.bannerInfo = [];
  41. }
  42. productInfo.bannerInfo.push({
  43. "catalog": data.Catalog,
  44. "fileName": data.FileName,
  45. "url": data.Url
  46. });
  47. that.setData({
  48. productInfo: productInfo
  49. });
  50.  
  51. //如果是最后一张,则隐藏等待中
  52. if (uploadImgCount == tempFilePaths.length) {
  53. wx.hideToast();
  54. }
  55. },
  56. fail: function (res) {
  57. wx.hideToast();
  58. wx.showModal({
  59. title: '错误提示',
  60. content: '上传图片失败',
  61. showCancel: false,
  62. success: function (res) { }
  63. })
  64. }
  65. });
  66. }
  67. }
  68. });
  69. }

后端上传代码(将文件上传到服务器临时文件夹内)

  1. [HttpPost]
  2. public ContentResult UploadFileNew()
  3. {
  4. UploadFileDTO model = new UploadFileDTO();
  5. HttpPostedFileBase file = Request.Files["uploadfile_ant"];
  6. if (file != null)
  7. {
  8. //公司编号+上传日期文件主目录
  9. model.Catalog = DateTime.Now.ToString("yyyyMMdd");
  10. model.ImgIndex = Convert.ToInt32(Request.Form["imgIndex"]);
  11.  
  12. //获取文件后缀
  13. string extensionName = System.IO.Path.GetExtension(file.FileName);
  14.  
  15. //文件名
  16. model.FileName = System.Guid.NewGuid().ToString("N") + extensionName;
  17.  
  18. //保存文件路径
  19. string filePathName = System.IO.Path.Combine(CommonHelper.GetConfigValue("ImageAbsoluteFolderTemp"), model.Catalog);
  20. if (!System.IO.Directory.Exists(filePathName))
  21. {
  22. System.IO.Directory.CreateDirectory(filePathName);
  23. }
  24. //相对路径
  25. string relativeUrl = CommonHelper.GetConfigValue("ImageRelativeFolderTemp");
  26. file.SaveAs(System.IO.Path.Combine(filePathName, model.FileName));
  27.  
  28. //获取临时文件相对完整路径
  29. model.Url = System.IO.Path.Combine(relativeUrl, model.Catalog, model.FileName).Replace("\\", "/");
  30. }
  31. return Content(Newtonsoft.Json.JsonConvert.SerializeObject(model));
  32. }
  1. /// <summary>
  2. /// 上传文件 返回数据模型
  3. /// </summary>
  4. public class UploadFileDTO
  5. {
  6.     /// <summary>
  7.     /// 目录名称
  8.     /// </summary>
  9.     public string Catalog { set; get; }
  10.     /// <summary>
  11.     /// 文件名称,包括扩展名
  12.     /// </summary>
  13.     public string FileName { set; get; }
  14.     /// <summary>
  15.     /// 浏览路径
  16.     /// </summary>
  17.     public string Url { set; get; }
  18.     /// <summary>
  19.     /// 上传的图片编号(提供给前端判断图片是否全部上传完)
  20.     /// </summary>
  21.     public int ImgIndex { get; set; }
  22. }
  1. #region 获取配置文件Key对应Value值
  2. /// <summary>
  3. /// 获取配置文件Key对应Value值
  4. /// </summary>
  5. /// <param name="key"></param>
  6. /// <returns></returns>
  7. public static string GetConfigValue(string key)
  8. {
  9. return ConfigurationManager.AppSettings[key].ToString();
  10. }
  11. #endregion

设置配置文件上传文件对应的文件夹信息

  1. <appSettings>
  2. <!--图片临时文件夹 绝对路径-->
  3. <add key="ImageAbsoluteFolderTemp" value="D:\Images\temp" />
  4. <!--图片正式文件夹 绝对路径-->
  5. <add key="ImageAbsoluteFolderFinal" value="D:\Images\product" />
  6.  
  7. <!--图片临时文件夹 相对路径-->
  8. <add key="ImageRelativeFolderTemp" value="http://192.168.1.79:9009/temp"/>
  9. <!--图片正式文件夹 相对路径-->
  10. <add key="ImageRelativeFolderFinal" value="http://192.168.1.79:9009/product"/>
  11. </appSettings>

微信小程序--实现图片上传的更多相关文章

  1. [转]微信小程序实现图片上传功能

    本文转自:http://blog.csdn.net/feter1992/article/details/77877659 前端: 微信开发者工具 后端:.Net 服务器:阿里云 这里介绍微信小程序如何 ...

  2. nodeJs实现微信小程序的图片上传

    今天我来介绍一下nodejs如何实现保存微信小程序传过来的图片及其返回 首先wx.uploadFile绝大部分时候是配合wx.chooseImage一起出现的,毕竟选择好了图片,再统一上传是实现用户图 ...

  3. 微信小程序实现图片上传功能

    前端: 微信开发者工具 后端:.Net 服务器:阿里云 这里介绍微信小程序如何实现上传图片到自己的服务器上 前端代码 data: { productInfo: {} }, //添加Banner bin ...

  4. 微信小程序中图片上传阿里云Oss

    本人今年6月份毕业,最近刚在上海一家小公司实习,做微信小程序开发.最近工作遇到一个小问题. 微信小程序图片上传阿里云服务器Oss也折腾了蛮久才解决的,所以特意去记录一下. 第一步:配置阿里云地址: 我 ...

  5. 微信小程序实现图片上传,预览,删除

    wxml: <view class='imgBox'> <image class='imgList' wx:for="{{imgs}}" wx:for-item= ...

  6. 微信小程序 实现图片上传并展示到前端(多文件)并实现表单提交验证

    链接: https://blog.csdn.net/guanj0623/article/details/121595884?spm=1001.2014.3001.5501 https://blog.c ...

  7. 小程序实现图片上传,预览以及图片base64位处理

    最近一段时间在做小程序项目,第一期功也完工了.需要好好总结一下经验,把项目中遇到的问题好好总结一下,遇到的问题,踩过的坑.今天写一个小程序实现图片上传,预览,以及删除,图片base64位处理.下面就是 ...

  8. 微信小程序多张图片上传

    微信小程序上传图片每次只能上传一张,所有很多朋友就会问想要多张图片上传怎么办? 首先,我们来看一看wx.chooseImage(object)和wx.uploadFile(OBJECT)这两个个api ...

  9. 「小程序JAVA实战」小程序头像图片上传(上)(43)

    转自:https://idig8.com/2018/09/08/xiaochengxujavashizhanxiaochengxutouxiangtupianshangchuan40/ 在微信小程序中 ...

随机推荐

  1. Satisfying memory ordering requirements between partial reads and non-snoop accesses

    A method and apparatus for preserving memory ordering in a cache coherent link based interconnect in ...

  2. stm32的DMA重新工作

    下面是在战舰V3寄存器程序例子中找到的: //开启一次DMA传输void MYDMA_Enable(DMA_Channel_TypeDef*DMA_CHx){    DMA_CHx->CCR&a ...

  3. jquery ajax 请求时间

    $.ajax({ url:'JsLongPollingMsgServlet', type:'post', dataType:'json', data:{"pageMsgNum":$ ...

  4. Bash玩转脚本1之自己的脚本安装程序

    Bash之打造自己的脚本安装器 前言 还是理所当然的前言,我一直想找一套管理脚本的"框架",能让自己杂乱的脚本有点规整.无奈眼界尚浅,未能找到. 因此萌生自己写一点优化脚本的工具来 ...

  5. Android 节日短信送祝福(UI篇:3-选择短信与发送短信的Activity的实现)

    一.ChooseMsgActivity的实现 1.布局文件 <RelativeLayout xmlns:android="http://schemas.android.com/apk/ ...

  6. php 中英文字符串截取,字符串长度

    在做PHP开发的时候,由于我国的语言环境问题,所以我们常常需要对中文进行处理.在PHP中,我们都知道有专门的mb_substr和mb_strlen函数,可以对中文进行截取和计算长度,但是,由于这些函数 ...

  7. 【u012】数字游戏

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] 小W发明了一个游戏,他在黑板上写出了一行数字a1,a2,-an,然后给你m个回合的机会,每回合你可以从 ...

  8. 【19.46%】【codeforces 551B】ZgukistringZ

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  9. Net Core 实现谷歌翻译ApI 免费版

    原文:Net Core 实现谷歌翻译ApI 免费版 由于谷歌翻译官方API是付费版本,本着免费和开源的精神.分享一下用 Net Core 实现谷歌翻译API的代码. 项目引用的Nuget 包: Cha ...

  10. Android 自定义View——自定义点击事件

    每个人手机上都有通讯录,这是毫无疑问的,我们通讯录上有一个控件,在通讯录的最左边有一列从”#”到”Z”的字母,我们通过滑动或点击指定的字母来确定联系人的位置,进而找到联系人.我们这一节就通过开发这个控 ...