二维码生成工厂

本次重大分享的是3只免费之次维码接口的对接代码和测试得出的瞩目点以及界别,有再好处理方式多多交流,相互促进进步;最近于念书JavsScript的扩张TypeScript,感觉语法糖好甜美,大部分及C#更为类似,可能还是微软项目之因吧,有趣味的情人可以多相互交流下;

 

上述是个人的见,下面来规范分享今天的章吧:

. Google的Api二维码生成接口

. 2d-code底Api二维码生成接口

. topscan的Api二维码生成接口

. 使用面向对象+加载程序集创建对象合并以上接口封装成二维码生成工厂

 

下一步一个脚印的来享受:

. Google的Api二维码生成接口

率先,这里给有Google接口文档的链接qr_codes文档,热情之心上人及时就是见面打开这个链接吧,详细看下里面的参数就即无做截图了,大致通常采用的参数是:api地址,内容参数,生成图片的大富这3只参数,其他的几只参数还用默认的吧,不同得大家好还详尽的看下;其实首先不行相文档中的参数,感觉少了有的物,比如怎么不克传递二维码中间深图标的图纸地址和围观二维码后怎么过反至我思念重新定向的url链接呢,带在此问题我进行了多次的品;下面被出团结尝试的结果证实:

1. 接口关键参数是:cht(固定值qr),chl(内容参数),chs(生成出来二维码图片尺寸,格式如:200×200,这里是xyz的x不是*)

2.
api接口就见面变一个二维码的图片流,如果用将图纸保存及地头需要经浏览器直接get访问接口或者通过序下充斥之二维码

3. 内容参数如果传递文本信息,在变化无常出来的老二维码图片当中不见面显示文本内容,只有用手机扫描二维码才会当手机上展示传递的公文信息

4.
情参数如果传递单纯的http://格式的链接地址,那么手机扫描后会自动重定向到改http://链接地址上(这个扫描重定向可以用来做一些商品或者文章的查看)

5. google接口暂无研究来这Logo图标地址参数(希望有朋友研究出后与自己享受,谢谢)

  1. 是因为api地址是海外的,调用接口响应不是那快速

从,上面是个体的片段总,下面我们来拘禁下封装的要接口方法以及下载二维码图片方法:

 1  #region 生成二维码
 2 
 3         /// <summary>
 4         /// 生成二维码
 5         /// </summary>
 6         /// <param name="content">展示内容(文本内容 或者 扫描后的跳转http://格式的地址)</param>
 7         /// <param name="savePath">保存二维码的磁盘路径(默认程序跟目录+QRCode)</param>
 8         /// <param name="logoUrl"> Logo图标地址(格式:http://),(注:google接口暂未研究出此参数)</param>
 9         /// <param name="apiUrl">接口地址(内置默认api地址)</param>
10         /// <param name="wAndh">宽度和高度(二维码正方形的,高宽一至,默认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 参数初始化
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">保存路径默认:Img文件夹</param>
 8         /// <param name="format">默认: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

方两独办法应用的是虚方法,因为自这边是吧google接口当做默认的第二维码生成器来利用,后面要讲话的另外两独接口都是重新写及此;下充斥图片的点子还是公用的,暂无需再次写;这里用提到的凡调用api接口时来一个恒定的参数cht=qr,这个参数表示用QR方法生成二维码,因为这api接口还有变化图标的效益,所以仅想使生成二维码这里就固定,更多之更动图标功能不在本章分享着,谢谢。

 

. 2d-code之Api二维码生成接口

率先,该接口需要通过他们官网注册一个key,然后起后台获取到是key后才能够调用接口地址,当然注册后发生只职能是,凡是您通过api接口生成的老二维码,除了自己通过流下载,还会经过她们后台一起下载所有变化的图纸,本人暂时没错过关爱是否生成量大了会晤收费哈哈,下面罗列下接口参数说明和测试得出的注意点:

