/*本次修改增加了unicode的支持,但是加密后依然显示为16进制数据,因为进行RSA加密后所得到的unicode编码是无法显示的,所以密文依然采用16进制数据显示。

需要特别注意:如果要对中文进行加密,那么所选取的两个素数要比较大,两个素数的成绩最好要大于65536,即大于unicode的最大编码值

*/

在SQL SERVER中实现RSA加密算法(第二版)

--判断是否为素数

if object_id('f_primeNumTest') is not null

drop function f_primeNumTest

go

create function [dbo].[f_primeNumTest]

(@p int)

returns bit

begin

declare @flg bit,@i int

select @flg=1, @i=2

while @i<sqrt(@p)

begin

if(@p%@i=0 )

begin

set @flg=0

break

end

set @i=@i+1

end

return @flg

end

go

--判断两个数是否互素

if object_id('f_isNumsPrime') is not null

drop function f_isNumsPrime

go

create function f_isNumsPrime

(@num1 int,@num2 int)

returns bit

begin

declare @tmp int,@flg bit

set @flg=1

while (@num2%@num1<>0)

begin

select @tmp=@num1,@num1=@num2%@num1,@num2=@tmp

end

if @num1=1

set @flg=0

return @flg

end

go

--产生密钥对

if object_id('p_createKey') is not null

drop proc p_createKey

go

create proc p_createKey

@p int,@q int

as

begin

declare @n bigint,@t bigint,@flag int,@d int

if dbo.f_primeNumTest(@p)=0

begin

print cast(@p as varchar)+'不是素数,请重新选择数据'

return

end

if dbo.f_primeNumTest(@q)=0

begin

print cast(@q as varchar)+'不是素数,请重新选择数据'

return

end

print '请从下列数据中选择其中一对,作为密钥'

select @n=@p*@q,@t=(@p-1)*(@q-1)

declare @e int

set @e=2

while @e<@t

begin

if dbo.f_isNumsPrime(@e,@t)=0

begin

set @d=2

while @d<@n

begin

if(@e*@d%@t=1)

print cast(@e as varchar)+space(5)+cast(@d as varchar)

set @d=@d+1

end

end

set @e=@e+1

end

end

/*加密函数说明,@key 为上一个存储过程中选择的密码中的一个 ,@p ,@q 产生密钥对时选择的两个数。获取每一个字符的unicode值,然后进行加密,产生3个字节的16位数据*/

if object_id('f_RSAEncry') is not null

drop function f_RSAEncry

go

create function f_RSAEncry

(@s varchar(100),@key int ,@p int ,@q int)

returns nvarchar(4000)

as

begin

declare @crypt varchar(8000)

set @crypt=''

while len(@s)>0

begin

declare @i bigint,@tmp varchar(10),@k2 int,@leftchar int

select @leftchar=unicode(left(@s,1)),@k2=@key/2,@i=1

while @k2>0

begin

set @i=(cast(power(@leftchar,2) as bigint)*@i)%(@p*@q)

set @k2=@k2-1

end

set @i=(@leftchar*@i)%(@p*@q)

set @tmp=''

select @tmp=case when @i%16 between 10 and 15 then char( @i%16+55) else cast(@i%16 as varchar) end +@tmp,@i=@i/16

from (select number from master.dbo.spt_values where type='p' and number<10 )K

order by number desc

set @crypt=@crypt+right(@tmp,6)

set @s=stuff(@s,1,1,'')

end

return @crypt

end

--解密:@key 为一个存储过程中选择的密码对中另一个数字 ,@p ,@q 产生密钥对时选择的两个数

if object_id('f_RSADecry') is not null

drop function f_RSADecry

go

create function f_RSADecry

(@s nvarchar(4000),@key int ,@p int ,@q int)

returns nvarchar(4000)

as

begin

declare @crypt varchar(8000)

set @crypt=''

while len(@s)>0

begin

declare @leftchar bigint

select @leftchar=sum(data1)

from (   select case upper(substring(left(@s,6), number, 1)) when 'A' then 10

when 'B' then 11

when 'C' then 12

when 'D' then 13

when 'E' then 14

when 'F' then 15

else substring(left(@s,6), number, 1)

end* power(16, len(left(@s,6)) - number) data1

from (select number from master.dbo.spt_values where type='p')K

where number <= len(left(@s,6))

) L

declare @k2 int,@j bigint

select @k2=@key/2,@j=1

while @k2>0

begin

set @j=(cast(power(@leftchar,2)as bigint)*@j)%(@p*@q)

set @k2=@k2-1

end

set @j=(@leftchar*@j)%(@p*@q)

set @crypt=@crypt+nchar(@j)

set @s=stuff(@s,1,6,'')

end

return @crypt

end

【测试】

if object_id('tb') is not null

drop table tb

go

create table tb(id int identity(1,1),col varchar(100))

go

insert into tb values(dbo.f_RSAEncry('中国人',779,1163,59))

insert into tb values(dbo.f_RSAEncry('Chinese',779,1163,59))

