日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

二维码生成工厂

發(fā)布時(shí)間:2025/4/16 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 二维码生成工厂 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

本次主要分享的是3個(gè)免費(fèi)的二維碼接口的對(duì)接代碼和測(cè)試得出的注意點(diǎn)及區(qū)別,有更好處理方式多多交流,相互促進(jìn)進(jìn)步;最近在學(xué)習(xí)JavsScript的擴(kuò)展TypeScript,感覺語法糖很甜,大部分與C#更為類似,可能都是微軟項(xiàng)目的原因吧,有興趣的朋友可以多多相互交流下;

?

以上是個(gè)人的看法,下面來正式分享今天的文章吧:

. Google的Api二維碼生成接口

.?2d-code的Api二維碼生成接口

.?topscan的Api二維碼生成接口

.?使用面向?qū)ο?#43;加載程序集創(chuàng)建對(duì)象合并以上接口封裝成二維碼生成工廠

?

下面一步一個(gè)腳印的來分享:

. Google的Api二維碼生成接口

首先,這里給出Google接口文檔的鏈接qr_codes文檔,熱情的朋友馬上就會(huì)打開此鏈接吧,詳細(xì)看下里面的參數(shù)這就不做截圖了,大致通常用到的參數(shù)是:api地址,內(nèi)容參數(shù),生成圖片的高寬這3個(gè)參數(shù),其他的幾個(gè)參數(shù)都采用默認(rèn)的吧,不同需要大家可以更詳細(xì)的看下;其實(shí)第一次看到文檔里面的參數(shù),感覺少了一些東西,比如怎么不能傳遞二維碼中間那個(gè)圖標(biāo)的圖片地址和掃描二維碼過后怎么跳轉(zhuǎn)到我想重定向的url鏈接呢,帶著這個(gè)疑問我進(jìn)行了多次的嘗試;下面給出自己嘗試的結(jié)果說明:

1.?接口關(guān)鍵參數(shù)是:cht(固定值qr),chl(內(nèi)容參數(shù)),chs(生成出來二維碼圖片尺寸,格式如:200x200,這里是xyz的x不是*)

2. api接口只會(huì)生成一個(gè)二維碼的圖片流,如果需要把圖片保存到本地需要通過瀏覽器直接get訪問接口或者通過程序下載這個(gè)二維碼

3.?內(nèi)容參數(shù)如果傳遞文本信息,在生成出來的二維碼圖片中間不會(huì)顯示文本內(nèi)容,只有用手機(jī)掃描二維碼才能在手機(jī)上顯示傳遞的文本信息

4. 內(nèi)容參數(shù)如果傳遞單純的http://格式的鏈接地址,那么手機(jī)掃描后會(huì)自動(dòng)重定向到改http://鏈接地址上(這個(gè)掃描重定向可以用來做一些商品或者文章的查看)

5.?google接口暫未研究出此Logo圖標(biāo)地址參數(shù)(希望有朋友研究出來后與我分享,謝謝)

6. 由于api地址是國(guó)外的,調(diào)用接口響應(yīng)不是那么快速

其次,上面是個(gè)人的一些總結(jié),下面我們來看下封裝的請(qǐng)求接口方法和下載二維碼圖片方法:

1 #region 生成二維碼 2 3 /// <summary> 4 /// 生成二維碼 5 /// </summary> 6 /// <param name="content">展示內(nèi)容(文本內(nèi)容 或者 掃描后的跳轉(zhuǎn)http://格式的地址)</param> 7 /// <param name="savePath">保存二維碼的磁盤路徑(默認(rèn)程序跟目錄+QRCode)</param> 8 /// <param name="logoUrl"> Logo圖標(biāo)地址(格式:http://),(注:google接口暫未研究出此參數(shù))</param> 9 /// <param name="apiUrl">接口地址(內(nèi)置默認(rèn)api地址)</param> 10 /// <param name="wAndh">寬度和高度(二維碼正方形的,高寬一至,默認(rèn)200)</param> 11 /// <returns></returns> 12 public virtual string CreateQRCode(string content = null, string savePath = null, string logoUrl = null, string apiUrl = null, int? wAndh = null) 13 { 14 var qrName = string.Empty; 15 16 #region 參數(shù)初始化 17 18 ApiUrl = apiUrl ?? ApiUrl; 19 Content = content ?? Content; 20 SaveQRPath = savePath ?? SaveQRPath; 21 LogoUrl = logoUrl ?? LogoUrl; 22 WAndH = wAndh ?? WAndH; 23 #endregion 24 25 if (string.IsNullOrEmpty(ApiUrl)) { return qrName; } 26 27 ApiUrl = string.Format("{0}?cht=qr&chl={1}&chs={2}x{2}", 28 ApiUrl, 29 HttpUtility.UrlEncode(Content), 30 WAndH); 31 32 qrName = DownImg(ApiUrl, SaveQRPath, ImageFormat.Jpeg); 33 return qrName; 34 } 35 #endregion

