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.引用名空间: ...
随机推荐
- 1+x 证书 Web 前端开发 JavaScript 专项练习
官方QQ群 1+x 证书 Web 前端开发 JavaScript 专项练习 http://blog.zh66.club/index.php/archives/198/
- LeetCode 206:反转链表 Reverse Linked List
反转一个单链表. Reverse a singly linked list. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3- ...
- Express 框架以及与http-proxy-middleware整合实现代理
1.Express的简单使用 1.简介 Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用,和丰富的 HTTP 工具. 使用 Exp ...
- linux部署java命令
启动: #!/bin/bash source /etc/profile log() { echo `date +[%Y-%m-%d" "%H:%M:%S]` $1 } log &q ...
- keepalived+Nginx实现主备保障Nginx的高可用。
1.什么是keepalived? Keepalived是集群管理中保证集群高可用的一个服务软件,用来防止单点故障. Keepalived的作用是检测web服务器的状态,如果有一台web服务器死机,或工 ...
- WPF MVVM框架(5)
前面几章节所讲到的内容, 基本上属于前端XAML的使用方法, 那么本章及后面的章节, 则会侧重于UI与业务分离如何分离 . UI与业务逻辑之间的互操作性,, 下面将介绍WPF中, 比较主流的MVVM框 ...
- SpringBoot+Swagger整合
0.引言及注意事项 Swagger是一个接口文档工具,依照Swagger可以0配置开发接口.不过要注意,Swagger是基于SpringBoot1.47版本开发的,而SpringBoot现在基本都是是 ...
- CTF必备技能丨Linux Pwn入门教程——栈溢出基础
这是一套Linux Pwn入门教程系列,作者依据i春秋Pwn入门课程中的技术分类,并结合近几年赛事中出现的一些题目和文章整理出一份相对完整的Linux Pwn教程. 课程回顾>>Linux ...
- SpringMVC 之 上传文件
一.需求: 利用SpringMVC实现上传文件的功能 二.思路: 1.我们可以在SpringMVC中,通过配置一个MultipartResolver来上传文件. 2.通过MultipartFile f ...
- vue -全局组件和局部组件
1.全局组件:Vue.component('标签名', 构造器名) Vue.component('mycpn', cpnC) 注:这种注册组件的方式是全局组件,可以在多个Vue实例中使用. 2.局部组 ...