select * from tb

id col

1   00359B00E6E000EAF5

2   01075300931B0010A4007EDC004B340074A6004B34

select * ,解密后=dbo.f_RSADecry(col,35039,1163,59)

from tb

id     col                                                                                解密后

1     00359B00E6E000EAF5                                中国人

2     01075300931B0010A4007EDC004B340074A6004B34       Chinese

[转帖]在SQL SERVER中实现RSA加密算法相关推荐

  1. 细说SQL Server中的加密

    简介 加密是指通过使用密钥或密码对数据进行模糊处理的过程.在SQL Server中,加密并不能替代其他的安全设置,比如防止未被授权的人访问数据库或是数据库实例所在的Windows系统,甚至是数据库所在 ...

  2. SQL Server中Identity标识列

    SQL Server中,经常会用到Identity标识列,这种自增长的字段操作起来的确是比较方便.但它有时还会带来一些麻烦. SQL Server中,经常会用到Identity标识列,这种自增长的字段 ...

  3. predicate 列存储索引扫描_在SQL SERVER中导致索引查找变成索引扫描的问题分析

    SQL Server 中什么情况会导致其执行计划从索引查找(Index Seek)变成索引扫描(Index Scan)呢? 下面从几个方面结合上下文具体场景做了下测试.总结.归纳. 1:隐式转换会导致 ...

  4. mysql2008 limit,在SQL Server中实现 Limit m, n 的功能

    在SQL Server中实现 Limit m, n 的功能 (2012-03-14 18:17:43) 标签: 杂谈 在MySQL中,可以用 Limit 来查询第 m 列到第 n列的记录,例如: se ...

  5. SQL Server中SELECT会真的阻塞SELECT吗?

    在SQL Server中,我们知道一个SELECT语句执行过程中只会申请一些意向共享锁(IS) 与共享锁(S), 例如我使用SQL Profile跟踪会话86执行SELECT * FROM dbo.T ...

  6. 将Session值储存于SQL Server中

    一般情况下,我们喜欢使用Session储存我们的变量.Asp.Net提供了下面一些方法储存Session的值: InProc State Server SQL Server "InProc& ...

  7. 在SQL Server中保存和输出任意类型的文件

    我们可以把任意类型的文件保存到SQL Server中,在进行例子之前,先建立测试用表格,TestFile.sql: if exists (select * from dbo.sysobjects wh ...

  8. SQL SERVER中什么情况会导致索引查找变成索引扫描

    原文:SQL SERVER中什么情况会导致索引查找变成索引扫描 SQL Server 中什么情况会导致其执行计划从索引查找(Index Seek)变成索引扫描(Index Scan)呢? 下面从几个方 ...

  9. SQL Server中读取XML文件的简单做法

    SQL Server 2000使得以XML导出数据变得更加简单,但在SQL Server 2000中导入XML数据并对其进行处理则有些麻烦.本文介绍在SQL Server中读取XML文件的简单做法. ...

最新文章

  1. 机器学习流程,以及实践应用
  2. jQuery 学习笔记一(认识jQuery jQuery选择器 jQuery中的DOM操作)
  3. 使用UISearchDisplayController
  4. Windows10熄屏自动断开WiFi连接解决方法
  5. 真实临床“生态”下实效性研究的挑战和意义
  6. 计算机设备管理程序在哪,电脑设备管理在哪,教您如何打开电脑设备管理
  7. 微服务一定要使用Spring-Cloud吗?
  8. “十步一杀” 干掉你的职场压力
  9. 用了这么久 IDEA,你真熟悉它的自动补全功能吗?
  10. google官方上拉刷新
  11. unity3d android 实时阴影,Unity移动端实时阴影绘制
  12. 输入函数的区别C++
  13. 程序员必须收藏的网站整理(持续更新)
  14. 成熟男人与24岁女孩精彩对白 —非常感动
  15. Reno5、Reno5 Pro和Reno5 Pro+ 的区别
  16. CSS 样式,如何计算临近颜色值?
  17. 基于LSTM模型的共享自行车需求预测
  18. 周末两天入门 PCB 设计
  19. WHISTLE特征提取
  20. Informatica任务卡在timeout based commit point

热门文章

  1. linux进程间通讯-消息队列
  2. cv2.rectangle()画出矩形的用法
  3. 二十二、死锁的处理策略----预防死锁
  4. 记一次Java多线程程序调试经历:HttpClient 死锁
  5. ASP.NET Core Web Razor Pages系列教程:使用ASP.NET Core创建Razor Pages Web应用程序
  6. 物流信息管理系统MySQL设计,物流管理系统的SQL数据库设计(含代码)
  7. 你知道那些JVM性能调优
  8. 复合的赋值运算符例题_Java千问:关于Java语言复合赋值运算符的两个问题,快来瞧瞧!...
  9. html分页自动加载数据库,AngularJS实现分页显示数据库信息
  10. python在线编辑器最新_skulpt搭建Python在线编译器(一):下载、安装