下載二維碼圖片保存到程序根目錄:

1 #region 下載圖片 2 3 /// <summary> 4 /// 下載圖片 5 /// </summary> 6 /// <param name="url">圖片下載地址</param> 7 /// <param name="savePath">保存路徑默認(rèn):Img文件夾</param> 8 /// <param name="format">默認(rèn):Jpeg</param> 9 /// <returns>新圖片名稱</returns> 10 public virtual string DownImg(string url, string savePath = "QRCode", ImageFormat format = null) 11 { 12 var qrName = string.Empty; 13 try 14 { 15 format = format ?? ImageFormat.Jpeg; 16 17 HttpClient http = new HttpClient(); 18 http.Timeout = new TimeSpan(0, 1, 0); 19 using (var stream = http.GetStreamAsync(url).Result) 20 { 21 22 if (!Directory.Exists(SaveQRPath)) { Directory.CreateDirectory(SaveQRPath); } 23 qrName = DateTime.Now.ToString("yyyyMMddHHmmssfff") + "." + format; 24 var path = Path.Combine(savePath, qrName); 25 using (Image img = Image.FromStream(stream)) 26 { 27 img.Save(path, format); 28 } 29 } 30 } 31 catch (Exception ex) 32 { 33 qrName = string.Empty; 34 } 35 return qrName; 36 } 37 #endregion

上面兩個(gè)方法使用的是虛方法,因?yàn)槲疫@里是吧google接口當(dāng)做默認(rèn)的二維碼生成器來使用,后面要講的另外兩個(gè)接口都是重寫與此;下載圖片的方法都是公用的,暫不需要重寫;這里需要提到的是調(diào)用api接口時(shí)有一個(gè)固定的參數(shù)cht=qr,這個(gè)參數(shù)表示采用QR方法生成二維碼,因?yàn)檫@個(gè)api接口還有生成圖標(biāo)的功能,所以只想要生成二維碼這里就固定,更多的生成圖標(biāo)功能不在本章分享中,謝謝。

?

.?2d-code的Api二維碼生成接口

首先,該接口需要通過他們官網(wǎng)注冊(cè)一個(gè)key,然后從后臺(tái)獲取到這個(gè)key后才能調(diào)用接口地址,當(dāng)然注冊(cè)后有個(gè)功能是,凡是您通過api接口生成的二維碼,除了自己通過流下載,還能通過他們后臺(tái)一起下載所有生成的圖片,本人暫時(shí)沒有去關(guān)注是否生成量大了會(huì)收費(fèi)哈哈,下面列舉下接口參數(shù)說明和測(cè)試得出的注意點(diǎn):

1. 接口關(guān)鍵參數(shù)是:key(注冊(cè)獲取),text(文本參數(shù)),url(掃描后重定向地址),logo(Logo圖標(biāo)地址),size(二維碼正方形,高寬)

2. 接口的文本參數(shù)只能傳遞文本,不能當(dāng)做掃描后重定向的地址參數(shù)使用和Google等接口有點(diǎn)不一樣

3.?掃描后重定向地址和Logo圖標(biāo)地址都是可訪問的http://格式的地址鏈接

4.?Logo圖標(biāo)地址,官方說不建議使用png格式,測(cè)試只有jpg成功(可能是測(cè)試不夠多這里只單純介紹我的結(jié)果)

