读取数据库信息,使用QR码API批量生成二维码并下载到本地

前言:宿舍没网了,赖在公司没事干,写点东西记录吧。。目前也是刚开始接触数据库,写的不好,请见谅,尽力用简洁步骤完成操作,上可执行的源代码,于人于己方便,大家都懂哈。。另我用的QR码API为联图的,因为这个网上的介绍很多,用的也很广。废话结束,开干。。

平台:win10(64bit)、vs2008、mysql5.1.73(64bit)

注:试运行程序的时候总提示无法解析的外部符号,是因为建的工程是win32,debug时改成x64平台就好了,因为这个墨迹了一天多,哎。。

预准备一:我用的mysql的msi安装文件,安装时选择的complete,一直next到尾,数据库密码设的102512(代码里需要用到,你的数据库设的什么就改成相应的密码),安装结束,打开mysql的命令窗口(在左下角所有程序目录mysql下边有),输入密码,进入命令行操作界面。底下创建数据库和数据表并插入数据见我的另一篇博客:http://blog.csdn.net/fx_odyssey/article/details/72866074,本篇批量生成的二维码附带文本信息用的是单条目信息,所以添入数据表数据时仅一列就够了。

预准备二:将mysql安装路径下带mysql.h文件的路径、带libmysql.lib文件的路径分别设置为所建vs2008工程属性的附加头文件路径、附加lib库文件路径;附加库目录添加libmysql.lib;将libmysql.dll文件拷贝到工程目录下。

准备工作结束,以下为源码:

//#pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"" )//屏蔽dos窗口
#pragma comment( lib, "libmysql.lib")
#pragma comment(lib, "urlmon.lib")//下载网络图片用
#include <winsock2.h>//定义socket
#include <WINDOWS.H>
#include <iostream>
#include "mysql.h"
int main(char **args)
{
 char *url = "http://tool.kd128.com/qrcode?text=";//这个是联图QR码API的基址,后边跟二维码信息,详细问度娘//http://qr.liantu.com/api.PHP?&bg=ffffff&text=
 char *urlbase = new char[256];
 char *filenamebase = new char[256];
 const char user[] = "root";
 const char password[] = "123456";//个人设置的数据库密码
 const char host[] = "localhost";
 const char table[] = "abc";//个人设置的数据库名称
 unsigned int port = 3306;//默认端口
 MYSQL mysql;
 MYSQL_RES *result;
 MYSQL_ROW sql_row;
 MYSQL_FIELD *fd;
 char column[32][32];
 int res;
 mysql_init(&mysql);
 if (mysql_real_connect(&mysql, host, user, password, table, port, NULL, 0))//判断是否连接数据库
 {
  std::cout << "connect succeed !" << std::endl;
  res = mysql_query(&mysql, "select *from mytable");//事先创建的数据库中的数据表名称为mytable
  if (!res)
  {
   result = mysql_store_result(&mysql);
   if (result)
   {
    int i, j;
    std::cout << "number of result: " << (unsigned long)mysql_num_rows(result) << std::endl;
    for (i = 0; fd = mysql_fetch_field(result); i++)
    {
     strcpy(column[i], fd->name);
    }
    j = mysql_num_fields(result);
    for (i = 0; i < j; i++)
    {
     //printf("%s\t", column[i]);
    }
    printf("\n");
    while (sql_row = mysql_fetch_row(result))
    {
     for (i = 0; i < j; i++)
     {
      if (j = 1)
      {
       //printf("%s\t", sql_row[i]);
       strcpy(urlbase, url);
       strcat(urlbase, sql_row[i]);
       strcpy(filenamebase, "./Download Pictures/");//我事先在工程目录下创建了download pictures这个文件夹,如果嫌麻烦,删掉,改成:“./";
       strcat(filenamebase, sql_row[i]);
       strcat(filenamebase, ".bmp");
       if (URLDownloadToFile(NULL, urlbase, filenamebase, 0, NULL) != S_OK)//下载图片,简单明了,小钢炮般的体验
        perror("Download Picture False.");
      }
      else
      {
       //此处为多表头数据表数据处理
      }
     }
     printf("\n");
    }
   }
  }
  else
  {
   std::cout << "query sql failed !" << std::endl;
  }
 }
 else
 {
  std::cout << "connect failed !" << std::endl;
  int i = mysql_errno(&mysql);
  const char * s = mysql_error(&mysql);
  std::cout << s << std::endl;
 }
 if (result != NULL)
  mysql_free_result(result);
 delete[] urlbase;
 delete[] filenamebase;
 mysql_close(&mysql);
 //system("pause");
 return 0;
}

有疑问的可以留言,大家相互学习,早日摆脱渣渣的水平。

备注:我渴望成功,虽然程序员没有出路,但我知道努力后多拿一块钱,就可以多喝一瓶自来水。

生成二维码并将其保存到数据库中,您可以使用以下步骤: 1. 导入相关的Java库:您可以使用ZXing库来生成二维码。请确保已将其添加到您的Java项目中。 2. 生成二维码使用ZXing库中的QRCodeWriter类,您可以创建一个QRCode对象,该对象可以转换为图片格式并保存到本地。 3. 将二维码图片转换为字节数组:使用ImageIO类将二维码图片转换为字节数组。 4. 将字节数组保存到数据库使用JDBC连接到您的数据库,并使用PreparedStatement类将字节数组保存到数据库中。 以下是一些示例代码来演示这些步骤: ```java import java.awt.image.BufferedImage; import java.io.ByteArrayOutputStream; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; import java.util.Base64; import javax.imageio.ImageIO; import com.google.zxing.WriterException; import com.google.zxing.common.BitMatrix; import com.google.zxing.qrcode.QRCodeWriter; public class QRCodeGenerator { public static void main(String[] args) throws SQLException { String data = "Hello, world!"; // 数据内容 int size = 300; // 生成二维码图片大小 String format = "png"; // 二维码图片格式 byte[] imageBytes = null; // 生成二维码 QRCodeWriter writer = new QRCodeWriter(); BitMatrix matrix; try { matrix = writer.encode(data, com.google.zxing.BarcodeFormat.QR_CODE, size, size); BufferedImage image = new BufferedImage(size, size, BufferedImage.TYPE_INT_RGB); for (int x = 0; x < size; x++) { for (int y = 0; y < size; y++) { image.setRGB(x, y, matrix.get(x, y) ? 0xFF000000 : 0xFFFFFFFF); } } ByteArrayOutputStream baos = new ByteArrayOutputStream(); ImageIO.write(image, format, baos); imageBytes = baos.toByteArray(); } catch (WriterException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } // 将字节数组保存到数据库 Connection conn = null; // 假设您已连接到数据库 PreparedStatement ps = conn.prepareStatement("INSERT INTO qr_codes (data) VALUES (?)"); ps.setBytes(1, imageBytes); ps.executeUpdate(); } } ``` 在这个示例中,我们生成一个包含字符串“Hello, world!”的二维码,将其转换为PNG格式的图片,将图片字节数组保存到名为“qr_codes”的数据库表中。请注意,此示例仅用于演示目的,您需要根据您的具体需求进行适当的修改。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值