校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > ASP.NET實現二維碼(QRCode)的創建和讀取實例

ASP.NET實現二維碼(QRCode)的創建和讀取實例

熱門標簽:河南語音外呼系統公司 t3出行地圖標注怎么做 威海電銷 400免費電話怎么辦理 河北網絡回撥外呼系統 400電話辦理最優質 外呼電銷機器人軟件 關于宗地圖標注技術規范 寧夏機器人電銷

本文實例講述了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;

}
function getQrImg()
{
    var txt_qr = escape($.trim($("#txt_qr").val()));
    var qrEncoding = $("#Encoding").val(); ;
    var Level = $("#Level").val(); ;
    var txt_ver = $("#txt_ver").val(); ;
    var txt_size = $("#txt_size").val(); ;
    $.ajax({
        type: "GET",
        data: "cmd=settxt_qr=" + txt_qr + "qrEncoding=" + qrEncoding + "Level=" + Level + "txt_ver=" + txt_ver + "txt_size=" + txt_size,
        url: "Ashx/test.ashx",
        dataType: 'text',
        beforeSend: function (x)
        {
            x.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=utf-8");
        },
        success: function (json)
        {
            var dataObj = eval(json);            
            $("#qrimg").attr("src", dataObj[0].list[0].imgurl);           
            return false;
        },
        error: function (request, message, ex)
        {
            alert("錯誤:" + message);
        }
    });
}


四、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();                        
                        Bitmap bm = new Bitmap(filepath);
                        qrdecode = decoder.decode(new QRCodeBitmapImage(bm));
                        bm.Dispose();                 
                       
                        context.Response.Write("[{\"count\":1,\"list\":[{\"imgurl\":\"upload/" + filename + "\",\"qrtext\":\"" + qrdecode + "\"}]}]");
                    }
                }
                else
                {
                    context.Response.Write("[{\"count\":0,\"list\":[{\"error\":\"沒有上傳文件\"}]}]");
                }
                break;
            case "set":
                string txt_qr =ConverToGB(context.Request["txt_qr"].ToString().Trim(), 16);
                string qrEncoding = context.Request["qrEncoding"].ToString();
                string Level = context.Request["Level"].ToString();
                string txt_ver = context.Request["txt_ver"].ToString();
                string txt_size = context.Request["txt_size"].ToString();

                QRCodeEncoder qrCodeEncoder = new QRCodeEncoder();
                String encoding = qrEncoding;
                if (encoding == "Byte")
                {
                    qrCodeEncoder.QRCodeEncodeMode = QRCodeEncoder.ENCODE_MODE.BYTE;
                }
                else if (encoding == "AlphaNumeric")
                {
                    qrCodeEncoder.QRCodeEncodeMode = QRCodeEncoder.ENCODE_MODE.ALPHA_NUMERIC;
                }
                else if (encoding == "Numeric")
                {
                    qrCodeEncoder.QRCodeEncodeMode = QRCodeEncoder.ENCODE_MODE.NUMERIC;
                }
                try
                {
                    int scale = Convert.ToInt16(txt_size);
                    qrCodeEncoder.QRCodeScale = scale;
                }
                catch (Exception ex)
                {
                    return;
                }
                try
                {
                    int version = Convert.ToInt16(txt_ver);
                    qrCodeEncoder.QRCodeVersion = version;
                }
                catch (Exception ex)
                {
                    return;
                }
                string errorCorrect = Level;
                if (errorCorrect == "L")
                    qrCodeEncoder.QRCodeErrorCorrect = QRCodeEncoder.ERROR_CORRECTION.L;
                else if (errorCorrect == "M")
                    qrCodeEncoder.QRCodeErrorCorrect = QRCodeEncoder.ERROR_CORRECTION.M;
                else if (errorCorrect == "Q")
                    qrCodeEncoder.QRCodeErrorCorrect = QRCodeEncoder.ERROR_CORRECTION.Q;
                else if (errorCorrect == "H")
                    qrCodeEncoder.QRCodeErrorCorrect = QRCodeEncoder.ERROR_CORRECTION.H;

                Image image;
                String data = txt_qr;
                image = qrCodeEncoder.Encode(data);
                filename = Guid.NewGuid().ToString() + ".jpg";
                filepath = context.Server.MapPath(@"~\Utilty\QRCode\upload") + "\\" + filename;
                System.IO.FileStream fs = new System.IO.FileStream(filepath, System.IO.FileMode.OpenOrCreate, System.IO.FileAccess.Write);
                image.Save(fs, System.Drawing.Imaging.ImageFormat.Jpeg);
                fs.Close();
                image.Dispose();
                context.Response.Write("[{\"count\":1,\"list\":[{\"imgurl\":\"upload/" + filename + "\"}]}]");

                //context.Response.Write(@"upload\" + filename);
                break;
        }
    }
    /// summary>
    /// 10進制或16進制轉換為中文
    /// /summary>
    /// param name="name">要轉換的字符串/param>
    /// param name="fromBase">進制(10或16)/param>
    /// returns>/returns>
    public string ConverToGB(string text, int fromBase)
    {
        string value = text;
        MatchCollection mc;
        System.Text.StringBuilder sb = new System.Text.StringBuilder();
        switch (fromBase)
        {
            case 10:
                MatchCollection mc1 = Regex.Matches(text, @"#([\d]{5})", RegexOptions.Compiled | RegexOptions.IgnoreCase);
                foreach (Match _v in mc1)
                {
                    string w = _v.Value.Substring(2);
                    w = Convert.ToString(int.Parse(w), 16);
                    byte[] c = new byte[2];
                    string ss = w.Substring(0, 2);
                    int c1 = Convert.ToInt32(w.Substring(0, 2), 16);
                    int c2 = Convert.ToInt32(w.Substring(2), 16);
                    c[0] = (byte)c2;
                    c[1] = (byte)c1;
                    sb.Append(Encoding.Unicode.GetString(c));
                }
                value = sb.ToString();

                break;
            case 16:
                mc = Regex.Matches(text, @"\\u([\w]{2})([\w]{2})", RegexOptions.Compiled | RegexOptions.IgnoreCase);
                if (mc != null mc.Count > 0)
                {

                    foreach (Match m2 in mc)
                    {
                        string v = m2.Value;
                        string w = v.Substring(2);
                        byte[] c = new byte[2];
                        int c1 = Convert.ToInt32(w.Substring(0, 2), 16);
                        int c2 = Convert.ToInt32(w.Substring(2), 16);
                        c[0] = (byte)c2;
                        c[1] = (byte)c1;
                        sb.Append(Encoding.Unicode.GetString(c));
                    }
                    value = sb.ToString();
                }
                break;
        }
        return value;
    }
    public bool IsReusable
    {
        get
        {
            return false;
        }
    }
}