5. 生成速度比較快,而且還有一個(gè)藝術(shù)字的生成接口,挺不錯(cuò)

6. api接口只會(huì)生成一個(gè)二維碼的圖片流,如果需要把圖片保存到本地需要通過瀏覽器直接get訪問接口或者通過程序下載這個(gè)二維碼

其次,下面給出封裝的代碼,由于下載和上面介紹的代碼一樣是公用的這里就不做陳述:

1 public QR_2dCode() 2 { 3 4 ApiUrl = "http://www.2d-code.cn/2dcode/api.php"; 5 } 6 7 #region 生成二維碼 8 9 /// <summary> 10 /// 生成二維碼 11 /// </summary> 12 /// <param name="content">展示內(nèi)容(文本內(nèi)容 或者 掃描后的跳轉(zhuǎn)http://格式的地址)</param> 13 /// <param name="savePath">保存二維碼的磁盤路徑(默認(rèn)程序跟目錄+QRCode)</param> 14 /// <param name="logoUrl"> Logo圖標(biāo)地址(格式:http://),官方不建議使用png格式,測(cè)試只有jpg成功</param> 15 /// <param name="directUrl">掃描后重定向地址(http://)</param> 16 /// <param name="apiUrl">接口地址(內(nèi)置默認(rèn)api地址)</param> 17 /// <param name="wAndh">寬度和高度(二維碼正方形的,高寬一至,默認(rèn)200)</param> 18 /// <returns></returns> 19 public override string CreateQRCode(string content = null, string savePath = null, string logoUrl = null, string apiUrl = null, int? wAndh = null) 20 { 21 var qrName = string.Empty; 22 23 #region 參數(shù)初始化 24 25 ApiUrl = apiUrl ?? ApiUrl; 26 Content = content ?? Content; 27 SaveQRPath = savePath ?? SaveQRPath; 28 LogoUrl = logoUrl ?? LogoUrl; 29 WAndH = wAndh ?? WAndH; 30 #endregion 31 32 if (string.IsNullOrEmpty(ApiUrl)) { return qrName; } 33 34 ApiUrl = string.Format("{0}?key=c_d800OBbu6hDzJtXPE2Yd02IMtmpuK9VdCqHe6vrtar4&text={1}&url={2}&logo={3}&size={4}", 35 ApiUrl, 36 HttpUtility.UrlEncode(Content.Contains("http") ? "" : Content), 37 HttpUtility.UrlEncode(Content), 38 HttpUtility.UrlEncode(LogoUrl), 39 WAndH); 40 41 qrName = DownImg(ApiUrl, SaveQRPath); 42 return qrName; 43 } 44 #endregion View Code

?

.?topscan的Api二維碼生成接口

首先,該接口肯定是免費(fèi)的,參數(shù)描述和google的差不多,不同處在于可以傳遞Logo圖標(biāo)地址(當(dāng)然可能我還沒發(fā)現(xiàn)google的可以傳遞logo的參數(shù),故此朋友們可以忽略);下面列舉下接口參數(shù)說明和測(cè)試得出的注意點(diǎn):

1.?接口關(guān)鍵參數(shù)是:text(內(nèi)容參數(shù)),logo(Logo圖標(biāo)地址),w(生成出來二維碼圖片尺寸,格式如:200x200,這里是xyz的x不是*)

2. api接口只會(huì)生成一個(gè)二維碼的圖片流,如果需要把圖片保存到本地需要通過瀏覽器直接get訪問接口或者通過程序下載這個(gè)二維碼

3.?內(nèi)容參數(shù)如果傳遞文本信息,在生成出來的二維碼圖片中間不會(huì)顯示文本內(nèi)容,只有用手機(jī)掃描二維碼才能在手機(jī)上顯示傳遞的文本信息

4. 內(nèi)容參數(shù)如果傳遞單純的http://格式的鏈接地址,那么手機(jī)掃描后會(huì)自動(dòng)重定向到改http://鏈接地址上(這個(gè)掃描重定向可以用來做一些商品或者文章的查看)

