linux数据库中使用MD5加密
MD5加密算法源码下载:https://pan.baidu.com/s/1nwyN0xV
下载完成了之后解压,得到两个文件

环境搭建:
1、把md5.h文件拷贝到/usr/include/目录下
sudo cp md5.h /usr/include
2、编译生成.o文件
gcc -fPIC -o md5.o -c md5.c -lpthread -ldl
3、编译生成.so文件
gcc -shared -fPIC -o libmd5.so md5.o -lpthread -ldl
4、把生成的.so文件拷贝都/lib/目录下,方便使用
sudo cp libmd5.so /lib/
其中我们使用到了MD5中数据加密函数
void MD5Str(char *input, unsigned char *output);
参数: input:要加密的数据
output:加密后的数据
程序mysqlite3.c如下:
#include <sqlite3.h>
#include <stdio.h>
#include <string.h>
#include "md5.h" /*定义此宏时使用回调函数查询否则只是用非回调函数查询*/
//#define CALLBACK /*定义创建表格指令IF not EXISTS:不存在,AUTOINCREMENT:自动增加主键,not NULL:不能为空*/
#define CREATE "create table IF not EXISTS passwd(id integer primary key AUTOINCREMENT,username text not NULL,password text not NULL)"
/*定义查询数据指令*/
#define SELECT "select * from passwd where username='%s' and password='%s'"
/*定义插入数据指令*/
#define INSERT "insert into passwd(username,password) values('%s','%s')" /*如果查询到多行数据, 那么这个函数就会调用多次(每一行调用一次)*/
int callback(void *arg, int col, char **value, char **name)
{
int i=;
for(i=;i<col; i++)
{
printf("%s\t", value[i]);
}
printf("\n");
return ;
} int main(void)
{ //1.打开数据库
sqlite3 *ppdb = NULL;
int ret = sqlite3_open("./passwd", &ppdb); /*我们之前要先创建一个名字叫passwd的数据库*/
if(ret != SQLITE_OK)
{
perror("open fail");
return -;
}
sqlite3_exec(ppdb,CREATE,NULL,NULL,NULL); /*创建一个表格*/
char temp[];
char temp1[];
char insert[strlen(temp)+strlen(temp1)+]; /*这里的数组要给大一点,因为等下加密的时候会得到一串很长的数据*/
printf("please input your username:");
scanf("%s",temp);
printf("please input your password:");
scanf("%s",temp1);
MD5Str(temp1,temp1);/*把输入的密码使用md5加密存储在数据库表格中*/
printf("1111\n"); sprintf(insert,INSERT,temp,temp1);/*打包数据,准备插入到表格中*/ sqlite3_exec(ppdb,insert,NULL,NULL,NULL); char username[];
char password[];
printf("input username:");
scanf("%s",username);
printf("input password:");
scanf("%s",password); MD5Str(password,password);/*把输入的密码使用md5加密之后与数据库表格中的密码匹对*/
char sql[strlen(SELECT)+strlen(username)+strlen(password)]; /*打包一个字符串,将SELECT字符串放到sql中,username和password这两个变量放大SELECT中*/
sprintf(sql,SELECT,username,password); #ifdef CALLBACK
//回调查询
char *selectsql = "select * from myname";
ret = sqlite3_exec(ppdb, selectsql, callback, NULL, NULL);
if(ret != SQLITE_OK)
{
perror("create fail");
sqlite3_close(ppdb);
return -;
} //非回调查询
#else
char **result = NULL;
int row = ;
int col = ;
char *error = NULL;
ret = sqlite3_get_table(ppdb,sql,&result,&row,&col,&error);
if(ret != SQLITE_OK)
{
perror("get table fail");
return -;
} int i=, j=;
for(i=;i<row+;i++)
{
for(j=;j<col;j++)
{
printf("%s\t",result[j+i*col]);
}
printf("\n");
} if(row > ) /*数据匹配成功*/
printf("checked OK\n");
else /*数据匹配失败*/
printf("fail\n");
sqlite3_free_table(result);//释放结果
#endif sqlite3_close(ppdb);
return ;
}
我们先要创建一个名字叫passwd数据库,如果不懂创建可以看看我的这篇文章:linux数据库环境搭建
sqlite3 passwd
接着我们编译程序
gcc -o mysqlite3 mysqlite3.c -lsqlite3 -lmd5
运行结果如下:

