Jquery 

Image 标签转Base64方法:

 function getBase64Image(img) {
             var canvas = document.createElement("canvas");
             var theImage = new Image();
             theImage.src = img.attr("src");
             canvas.width = theImage.width;
             canvas.height = theImage.height;
             var ctx = canvas.getContext("2d");
             ctx.drawImage(theImage, 0, 0, theImage.width, theImage.height);
             var ext = theImage.src.substring(theImage.src.lastIndexOf(".") + 1).toLowerCase();
             var dataURL = canvas.toDataURL("image/" + ext);
             return dataURL;
         } 
View Code

 

使用:

web api:

处理图片数据:

            var Pic = context.Request.Form["Pic"];//键值对字符串 key-图片格式,value
            if (string.IsNullOrEmpty(Pic)) return "图片没找到";
              var imgStr = Pic.Split(',')[1];//base64
              string path = ConfigurationManager.AppSettings["UplaodPath"];//获取当前项目所在目录
              string ShowPath = ConfigurationManager.AppSettings["ShowPath"];//显示路径;
             //string suffix = "." + Pic.Split(',')[0].Split('/')[1].Split(';')[0] //文件的后缀名

             string name=时间戳+后缀名;//图片名字

           var imgStr = Pic.Split(',')[1];//base64
            string path = ConfigurationManager.AppSettings["UplaodPath"];//获取当前项目所在目录
            string ShowPath = ConfigurationManager.AppSettings["ShowPath"];//显示路径;
            //string suffix = "." + Pic.Split(',')[0].Split('/')[1].Split(';')[0] //文件的后缀名
            string strPath = path + name;
            ImgInfo img = new ImgInfo();
            img.Id = Guid.NewGuid().ToString("N");
            img.ImgId = Guid.NewGuid().ToString("N");
            img.ImgName = name;
            img.CreateDate = DateTime.Now;
            try
            {
                var connectionstr = @"Data Source=D:\ProJ\TestServiceIp\TestServiceIp\DB\TestImgBD.db3;Version=3;Journal Mode=WAL";
                int row = 0;
                string msg= string.Empty;
                 using (SQLiteConnection connection = new SQLiteConnection(connectionstr))
                {
                    if (connection.State != ConnectionState.Open)
                    {
                        connection.Open();
                    }
                    using (SQLiteCommand cmd = connection.CreateCommand())
                    {
                        DbTransaction trans = connection.BeginTransaction();//开始事务
                        cmd.CommandText = "insert into ImgTb(Id,ImgId,ImgName,CreateDate) values(@Id,@ImgId,@ImgName,@CreateDate)";
                        cmd.Parameters.Add(new SQLiteParameter("@Id", DbType.String));
                        cmd.Parameters.Add(new SQLiteParameter("@ImgId", DbType.String));
                        cmd.Parameters.Add(new SQLiteParameter("@ImgName", DbType.String));
                        cmd.Parameters.Add(new SQLiteParameter("@CreateDate", DbType.DateTime));
                        cmd.Parameters["@Id"].Value = img.Id;
                        cmd.Parameters["@ImgId"].Value = img.ImgId;
                        cmd.Parameters["@ImgName"].Value = img.ImgName;
                        cmd.Parameters["@CreateDate"].Value = img.CreateDate;
                        row = cmd.ExecuteNonQuery();
                        if (row > 0)
                        {
                            var success = ImageHelper.UpLoadImage(imgStr, path, strPath);
                            if (!success)
                            {
                                cmd.Dispose();
                                msg= "图片上传失败";
                            }
                            else
                            {
                                trans.Commit();//提交事务   如果上传图片也成功了那就提交事务
                                msg= "图片Path:" + ShowPath + name;
                            }
                        }
                        else
                        {
                            cmd.Dispose();
                            msg= "数据库添加图片失败";
                        }
                    }
                    connection.Close();
                    return msg;
                }
            }
            catch (Exception)
            {

                return "出错了";
            }

 

 

 

      /// <summary>
        /// 上传图片
        /// </summary>
        /// <param name="Base64Str">base64串</param>
        /// <param name="strPath">保存路径</param>
        /// <returns></returns>
        public bool UpLoadIma(string Base64Str, string strPath)
        {
            try
            {
                byte[] bit = Convert.FromBase64String(Base64Str);
                MemoryStream ms = new MemoryStream(bit);
                Bitmap bmp = new Bitmap(ms);
                bmp.Save(HttpContext.Current.Server.MapPath(strPath), ImageFormat.Jpeg);
                return true;
            }
            catch (Exception)
            {

                return false;
            }

        }

 