5.?Logo圖標(biāo)地址(格式:http://),jpg,png測(cè)試通過

6.?測(cè)試得出有時(shí)候請(qǐng)求生成二維碼不返回?cái)?shù)據(jù),有可能是我網(wǎng)路問題吧,正常生成二維碼的速度還是挺快

其次,下面給出封裝的代碼,由于下載和上面介紹的代碼一樣是公用的這里就不做陳述:

1 public QR_TopScan() 2 { 3 4 ApiUrl = "http://qr.topscan.com/api.php"; 5 } 6 7 #region 生成二維碼 8 9 /// <summary> 10 /// 生成二維碼 11 /// </summary> 12 /// <param name="content">展示內(nèi)容(文本內(nèi)容 或者 掃描后的跳轉(zhuǎn)http://格式的地址)</param> 13 /// <param name="savePath">保存二維碼的磁盤路徑(默認(rèn)程序跟目錄+QRCode)</param> 14 /// <param name="logoUrl"> Logo圖標(biāo)地址(格式:http://),jpg,png測(cè)試通過,測(cè)試得出有不能成功的,原因不知是否和地址有關(guān)</param> 15 /// <param name="apiUrl">接口地址(內(nèi)置默認(rèn)api地址)</param> 16 /// <param name="wAndh">寬度和高度(二維碼正方形的,高寬一至,默認(rèn)200)</param> 17 /// <returns></returns> 18 public override string CreateQRCode(string content = null, string savePath = null, string logoUrl = null, string apiUrl = null, int? wAndh = null) 19 { 20 var qrName = string.Empty; 21 22 #region 參數(shù)初始化 23 24 ApiUrl = apiUrl ?? ApiUrl; 25 Content = content ?? Content; 26 SaveQRPath = savePath ?? SaveQRPath; 27 LogoUrl = logoUrl ?? LogoUrl; 28 WAndH = wAndh ?? WAndH; 29 #endregion 30 31 if (string.IsNullOrEmpty(ApiUrl)) { return qrName; } 32 33 ApiUrl = string.Format("{0}?text={1}&logo={2}&w={3}", 34 ApiUrl, 35 HttpUtility.UrlEncode(Content), 36 HttpUtility.UrlEncode(LogoUrl), 37 WAndH); 38 39 qrName = DownImg(ApiUrl, SaveQRPath); 40 return qrName; 41 } 42 #endregion View Code

?

.?使用面向?qū)ο?#43;加載程序集創(chuàng)建對(duì)象合并以上接口封裝成二維碼生成工廠

首先,分析上面3個(gè)接口的參數(shù)可以看出,都需要固定的參數(shù):接口api,內(nèi)容(文本或跳轉(zhuǎn)http地址),Logo圖片地址(google暫時(shí)除外),寬度和高度等這幾個(gè)參數(shù),這樣一來咋們可以定義個(gè)統(tǒng)一參數(shù)類,來傳遞該參數(shù)信息,這里還要提下由于這幾個(gè)接口都是從別人接口獲取圖片流,如果想要吧圖片在執(zhí)行程序時(shí)候直接保存在我們的程序本地,都需要下載,所以又多一個(gè)參數(shù):?保存二維碼的磁盤路徑,所以才有了一下公共的屬性:

1 #region 基礎(chǔ)配置信息 2 3 /// <summary> 4 /// 接口地址(必填) 5 /// </summary> 6 protected string ApiUrl = "https://chart.googleapis.com/chart"; 7 8 /// <summary> 9 /// 展示內(nèi)容(文本內(nèi)容),google文本參數(shù)直接傳遞http地址直接重定向 10 /// </summary> 11 protected string Content = "http://www.cnblogs.com/wangrudong003/"; 12 13 /// <summary> 14 /// 保存二維碼的磁盤路徑(默認(rèn)程序跟目錄+QRCode) 15 /// </summary> 16 protected string SaveQRPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "QRCode"); 17 18 /// <summary> 19 /// Logo圖片地址(http://) 20 /// </summary> 21 protected string LogoUrl = "http://a.hiphotos.baidu.com/baike/w%3D268%3Bg%3D0/sign=9a34e44d8bd4b31cf03c93bdbfed4042/2cf5e0fe9925bc318cb9fe965edf8db1ca1370dc.jpg"; 22 23 /// <summary> 24 /// 寬度和高度(二維碼正方形的,高寬一至,默認(rèn)200) 25 /// </summary> 26 protected int WAndH = 200; 27 28 #endregion