linux数据库中使用MD5加密的更多相关文章
- 简单讲解iOS应用开发中的MD5加密的相关使用<转>
这篇文章主要介绍了iOS应用开发中的MD5加密的相关使用,示例代码基于传统的Objective-C,需要的朋友可以参考下 一.简单说明 1.说明 在开发应用的时候,数据的安全性至关重要,而仅仅用POS ...
- 简单讲解iOS应用开发中的MD5加密的相关使用
简单讲解iOS应用开发中的MD5加密的相关使用 作者:文顶顶 字体:[增加 减小] 类型:转载 时间:2015-12-19 我要评论 这篇文章主要介绍了iOS应用开发中的MD5加密的相关使用, ...
- java中使用MD5加密的算法
MD5,全名Message Digest Algorithm 5,中文名为消息摘要算法第五版,为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护.以下是JAVA语言中使用MD5加密的工具 ...
- Jmeter 请求参数中包含 MD5 加密的密码
如何在jmeter中对参数进行加密 使用工具:java+myeclipse 让开发将他的加密类从eclipse中导出来打成jar包,放在jmeter安装文件夹lib文件夹中%JMETER HOME%\ ...
- ASP.NET中的MD5加密
新人冒泡,打今起在园子里算是开博了,先来写点关于基础性的东西 为以后的写其他的文章做准备. 今天就先来说说MD5加密与在ASP.NET中如何实现MD5加密. MD5加密简单的说就是把一段明文 通过某种 ...
- [转]SQL Server 数据库中的 MD5 和 SHA1
MD5 和 SHA1 是一种单向加密算法,常用于密码的验证等需要加密操作的场合,在一般情况下,开发人员可以通过 Delphi 或 PHP 这类语言自己编写相关函数或者使用自带的函数,然后将加密过的结果 ...
- JS中使用MD5加密
下载 MD5 使用MD5加密的方法:下载md5.js文件,在网页中引用该文件: < script type="text/javascript" src="md5.j ...
- java中使用MD5加密技术
在项目中经常会对一些信息进行加密,现在常用的信息加密技术有:MD5.RSA.DES等,今天主要说一下,md5加密,以及如何在java代码根据自己的业务需求使用md5. MD5简介: MD5即Messa ...
- Winform中进行MD5加密
Winform,c#进行MD5加密直接上步骤: 1.添加引用 2.在.NET选项卡中找到“System.Web” 3.选中之后,点击“确定”即可,此时会在解决方案中看到刚才添加的引用 4.引用名空间: ...
随机推荐
- 在ASP.Net Core 中使用枚举类而不是枚举
前言:我相信大家在编写代码时经常会遇到各种状态值,而且为了避免硬编码和代码中出现魔法数,通常我们都会定义一个枚举,来表示各种状态值,直到我看到Java中这样使用枚举,我再想C# 中可不可以这样写,今天 ...
- Python连载23-file_analysis
一.文件 1.定义:长久保存信息的一种信息集合 2.常用操作:(1)打开关闭(2)读写内容(3)查找 3.open函数 (1)意义:打开文件,带有很多参数 (2)第一个参数:必须有,文件的路径和名称 ...
- 快速了解Electron:新一代基于Web的跨平台桌面技术
本文引用了作者“ ConardLi”的<用JS开发跨平台桌面应用,从原理到实践>一文部分内容,原文链接:segmentfault.com/a/1190000019426512,感谢原作者的 ...
- git push 报504 (因提交文件内容过大而失败的解决方案)
Enumerating objects: 60, done. Counting objects: 100% (60/60), done. Delta compression using up to 4 ...
- css3 rem手机自适应框架
css3 rem手机自适应框架 rem是按照html的字体大小来 所以 不同宽度浏览器 htmlfont-size不一样 就可以做到自适应了 此方法比百分比方便<pre><!DOCT ...
- CSS3倒影效果
比较简单的倒影效果 <pre><div class="box-reflect"><img src="https://www.baidu.co ...
- linux基础学习路线&review
linux基础学习网址: https://www.runoob.com/linux/linux-tutorial.html 比较重点的是这个启动过程的介绍学习:https://www.runoob.c ...
- Oracle 11g 服务端的安装步骤
Ø 简介 本文主要介绍 Oracle 11g 服务端的安装步骤,在介绍之前说明以下几点: 1. 所安装的服务器是本机的虚拟机,操作系统为 Windows Server 2019: 2. 以下 ...
- ssh遇到port 22:No route to host问题的解决方法
一 iptables 问题 1.没有安装,可以先安装 yum install iptables 2.防火墙的开启与关闭 即时生效,重启失效 service iptables start(开启) ser ...
- Windows Service 服务搭配FluentScheduler实现定时任务调度
Windows Service 服务 创建Windows Service 项目 创建一个Windows Service项目,并将项目名称改为 TaskWindowService 在解决方案资源管理器内 ...