1.
接口关键参数是:key(注册获取),text(文本参数),url(扫描后重定向地方),logo(Logo图标地址),size(二维码正方形,高宽)

2.
接口的文本参数只能传递文本,不能够作扫描后又定向的地方参数使用及Google等接口有接触未等同

3. 扫描后重定向地方与Logo图标地址都是只是看的http://格式的地址链接

4. Logo图标地点,官方说非建议下png格式,测试只有jpg成功(可能是测试不敷多这里仅独介绍自己之结果)

  1. 浮动速度比快,而且还有一个办法字的变通接口,挺不错

6.
api接口就会变卦一个二维码的图片流,如果急需把图纸保存至本地需要经浏览器直接get访问接口或者经过序下充斥者二维码

其次,下面让有封装的代码,由于下载和点介绍的代码一样是公用的这里就无开述:

银河至尊游戏官网 1银河至尊游戏官网 2

 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">展示内容(文本内容 或者 扫描后的跳转http://格式的地址)</param>
13         /// <param name="savePath">保存二维码的磁盘路径(默认程序跟目录+QRCode)</param>
14         /// <param name="logoUrl"> Logo图标地址(格式:http://),官方不建议使用png格式,测试只有jpg成功</param>
15         /// <param name="directUrl">扫描后重定向地址(http://)</param>
16         /// <param name="apiUrl">接口地址(内置默认api地址)</param>
17         /// <param name="wAndh">宽度和高度(二维码正方形的,高宽一至,默认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 参数初始化
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二维码生成接口

率先,该接口肯定是免费之,参数描述和google的大半,不同处在于得传递Logo图标地址(当然或许我还从未觉察google的得传递logo的参数,故此朋友等可忽略);下面列举下接口参数说明和测试得出的注意点:

1. 接口关键参数是:text(内容参数),logo(Logo图标地址),w(生成出来二维码图片尺寸,格式如:200×200,这里是xyz的x不是*)

2.
api接口就会变卦一个二维码的图片流,如果用把图纸保存至地头需要经过浏览器直接get访问接口或者经序下充斥是二维码

3. 情参数如果传递文本信息,在转变出来的亚维码图片当中不会见显示文本内容,只有用手机扫描二维码才会于大哥大及展示传递的文本信息

4.
情节参数如果传递单纯的http://格式的链接地址,那么手机扫描后会自动重定向到改http://链接地址上(这个扫描重定向可以用来做一些商品或者文章的查看)

5. Logo图标地点(格式:http://),jpg,png测试通过

6. 测试得出有时候要生成二维码不返数据,有或是自身网路问题吧,正常生成二维码银河至尊游戏官网的进度还是挺快

从,下面为闹封装的代码,由于下载和地方介绍的代码一样是公用的此就是非举行述:

银河至尊游戏官网 3银河至尊游戏官网 4

 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">展示内容(文本内容 或者 扫描后的跳转http://格式的地址)</param>
13         /// <param name="savePath">保存二维码的磁盘路径(默认程序跟目录+QRCode)</param>
14         /// <param name="logoUrl"> Logo图标地址(格式:http://),jpg,png测试通过,测试得出有不能成功的,原因不知是否和地址有关</param>
15         /// <param name="apiUrl">接口地址(内置默认api地址)</param>
16         /// <param name="wAndh">宽度和高度(二维码正方形的,高宽一至,默认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 参数初始化
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

 

. 使用面向对象+加载程序集创建对象合并以上接口封装成二维码生成工厂

首先,分析者3只接口的参数可以看看,都需要固定的参数:接口api,内容(文本或跳转http地址),Logo图片地址(google暂时除外),宽度与惊人等及时几只参数,这样一来咋们可以定义个统一参数近似,来传递该参数信息,这里还要提下由当下几乎单接口都是自从旁人接口获取图片流,如果想使吧图片在执行顺序下一直保存在我们的程序本地,都要下载,所以还要大多一个参数: 保存二维码的磁盘路径,所以才起矣瞬间共用的特性:

 1 #region 基础配置信息
 2 
 3         /// <summary>
 4         /// 接口地址(必填)
 5         /// </summary>
 6         protected string ApiUrl = "https://chart.googleapis.com/chart";
 7 
 8         /// <summary>
 9         /// 展示内容(文本内容),google文本参数直接传递http地址直接重定向
10         /// </summary>
11         protected string Content = "http://www.cnblogs.com/wangrudong003/";
12 
13         /// <summary>
14         /// 保存二维码的磁盘路径(默认程序跟目录+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         /// 宽度和高度(二维码正方形的,高宽一至,默认200)
25         /// </summary>
26         protected int WAndH = 200;
27 
28         #endregion

接下来,这里自己弗思每个接口都手动new一次来创建对象,所以用了加载程序集的模块的方来创造所欲的靶子,因此发生矣工厂类的输入:

 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     }