然后,這里我不想每個(gè)接口都手動(dòng)new一次來創(chuàng)建對(duì)象,所以用了加載程序集的模塊的方式來創(chuàng)建所需要的對(duì)象,因此有了工廠類的入口:

1 /// <summary> 2 /// 二維碼生成工廠 3 /// </summary> 4 public class QRCodeReposity 5 { 6 7 public static BaseQRCode Current(QREmType qrEmType = QREmType.BaseQRCode) 8 { 9 10 var nspace = typeof(BaseQRCode); 11 var fullName = nspace.FullName; 12 var nowspace = fullName.Substring(0, fullName.LastIndexOf('.') + 1); 13 14 return Assembly.GetExecutingAssembly().CreateInstance(nowspace + qrEmType.ToString(), true) as BaseQRCode; 15 } 16 }

這里和之前的緩存工廠文章設(shè)計(jì)差不多,可以查閱下之前的分享篇,也多多點(diǎn)贊,謝謝;下面在給出說有的代碼如下:

1 /// <summary> 2 /// 工廠模塊定義 3 /// </summary> 4 public enum QREmType 5 { 6 /// <summary> 7 /// google接口 8 /// </summary> 9 BaseQRCode, 10 11 /// <summary> 12 /// 2d-code接口 13 /// </summary> 14 QR_2dCode, 15 16 /// <summary> 17 /// topscan接口 18 /// </summary> 19 QR_TopScan 20 } 21 22 /// <summary> 23 /// 二維碼生成工廠 24 /// </summary> 25 public class QRCodeReposity 26 { 27 28 public static BaseQRCode Current(QREmType qrEmType = QREmType.BaseQRCode) 29 { 30 31 var nspace = typeof(BaseQRCode); 32 var fullName = nspace.FullName; 33 var nowspace = fullName.Substring(0, fullName.LastIndexOf('.') + 1); 34 35 return Assembly.GetExecutingAssembly().CreateInstance(nowspace + qrEmType.ToString(), true) as BaseQRCode; 36 } 37 } 38 39 /// <summary> 40 /// 基類使用Google提供Api:https://developers.google.com/chart/infographics/docs/qr_codes ,由于是國(guó)外地址,相對(duì)來說有點(diǎn)慢 41 /// </summary> 42 public class BaseQRCode 43 { 44 45 #region 基礎(chǔ)配置信息 46 47 /// <summary> 48 /// 接口地址(必填) 49 /// </summary> 50 protected string ApiUrl = "https://chart.googleapis.com/chart"; 51 52 /// <summary> 53 /// 展示內(nèi)容(文本內(nèi)容),google文本參數(shù)直接傳遞http地址直接重定向 54 /// </summary> 55 protected string Content = "http://www.cnblogs.com/wangrudong003/"; 56 57 /// <summary> 58 /// 保存二維碼的磁盤路徑(默認(rèn)程序跟目錄+QRCode) 59 /// </summary> 60 protected string SaveQRPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "QRCode"); 61 62 /// <summary> 63 /// Logo圖片地址(http://) 64 /// </summary> 65 protected string LogoUrl = "http://a.hiphotos.baidu.com/baike/w%3D268%3Bg%3D0/sign=9a34e44d8bd4b31cf03c93bdbfed4042/2cf5e0fe9925bc318cb9fe965edf8db1ca1370dc.jpg"; 66 67 /// <summary> 68 /// 寬度和高度(二維碼正方形的,高寬一至,默認(rèn)200) 69 /// </summary> 70 protected int WAndH = 200; 71 72 #endregion 73 74 #region 方法 75 76 #region 生成二維碼 77 78 /// <summary> 79 /// 生成二維碼 80 /// </summary> 81 /// <param name="content">展示內(nèi)容(文本內(nèi)容 或者 掃描后的跳轉(zhuǎn)http://格式的地址)</param> 82 /// <param name="savePath">保存二維碼的磁盤路徑(默認(rèn)程序跟目錄+QRCode)</param> 83 /// <param name="logoUrl"> Logo圖標(biāo)地址(格式:http://),(注:google接口暫未研究出此參數(shù))</param> 84 /// <param name="apiUrl">接口地址(內(nèi)置默認(rèn)api地址)</param> 85 /// <param name="wAndh">寬度和高度(二維碼正方形的,高寬一至,默認(rèn)200)</param> 86 /// <returns></returns> 87 public virtual string CreateQRCode(string content = null, string savePath = null, string logoUrl = null, string apiUrl = null, int? wAndh = null) 88 { 89 var qrName = string.Empty; 90 91 #region 參數(shù)初始化 92 93 ApiUrl = apiUrl ?? ApiUrl; 94 Content = content ?? Content; 95 SaveQRPath = savePath ?? SaveQRPath; 96 LogoUrl = logoUrl ?? LogoUrl; 97 WAndH = wAndh ?? WAndH; 98 #endregion 99 100 if (string.IsNullOrEmpty(ApiUrl)) { return qrName; } 101 102 ApiUrl = string.Format("{0}?cht=qr&chl={1}&chs={2}x{2}", 103 ApiUrl, 104 HttpUtility.UrlEncode(Content), 105 WAndH); 106 107 qrName = DownImg(ApiUrl, SaveQRPath, ImageFormat.Jpeg); 108 return qrName; 109 } 110 #endregion 111 112 #region 下載圖片 113 114 /// <summary> 115 /// 下載圖片 116 /// </summary> 117 /// <param name="url">圖片下載地址</param> 118 /// <param name="savePath">保存路徑默認(rèn):Img文件夾</param> 119 /// <param name="format">默認(rèn):Jpeg</param> 120 /// <returns>新圖片名稱</returns> 121 public virtual string DownImg(string url, string savePath = "QRCode", ImageFormat format = null) 122 { 123 var qrName = string.Empty; 124 try 125 { 126 format = format ?? ImageFormat.Jpeg; 127 128 HttpClient http = new HttpClient(); 129 http.Timeout = new TimeSpan(0, 1, 0); 130 using (var stream = http.GetStreamAsync(url).Result) 131 { 132 133 if (!Directory.Exists(SaveQRPath)) { Directory.CreateDirectory(SaveQRPath); } 134 qrName = DateTime.Now.ToString("yyyyMMddHHmmssfff") + "." + format; 135 var path = Path.Combine(savePath, qrName); 136 using (Image img = Image.FromStream(stream)) 137 { 138 img.Save(path, format); 139 } 140 } 141 } 142 catch (Exception ex) 143 { 144 qrName = string.Empty; 145 } 146 return qrName; 147 } 148 #endregion 149 150 #endregion 151 } 152 153 /// <summary> 154 /// 使用2d-code提供Api,需要去官網(wǎng)注冊(cè)獲取Key 155 /// </summary> 156 public class QR_2dCode : BaseQRCode 157 { 158 159 public QR_2dCode() 160 { 161 162 ApiUrl = "http://www.2d-code.cn/2dcode/api.php"; 163 } 164 165 #region 生成二維碼 166 167 /// <summary> 168 /// 生成二維碼 169 /// </summary> 170 /// <param name="content">展示內(nèi)容(文本內(nèi)容 或者 掃描后的跳轉(zhuǎn)http://格式的地址)</param> 171 /// <param name="savePath">保存二維碼的磁盤路徑(默認(rèn)程序跟目錄+QRCode)</param> 172 /// <param name="logoUrl"> Logo圖標(biāo)地址(格式:http://),官方不建議使用png格式,測(cè)試只有jpg成功</param> 173 /// <param name="directUrl">掃描后重定向地址(http://)</param> 174 /// <param name="apiUrl">接口地址(內(nèi)置默認(rèn)api地址)</param> 175 /// <param name="wAndh">寬度和高度(二維碼正方形的,高寬一至,默認(rèn)200)</param> 176 /// <returns></returns> 177 public override string CreateQRCode(string content = null, string savePath = null, string logoUrl = null, string apiUrl = null, int? wAndh = null) 178 { 179 var qrName = string.Empty; 180 181 #region 參數(shù)初始化 182 183 ApiUrl = apiUrl ?? ApiUrl; 184 Content = content ?? Content; 185 SaveQRPath = savePath ?? SaveQRPath; 186 LogoUrl = logoUrl ?? LogoUrl; 187 WAndH = wAndh ?? WAndH; 188 #endregion 189 190 if (string.IsNullOrEmpty(ApiUrl)) { return qrName; } 191 192 ApiUrl = string.Format("{0}?key=c_d800OBbu6hDzJtXPE2Yd02IMtmpuK9VdCqHe6vrtar4&text={1}&url={2}&logo={3}&size={4}", 193 ApiUrl, 194 HttpUtility.UrlEncode(Content.Contains("http") ? "" : Content), 195 HttpUtility.UrlEncode(Content), 196 HttpUtility.UrlEncode(LogoUrl), 197 WAndH); 198 199 qrName = DownImg(ApiUrl, SaveQRPath); 200 return qrName; 201 } 202 #endregion 203 } 204 205 /// <summary> 206 /// 使用topscan提供Api 207 /// </summary> 208 public class QR_TopScan : BaseQRCode 209 { 210 211 public QR_TopScan() 212 { 213 214 ApiUrl = "http://qr.topscan.com/api.php"; 215 } 216 217 #region 生成二維碼 218 219 /// <summary> 220 /// 生成二維碼 221 /// </summary> 222 /// <param name="content">展示內(nèi)容(文本內(nèi)容 或者 掃描后的跳轉(zhuǎn)http://格式的地址)</param> 223 /// <param name="savePath">保存二維碼的磁盤路徑(默認(rèn)程序跟目錄+QRCode)</param> 224 /// <param name="logoUrl"> Logo圖標(biāo)地址(格式:http://),jpg,png測(cè)試通過,測(cè)試得出有不能成功的,原因不知是否和地址有關(guān)</param> 225 /// <param name="apiUrl">接口地址(內(nèi)置默認(rèn)api地址)</param> 226 /// <param name="wAndh">寬度和高度(二維碼正方形的,高寬一至,默認(rèn)200)</param> 227 /// <returns></returns> 228 public override string CreateQRCode(string content = null, string savePath = null, string logoUrl = null, string apiUrl = null, int? wAndh = null) 229 { 230 var qrName = string.Empty; 231 232 #region 參數(shù)初始化 233 234 ApiUrl = apiUrl ?? ApiUrl; 235 Content = content ?? Content; 236 SaveQRPath = savePath ?? SaveQRPath; 237 LogoUrl = logoUrl ?? LogoUrl; 238 WAndH = wAndh ?? WAndH; 239 #endregion 240 241 if (string.IsNullOrEmpty(ApiUrl)) { return qrName; } 242 243 ApiUrl = string.Format("{0}?text={1}&logo={2}&w={3}", 244 ApiUrl, 245 HttpUtility.UrlEncode(Content), 246 HttpUtility.UrlEncode(LogoUrl), 247 WAndH); 248 249 qrName = DownImg(ApiUrl, SaveQRPath); 250 return qrName; 251 } 252 #endregion 253 } View Code

本篇的分享內(nèi)容在程序設(shè)計(jì)方面沒有太多,重點(diǎn)是分裝下這幾個(gè)接口和分享下接口的差異,方面朋友們可以拿來主義和正在對(duì)接二維碼生成的朋友做下交流,僅此而已;關(guān)鍵代碼的備注都在分享代碼里,有更好或者不清楚的地方歡迎留言,謝謝,放一張效果圖,大家可以掃一掃:

?

git地址: https://github.com/shenniubuxing3????nuget發(fā)布包:https://www.nuget.org/profiles/shenniubuxing3

總結(jié)

以上是生活随笔為你收集整理的二维码生成工厂的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。