Type="file"  图片文件上传

<div class="fileWrap">
                    <input type="file" accept="image/gif,image/jpeg,image/jpg,image/png,image/svg" onchange="upImg(this)" />
                </div>
    function upImg(obj) {
        var imgFile = obj.files[0];
        var reader = new FileReader();
        reader.onload = (function (file) {
            return function (e) {
                $.ajax({
                    url: "api/Values/UploadImg",
                    type: "POST",
                    datatype: "Json",
                    data: { Pic: this.result, Name: imgFile.name },
                    success: function (data) {
                        $("#ImgPath").append("<p>" + data + "</p>");
                    },
                    error: function (xhr) { console.log(xhr.responseText) }
                });
            };
        })(imgFile);
        reader.readAsDataURL(imgFile);
    };

 

上传图片实施预览:

<div class="content clearFlex">
            <form action="" enctype="multipart/form-data">
                <div class="upImg clearFlex">
                    <div class="imgOnloadWrap"></div>
                    <div class="upWrap">
                        <div class="fileWrap">
                            <input type="file" accept="image/gif,image/jpeg,image/jpg,image/png,image/svg" onchange="upImg(this)"/>
                        </div>
                        <div class="imgWrap">
                            <img src="img/icon6.png" alt="" />
                        </div>
                    </div>
                </div>
            </form>
        </div>


       function upImg(obj){
            var imgFile = obj.files[0];
            console.log(imgFile);
            var img = new Image();
            var fr = new FileReader();

            

               //读取文件过程方法
                reader.onloadstart = function (e) {
                    console.log("开始读取....");
                }
                reader.onprogress = function (e) {
                    console.log("正在读取中....");
                }
                reader.onabort = function (e) {
                    console.log("中断读取....");
                }
                reader.onerror = function (e) {
                    console.log("读取异常....");
                            fr.onload = function(){

                  var htmlStr = '<div class="upWrap">';
                  htmlStr += '<div class="fileWrap">';
                  htmlStr += '<input type="file" accept="image/gif,image/jpeg,image/jpg,image/png,image/svg" onchange="upImg(this)"/>';
                  htmlStr += '</div>';
                  htmlStr += '<div class="imgWrap upedImg"><span class="deleteImg">X</span>';
                  htmlStr += '<img src="'+fr.result+'" alt="" />';
                  htmlStr += '</div>';
                  htmlStr += '</div>';
                 $('.imgOnloadWrap').append(htmlStr);
                 obj.value = '';
              }

               fr.readAsDataURL(imgFile);
     }
  /*-----------------------------删除图片------------------------------*/
          $(document).on('click','.upedImg .deleteImg',function(){
               //处理未来事件
               $(this).parent().parent().remove();
            })



 

-----2020年9月21更新  后台base64转图片格式

 //   --base64格式  js
  
string BaseStr='xxxxx'    --js格式的后半部分

byte[] bytes2 = Convert.FromBase64String(BaseStr);

 MemoryStream memStream = new MemoryStream(bytes2);
      
 Image img = Image.FromStream(memStream);
 this.pictureBox1.Image = img;

 

posted on 2019-01-02 15:22  FL0528  阅读(527)  评论(0)    收藏  举报