效果如下圖所示:

PS:感興趣的朋友還可參考本站二維碼工具:http://tools.jb51.net/transcoding/jb51qrcode

希望本文所述對大家的asp.net程序設計有所幫助。

您可能感興趣的文章:
  • ASP.NET對txt文件相關操作(讀取、寫入、保存)
  • asp.net cookie的操作,寫入、讀取與操作
  • Asp.Net 文件操作基類(讀取,刪除,批量拷貝,刪除,寫入,獲取文件夾大小,文件屬性,遍歷目錄)
  • asp.net使用npoi讀取excel模板并導出下載詳解
  • Asp.net把圖片存入數據庫和讀取圖片的方法
  • asp.net 未能寫入輸出文件--“拒絕訪問的解決辦法
  • asp.net中上傳圖片文件實現防偽圖片水印并寫入數據庫
  • asp.net 圖片的讀寫入庫實現代碼
  • asp.net 操作XML 按指定格式寫入XML數據 WriteXml
  • ASP.NET 動態寫入服務器端控件
  • asp.net讀取模版并寫入文本文件

標簽:賀州 廣元 吉林 淮北 固原 咸寧 樂山 池州

巨人網絡通訊聲明:本文標題《ASP.NET實現二維碼(QRCode)的創建和讀取實例》,本文關鍵詞  ASP.NET,實現,二維,碼,QRCode,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ASP.NET實現二維碼(QRCode)的創建和讀取實例》相關的同類信息!
  • 本頁收集關于ASP.NET實現二維碼(QRCode)的創建和讀取實例的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    在线视频中文字幕一区二区| 色综合久久久久| 图片区小说区国产精品视频| 亚洲色图制服诱惑| 一区二区三区在线观看欧美| 亚洲欧洲中文日韩久久av乱码| 国产精品成人免费| 综合久久一区二区三区| 国产精品卡一卡二| 一区二区在线观看av| 亚洲摸摸操操av| 亚洲成人动漫在线观看| 蜜臀av一级做a爰片久久| 免费av成人在线| 国产一区二区三区免费在线观看| 黑人精品欧美一区二区蜜桃| 国产精品亚洲成人| 99视频在线精品| 欧美丝袜丝nylons| 日韩欧美一区二区在线视频| 亚洲精品一区二区三区香蕉| 国产精品丝袜一区| 亚洲精品久久7777| 蜜臀av一区二区在线观看| 国产成人午夜精品影院观看视频| 丁香一区二区三区| 欧美日韩一区二区三区四区| 精品毛片乱码1区2区3区| 日本一区二区三区免费乱视频| 国产精品国产成人国产三级 | 激情五月婷婷综合| 国产精品18久久久久久vr| jizzjizzjizz欧美| 在线成人免费观看| 久久久九九九九| 一区二区欧美国产| 久久99精品久久久久久| 粉嫩嫩av羞羞动漫久久久| 欧美午夜精品久久久久久孕妇| 精品女同一区二区| 亚洲在线免费播放| 国产丶欧美丶日本不卡视频| 欧美日韩国产综合一区二区| 国产日产欧美一区二区视频| 亚洲成av人片观看| 成人黄色国产精品网站大全在线免费观看 | 国产欧美日韩久久| 亚洲国产日韩a在线播放性色| 国产一区二区三区| 欧美日韩国产综合久久| 国产精品网站一区| 麻豆免费精品视频| 欧美丝袜第三区| 亚洲欧洲美洲综合色网| 国内精品伊人久久久久av一坑| 欧美视频一区二区三区四区 | 亚洲一区在线观看免费| 国产麻豆精品theporn| 欧美综合视频在线观看| 国产欧美日韩在线视频| 九九精品一区二区| 欧美一级理论片| 香蕉影视欧美成人| 欧美性生活影院| 亚洲女与黑人做爰| av一二三不卡影片| 国产精品久久久久久久岛一牛影视 | 欧美三级视频在线观看| 亚洲视频一区二区免费在线观看 | 一区二区高清在线| 99国产精品久| 亚洲欧美一区二区久久| 99精品一区二区三区| 久久天天做天天爱综合色| 日韩黄色免费电影| 欧美日韩亚洲综合在线| 亚洲成人动漫在线免费观看| 欧美日韩国产欧美日美国产精品| 亚洲美女免费在线| 91亚洲资源网| 亚洲欧美激情在线| 91蜜桃网址入口| 亚洲精品国产无套在线观| 色综合色综合色综合色综合色综合 | 中文字幕一区二区三区在线播放 | 精品88久久久久88久久久| 日本aⅴ免费视频一区二区三区 | 成人h版在线观看| 久久久www成人免费无遮挡大片| 国产综合色产在线精品| 久久久久青草大香线综合精品| 国产精品综合网| 国产日韩欧美一区二区三区综合| 国产成人综合亚洲网站| 最好看的中文字幕久久| 精品视频一区 二区 三区| 天天影视网天天综合色在线播放| 日韩午夜激情免费电影| 国产高清亚洲一区| 中文字幕亚洲一区二区av在线| 一本到一区二区三区| 日本麻豆一区二区三区视频| 欧美va日韩va| 99久久精品国产一区| 亚洲一区二区三区免费视频| 欧美成人aa大片| 99国产精品久久久久久久久久久| 亚洲激情第一区| 欧美精品aⅴ在线视频| 国产一区二区不卡老阿姨| 中文字幕一区二| 日韩免费视频一区| 91浏览器在线视频| 黄页视频在线91| 亚洲综合图片区| 久久久亚洲综合| 欧美日韩日日夜夜| 成人永久aaa| 蜜桃av一区二区在线观看| 亚洲日本欧美天堂| 欧美一区三区二区| 99riav久久精品riav| 捆绑紧缚一区二区三区视频| 亚洲色图在线播放| 欧美精品一区二| 欧美日韩五月天| 成人h动漫精品一区二区| 麻豆精品视频在线观看视频| 亚洲精品菠萝久久久久久久| 久久久国际精品| 日韩午夜精品视频| 欧美精品高清视频| 91麻豆swag| 成人理论电影网| 国产一区二区三区免费在线观看| 亚洲福利国产精品| 又紧又大又爽精品一区二区| 国产精品初高中害羞小美女文| 2023国产一二三区日本精品2022| 欧美系列一区二区| 在线亚洲人成电影网站色www| 丰满亚洲少妇av| 国产成人av自拍| 国产乱码精品一区二区三| 免费成人在线播放| 偷窥少妇高潮呻吟av久久免费| 亚洲精品国久久99热| 中文字幕一区二区三区蜜月 | 日韩二区三区在线观看| 亚洲综合色区另类av| 综合网在线视频| 亚洲三级免费电影| 亚洲欧美另类图片小说| 亚洲欧洲三级电影| 欧美激情一区二区三区全黄| 久久免费的精品国产v∧| 日韩欧美另类在线| 日韩欧美国产一区在线观看| 精品成人一区二区三区| 欧美成人精品1314www| 日韩精品一区二区三区四区视频| 日韩欧美高清一区| 久久综合网色—综合色88| 久久久久久免费网| 亚洲国产岛国毛片在线| 国产精品久久久久毛片软件| 日韩毛片在线免费观看| 亚洲色欲色欲www在线观看| 亚洲丝袜制服诱惑| 亚洲一区在线观看视频| 婷婷开心久久网| 久久97超碰色| 国产成人亚洲综合a∨婷婷| 99久久国产免费看| 色哟哟在线观看一区二区三区| 色婷婷久久久久swag精品| 欧美亚洲一区三区| 欧美一级免费大片| 久久久亚洲综合| 亚洲综合一二三区| 久久99国产精品免费网站| 国产传媒一区在线| 91黄色免费观看| 2021久久国产精品不只是精品| 国产精品久久久久影院色老大| 亚洲综合图片区| 国产一区美女在线| 欧美日韩一区二区三区在线看| 久久先锋资源网| 亚洲综合免费观看高清在线观看| 日本欧美一区二区三区| av电影在线观看完整版一区二区| 91黄色免费看| 久久久99精品免费观看| 亚洲超碰精品一区二区| 国产精品一二三四五| 欧美在线不卡视频| 国产日韩av一区| 视频一区二区中文字幕| av午夜一区麻豆|