C#如何生成帶二維碼的專屬微信公眾號推廣海報-創新互聯

這篇文章主要介紹了C#如何生成帶二維碼的專屬微信公眾號推廣海報,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創新互聯從2013年開始,是專業互聯網技術服務公司,擁有項目成都網站設計、網站制作網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元瑞金做網站,已為上家服務,為瑞金各地企業和個人服務,聯系電話:18982081108

效果如下:

C#如何生成帶二維碼的專屬微信公眾號推廣海報

代碼實現:

1.獲取臨時二維碼ticket

 /// <summary>
 /// 獲取臨時二維碼ticket
 /// </summary>
 /// <param name="scene_str">場景值ID openid做場景值ID</param>
 /// <returns></returns>
 public static string CreateTempQRCode(string scene_str,string access_token)
 {
  var result = HttpUtility.SendPostHttpRequest($"https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token={access_token}", "application/json", "{\"expire_seconds\": 2592000, \"action_name\": \"QR_STR_SCENE\", \"action_info\": {\"scene\": {\"scene_str\": \"" + scene_str + "\"}}}");

  JObject jobect = (JObject)JsonConvert.DeserializeObject(result);

  string ticket = (string)jobect["ticket"];

  if (string.IsNullOrEmpty(ticket))
  {
   LogHelper.WriteLog(typeof(WeixinHelper), "獲取臨時二維碼ticket失敗" + result);
   return null;
  }
  return ticket;
 }

使用openid作為場景值的好處是通過掃A推廣的二維碼關注用戶的場景值便是A的openid。

2. 生成帶二維碼的專屬推廣圖片

 /// <summary>
 /// 生成帶二維碼的專屬推廣圖片
 /// </summary>
 /// <param name="user"></param>
 /// <returns></returns>
 public string Draw(WxUser user)
 {
  //背景圖片
  string path = Server.MapPath("/Content/images/tg.jpg");

  System.Drawing.Image imgSrc = System.Drawing.Image.FromFile(path);

  //處理二維碼圖片大小 240*240px
  System.Drawing.Image qrCodeImage = ReduceImage("https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket="+user.ticket, 240, 240);

  //處理頭像圖片大小 100*100px
  Image titleImage = ReduceImage(user.headimgurl, 100, 100);

  using (Graphics g = Graphics.FromImage(imgSrc))
  {
   //畫專屬推廣二維碼
   g.DrawImage(qrCodeImage, new Rectangle(imgSrc.Width - qrCodeImage.Width - 200,
   imgSrc.Height - qrCodeImage.Height - 200,
   qrCodeImage.Width,
   qrCodeImage.Height),
   0, 0, qrCodeImage.Width, qrCodeImage.Height, GraphicsUnit.Pixel);

   //畫頭像
   g.DrawImage(titleImage, 8, 8, titleImage.Width, titleImage.Height);

   Font font = new Font("宋體", 30, FontStyle.Bold);

   g.DrawString(user.nickname, font, new SolidBrush(Color.Red), 110, 10);
  }
  string newpath = Server.MapPath(@"/Content/images/newtg_" + Guid.NewGuid().ToString() + ".jpg");
  imgSrc.Save(newpath, System.Drawing.Imaging.ImageFormat.Jpeg);
  return newpath;
 }


 /// <summary>
 /// 縮小/放大圖片
 /// </summary>
 /// <param name="url">圖片網絡地址</param>
 /// <param name="toWidth">縮小/放大寬度</param>
 /// <param name="toHeight">縮小/放大高度</param>
 /// <returns></returns>
 public Image ReduceImage(string url, int toWidth, int toHeight)
 {
  WebRequest request = WebRequest.Create(url);
  WebResponse response = request.GetResponse();
  Stream responseStream = response.GetResponseStream();

  Image originalImage = Image.FromStream(responseStream);
  if (toWidth <= 0 && toHeight <= 0)
  {
   return originalImage;
  }
  else if (toWidth > 0 && toHeight > 0)
  {
   if (originalImage.Width < toWidth && originalImage.Height < toHeight)
    return originalImage;
  }
  else if (toWidth <= 0 && toHeight > 0)
  {
   if (originalImage.Height < toHeight)
    return originalImage;
   toWidth = originalImage.Width * toHeight / originalImage.Height;
  }
  else if (toHeight <= 0 && toWidth > 0)
  {
   if (originalImage.Width < toWidth)
    return originalImage;
   toHeight = originalImage.Height * toWidth / originalImage.Width;
  }
  Image toBitmap = new Bitmap(toWidth, toHeight);
  using (Graphics g = Graphics.FromImage(toBitmap))
  {
   g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High;
   g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
   g.Clear(Color.Transparent);
   g.DrawImage(originalImage,
      new Rectangle(0, 0, toWidth, toHeight),
      new Rectangle(0, 0, originalImage.Width, originalImage.Height),
      GraphicsUnit.Pixel);
   originalImage.Dispose();
   return toBitmap;
  }
 }

