C#后台生成二维码

23 篇文章 0 订阅
2 篇文章 0 订阅

先展示下效果图
在这里插入图片描述
读完本文您将了解到C#后端如何生成二维码图片,废话不多说,代码如下。

编程工具:VisualStudio2017

目录

  1. 安装ThoughtWorks.QRCode程序包
  2. 前端代码
  3. 后端代码
  4. 效果图

1. 安装ThoughtWorks.QRCode程序包

生成二维码的方法都是用的这个程序包内的方法。
a. 打开工具栏->NuGet包管理器->管理解决方案的NuGet程序包
在这里插入图片描述
b.下载ThoughtWorks.QRCode
在这里插入图片描述
c. 引用dll文件,不多说

2. 前端代码

asp:TextBox:输入内容文本框
asp:Button:生成二维码按钮
asp:Image:展示二维码图片

<body>
    <form id="form1" runat="server">
        <div>
            请输入内容:<asp:TextBox ID="TextBox_qr" runat="server" Text="Hello World!"></asp:TextBox>
            <asp:Button ID="Button1" runat="server" Text="字符串生成二维码" OnClick="Button_MakeQrimg" />
            <br/>
            <%--展示二维码图片--%>
            <asp:Image ImageUrl="imageStr" runat="server" ID="imageStr" />
        </div>
        <div>
        </div>
    </form>

</body>

3. 后端代码

后端主要注意以下几点,如下:
a. 编码方式使用BYTE,能支持中文
b. QRCodeScale可以设置为5,值越大生成的二维码的图片的像素越高
c. QRCodeVersion的版本设置为8。如果设置为8,会有具体的信息量上限,如果字符串过长超过了信息量的上限,会生成报错。如果设置为0即使是超级长的字符串也可以正常生成二维码图片,
d. QRCodeErrorCorrect:编码错误纠正

e. Encode(“str”)方法:生成Bitmap类型的二维码信息
f. ToBase64String()方法:将8位无符号整数的数组转换为其用Base64数字编码的等效字符串表示形式。通俗的讲就是转换为Base64格式的图片信息,可以直接在页面中显示图片。

protected void Page_Load(object sender, EventArgs e)
{
    makeQrImage();//初始化二维码图片
}
protected void Button_MakeQrimg(object sender, EventArgs e)
{
    makeQrImage();//点金生成二维码事件
}
/// <summary>
/// 字符串生成二维码的方法
/// </summary>
private void makeQrImage()
{
    QRCodeEncoder qrCodeEncoder = new QRCodeEncoder();
    qrCodeEncoder.QRCodeEncodeMode = QRCodeEncoder.ENCODE_MODE.BYTE;//编码方式 BYTE能支持中文
    qrCodeEncoder.QRCodeScale = 5;//大小(值越大生成的二维码图片像素越高)
    qrCodeEncoder.QRCodeVersion = 8;//版本(注意:设置为0主要是防止编码的字符串太长时发生错误)
    qrCodeEncoder.QRCodeErrorCorrect = QRCodeEncoder.ERROR_CORRECTION.M;//错误效验、错误更正

    Bitmap image = qrCodeEncoder.Encode(TextBox_qr.Text.ToString());
    MemoryStream ms = new MemoryStream();//创建其支持存储区为内存的流
    image.Save(ms, System.Drawing.Imaging.ImageFormat.Png);
    imageStr.ImageUrl = "data:image/png;base64," + Convert.ToBase64String(ms.ToArray());//图片转化为base64,展示在页面中
}

4. 效果图

最终的效果退如下
在这里插入图片描述

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星银色飞行船

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值