在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
本文实例讲述了ASP.NET实现二维码(QRCode)的创建和读取方法。分享给大家供大家参考。具体分析如下: 概述: QR二维码比其他二维码相比,具有识读速度快、数据密度大、占用空间小的优势。QR码的三个角上有三个寻象图形,使用CCD识读设备来探测码的位置、大小、倾斜角度、并加以解码,实现360读高速识读。每秒可以识读30个含有100个字符QR码。QR码容量密度 大,可以放入1817个汉字、7089个数字、4200个英文字母。QR码用数据压缩方式表示汉字,仅用13bit即可表示一个汉字,比其他二维条码表示 汉字的效率提高了20%。QR具有4个等级的纠错功能,即使破损或破损也能够正确识读。QR码抗弯曲的性能强,通过QR码中的每隔一定的间隔配置有校正图 形,从码的外形来求得推测校正图形中心点与实际校正图形中心点的误差来修正各个模快的中心距离,即使将QR码贴在弯曲的物品上也能够快速识读。QR码可以分割成16个QR码,可以一次性识读数个分割码,适应于印刷面积有限及细长空间印刷的需要。此外微型QR码可以在1厘米的空间内放入35个数字或9个汉字 或21个英文字母,适合对小型电路板对ID号码进行采集的需要。 QRCode点击此处本站下载(支持中文) 一、项目引用QRCode的DLL文件(ThoughtWorks.QRCode.dll) 二、ASPX页面(两个jquery的js文件请自行去官网下载): 复制代码 代码如下: <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server"> <title>二维码工具测试</title> <script type="text/javascript" src="../../Scripts/Jquery/jquery-1.6.2.js"></script> <script type="text/javascript" src="../../Scripts/Jquery/jquery.form.js"></script> <script type="text/javascript" src="js/test.js"></script> <style type="text/css"> .style1 { width: 100%; } #txt_qr { width: 632px; } </style> </head> <body> <div> <table class="style1"> <tr> <td> 输入文字: </td> <td> <input type="text" id="txt_qr" name="txt_qr" /> </td> </tr> <tr> <td> 二维码图片 </td> <td> <img id="qrimg" alt="二维码图片" /> </td> </tr> <tr> <td> 生成选项 </td> <td> Encoding:<select id="Encoding"> <option value="Byte">Byte</option> <option value="AlphaNumeric">AlphaNumeric</option> <option value="Numeric">Numeric</option> </select> Correction Level:<select id="Level"> <option value="M">M</option> <option value="L">L</option> <option value="Q">Q</option> <option value="H">H</option> </select> Version:<input id="txt_ver" type="text" value="7" />(1-40) Size:<input id="txt_size" type="text" value="4" /> </td> </tr> <tr> <td colspan="4"> <input type="button" onclick="getQrImg();" value="生成二维码" /> </td> </tr> <tr> <td> <form id="qrForm" action="Ashx/test.ashx" method="post" enctype="multipart/form-data"> <input type="file" id="file_qr" name="file_qr" /><input type="submit" value="读取二维码" /> </form> </td> <td colspan="1"> <img id="img_qr" alt="要读取的图片" /><br /> <input id="txt_readqr" type="text" /> </td> </tr> </table> </div> </body> </html> 三、test.js文件 复制代码 代码如下: $(document).ready(function () { var options = { beforeSubmit: showRequest, success: showResponse, dataType: 'json', clearForm: true, error: function (request, message, ex) { alert('错误:' + message); } }; $('#qrForm').ajaxForm(options); }); function showRequest(formData, jqForm, options) { return true; } function showResponse(responseText, statusText, xhr, $form) { if (responseText[0].count == 0) { alert(responseText[0].list[0].error); return false; } $("#img_qr").attr("src", responseText[0].list[0].imgurl); $("#txt_readqr").val(responseText[0].list[0].qrtext); return false; } 四、test.ashx,没有判断目录是否存在等问题,请自行建立或者更改代码。 复制代码 代码如下: using System;
using System.Web; using System.Drawing; using System.Drawing.Imaging; using System.Text; using System.Text.RegularExpressions; using ThoughtWorks.QRCode.Codec; using ThoughtWorks.QRCode.Codec.Data; using ThoughtWorks.QRCode.Codec.Util; public class test : IHttpHandler { public void ProcessRequest(HttpContext context) { context.Response.ContentType = "text/plain"; string cmd = context.Request["cmd"] == null ? "get" : context.Request["cmd"].ToString(); string filename = string.Empty; string filepath = string.Empty; switch (cmd) { case "get": if (context.Request.Files.Count > 0) { for (int j = 0; j < context.Request.Files.Count; j++) { filename = Guid.NewGuid().ToString() + "_tmp.jpg"; filepath = context.Server.MapPath(@"~\Utilty\QRCode\upload") + "\\" + filename; string qrdecode = string.Empty; HttpPostedFile uploadFile = context.Request.Files[j]; uploadFile.SaveAs(filepath); QRCodeDecoder decoder = new QRCodeDecoder(); QRCodeEncoder qrCodeEncoder = new QRCodeEncoder(); Image image; //context.Response.Write(@"upload\" + filename); break; foreach (Match m2 in mc) 效果如下图所示: PS:感兴趣的朋友还可参考本站二维码工具:http://tools.ogeek.net/transcoding/ogeekqrcode 希望本文所述对大家的asp.net程序设计有所帮助。 |
请发表评论