3.將圖片上傳微信服務器,并發送給用戶

string imagePath = Draw(user);
         
string result = HttpUtility.UploadFile($"https://api.weixin.qq.com/cgi-bin/material/add_material?access_token={access_token}&type=image", imagePath);

JObject jObject = (JObject)JsonConvert.DeserializeObject(result);
         
string media_id = (string)jObject["media_id"];
if (!string.IsNullOrEmpty(media_id))
{
          
  string resxml = "<xml><ToUserName><![CDATA[" + xmlMsg.FromUserName + "]]></ToUserName><FromUserName><![CDATA[" + xmlMsg.ToUserName + "]]></FromUserName><CreateTime>" + nowtime + "</CreateTime><MsgType><![CDATA[image]]></MsgType><Image><MediaId><![CDATA[" + media_id + "]]></MediaId></Image></xml>";
  return resxml;
}
LogHelper.WriteLog(typeof(WechatController), "上傳專屬推廣圖片素材失敗" + result);

感謝你能夠認真閱讀完這篇文章,希望小編分享的“C#如何生成帶二維碼的專屬微信公眾號推廣海報”這篇文章對大家有幫助,同時也希望大家多多支持創新互聯成都網站設計公司,關注創新互聯成都網站設計公司行業資訊頻道,更多相關知識等著你來學習!

另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、網站設計器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

當前標題:C#如何生成帶二維碼的專屬微信公眾號推廣海報-創新互聯
地址分享:http://m.kartarina.com/article18/cdsdgp.html

成都網站建設公司_創新互聯,為您提供網站設計品牌網站設計做網站用戶體驗網站收錄小程序開發

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都seo排名網站優化
主站蜘蛛池模板: 国产乱妇无码大片在线观看| 韩国无码AV片在线观看网站| 亚洲AV无码XXX麻豆艾秋| 国产V亚洲V天堂无码久久久| 无码人妻精品一区二区三区久久 | 无码精品国产一区二区三区免费| 久久国产精品无码一区二区三区| 无码的免费不卡毛片视频| 亚洲精品无码久久久久去q| 无码区国产区在线播放| 精品无码黑人又粗又大又长| 特级无码毛片免费视频尤物| 国产精品一级毛片无码视频| 亚洲AV综合色区无码一二三区 | 午夜无码人妻av大片色欲| 亚洲精品无码专区久久久 | 五十路熟妇高熟无码视频| 色偷偷一区二区无码视频| 精品久久久久久无码人妻蜜桃| 亚洲av纯肉无码精品动漫| 人妻无码一区二区不卡无码av| 国产精品热久久无码av| 国产爆乳无码视频在线观看3| 亚洲Av无码国产一区二区| 久久水蜜桃亚洲av无码精品麻豆| 中文字幕无码日韩专区| 人妻无码人妻有码中文字幕| 无码毛片一区二区三区中文字幕| 精品人妻无码一区二区色欲产成人 | 亚洲国产综合无码一区| 亚洲毛片av日韩av无码| 国产精品成人无码免费| 国产精品无码一区二区三区不卡 | 精品无码人妻一区二区免费蜜桃| 久久久久亚洲AV无码专区桃色| 亚洲国产精品无码久久九九 | 国产亚洲精品无码成人| 免费看成人AA片无码视频吃奶| av无码aV天天aV天天爽| 亚洲区日韩区无码区| 波多野结衣AV无码久久一区|