此跟之前的缓存工厂文章设计多,可以查下前的分享篇,也多多点赞,谢谢;下面在吃出说有的代码如下:

银河至尊游戏官网 5银河至尊游戏官网 6

  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 ,由于是国外地址,相对来说有点慢
 41     /// </summary>
 42     public class BaseQRCode
 43     {
 44 
 45         #region 基础配置信息
 46 
 47         /// <summary>
 48         /// 接口地址(必填)
 49         /// </summary>
 50         protected string ApiUrl = "https://chart.googleapis.com/chart";
 51 
 52         /// <summary>
 53         /// 展示内容(文本内容),google文本参数直接传递http地址直接重定向
 54         /// </summary>
 55         protected string Content = "http://www.cnblogs.com/wangrudong003/";
 56 
 57         /// <summary>
 58         /// 保存二维码的磁盘路径(默认程序跟目录+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         /// 宽度和高度(二维码正方形的,高宽一至,默认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">展示内容(文本内容 或者 扫描后的跳转http://格式的地址)</param>
 82         /// <param name="savePath">保存二维码的磁盘路径(默认程序跟目录+QRCode)</param>
 83         /// <param name="logoUrl"> Logo图标地址(格式:http://),(注:google接口暂未研究出此参数)</param>
 84         /// <param name="apiUrl">接口地址(内置默认api地址)</param>
 85         /// <param name="wAndh">宽度和高度(二维码正方形的,高宽一至,默认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 参数初始化
 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">保存路径默认:Img文件夹</param>
119         /// <param name="format">默认: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,需要去官网注册获取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">展示内容(文本内容 或者 扫描后的跳转http://格式的地址)</param>
171         /// <param name="savePath">保存二维码的磁盘路径(默认程序跟目录+QRCode)</param>
172         /// <param name="logoUrl"> Logo图标地址(格式:http://),官方不建议使用png格式,测试只有jpg成功</param>
173         /// <param name="directUrl">扫描后重定向地址(http://)</param>
174         /// <param name="apiUrl">接口地址(内置默认api地址)</param>
175         /// <param name="wAndh">宽度和高度(二维码正方形的,高宽一至,默认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 参数初始化
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">展示内容(文本内容 或者 扫描后的跳转http://格式的地址)</param>
223         /// <param name="savePath">保存二维码的磁盘路径(默认程序跟目录+QRCode)</param>
224         /// <param name="logoUrl"> Logo图标地址(格式:http://),jpg,png测试通过,测试得出有不能成功的,原因不知是否和地址有关</param>
225         /// <param name="apiUrl">接口地址(内置默认api地址)</param>
226         /// <param name="wAndh">宽度和高度(二维码正方形的,高宽一至,默认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 参数初始化
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

本篇的享受内容在程序设计方没有尽多,重点是分装下这几乎独接口及享受下接口的别,方面朋友等好拿来主义和方对接二维码生成的对象开下交流,仅此而已;关键代码的备注都以享用代码里,有更好或者未知底的地方迎留言,谢谢,放平张效果图,大家可扫一扫:

 银河至尊游戏官网 7

相关文章