祝愿大家身体健康!

 站点注册  找回密码
 站点注册

QQ登录

只需一步,快速开始

查看: 8754|回复: 5

[其它] PB加密解密方法

[复制链接]

[其它] PB加密解密方法

[复制链接]
ehxz

主题

0

回帖

57万

积分

管理员

积分
570724
贡献
在线时间
小时
2009-7-22 12:10:51 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?站点注册

×
global type f_encrypt from function_object
end type

forward prototypes
global function string f_encrypt (string st_text, string st_key)
end prototypes

global function string f_encrypt (string st_text, string st_key);//**************************************************************
// Function:   uf_pub_encrypt()           *
// Descirption: 用给定的密钥加密字符串       *
// Parameters:   string   st_text   待加密字串     *
//           string   st_key   密钥     *
//                               *
// Return:   <加密后字串>                 *
//                               *
// Author:   rain                   *
// Date:     2002.11.05                 *
//**************************************************************


string st_textencrypt
long lg_textlen,lg_keylen,lg_key
long lg_loop

IF isnull(st_key) OR isnull(st_text) THEN RETURN ''

lg_keylen = len(st_key)
FOR lg_loop = 1 TO lg_keylen
lg_key = lg_key + (asc(mid(st_key,lg_loop,1)) * lg_loop)
IF lg_key > 255 THEN lg_key = lg_key - 255
NEXT

DO While lg_key > 255
lg_key = lg_key - 255
LOOP

LONG lg_cbyte

lg_textlen = Len(st_text)

FOR lg_loop = 1 TO lg_textlen
lg_cbyte = asc(mid(st_text,lg_loop,1)) + lg_key
IF lg_cbyte > 255 THEN lg_cbyte = lg_cbyte - 255
st_textencrypt = st_textencrypt + char(lg_cbyte)
lg_key = lg_key + lg_cbyte
IF lg_key > 255 THEN lg_key = lg_key - 255
NEXT

RETURN st_textencrypt
end function


//解密
global type f_decrypt from function_object
end type

forward prototypes
global function string f_decrypt (string st_text, string st_key)
end prototypes

global function string f_decrypt (string st_text, string st_key);//**************************************************************
// Function:   uf_pub_decrypt()           *
// Descirption: 用给定的密钥解密字符串,与uf_pub_encrypt相对 *
// Parameters:   string   st_text   待解密字串     *
//           string   st_key   密钥     *
//                               *
// Return:   <解密后字串>                 *
//                               *
// Author:   rain                   *
// Date:     2002.11.05                 *
//**************************************************************

string st_textdecrypt
IF isnull(st_key) OR isnull(st_text) THEN RETURN ''
long lg_textlen,lg_keylen,lg_key
long lg_loop

lg_keylen = len(st_key)

FOR lg_loop = 1 TO lg_keylen
lg_key = lg_key + (asc(mid(st_key,lg_loop,1)) * lg_loop)
IF lg_key>255 THEN lg_key = lg_key - 255
NEXT

DO While lg_key>255
lg_key = lg_key - 255
LOOP

lg_textlen = len(st_text)

long lg_cbyte
FOR lg_loop = 1 TO lg_textlen
lg_cbyte = asc(mid(st_text,lg_loop,1)) - lg_key
IF lg_cbyte<0 THEN lg_cbyte = lg_cbyte + 255
st_textdecrypt = st_textdecrypt + char(lg_cbyte)
lg_key = lg_key + asc(mid(st_text,lg_loop,1))
IF lg_key > 255 THEN lg_key = lg_key - 255
NEXT

RETURN st_textdecrypt
end function



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/sdrzths/archive/2009/01/20/3839177.aspx
来自上面,未测试
共享共进共赢Sharing And Win-win Results
SYBASEBBS - 免责申明1、欢迎访问“SYBASEBBS.COM”,本文内容及相关资源来源于网络,版权归版权方所有!本站原创内容版权归本站所有,请勿转载!
2、本文内容仅代表作者观点,不代表本站立场,作者自负,本站资源仅供学习研究,请勿非法使用,否则后果自负!请下载后24小时内删除!
3、本文内容,包括但不限于源码、文字、图片等,仅供参考。本站不对其安全性,正确性等作出保证。但本站会尽量审核会员发表的内容。
4、如本帖侵犯到任何版权问题,请立即告知本站 ,本站将及时删除并致以最深的歉意!客服邮箱:admin@sybasebbs.com
top_two

主题

0

回帖

7

积分

新手上路

积分
7
贡献
在线时间
小时
2009-7-23 09:50:57 | 显示全部楼层
非常3q!!
共享共进共赢Sharing And Win-win Results
newease

主题

0

回帖

1万

积分

论坛元老

积分
19020
贡献
在线时间
小时
2009-8-5 09:23:36 | 显示全部楼层
测试此加密和解密函数,发现有不少需要完善的地方

加密的key为字母时加解密不正常

key即使为string(数值)加解密的结果有时也不正确

……
共享共进共赢Sharing And Win-win Results
zhang793399158

主题

0

回帖

226

积分

注册会员

积分
226
贡献
在线时间
小时
2019-11-21 21:30:33 | 显示全部楼层
顶顶更健康
共享共进共赢Sharing And Win-win Results
shun4132175

主题

0

回帖

619

积分

高级会员

积分
619
贡献
在线时间
小时
2023-11-13 09:19:29 | 显示全部楼层
进来学习一下
共享共进共赢Sharing And Win-win Results
sky_sw32

主题

0

回帖

414

积分

中级会员

积分
414
贡献
在线时间
小时
2024-4-13 11:14:25 | 显示全部楼层
非常好,值得学习一下,谢谢
共享共进共赢Sharing And Win-win Results
您需要登录后才可以回帖 登录 | 站点注册

本版积分规则

免责声明:
本站所发布的一切破解补丁、注册机和注册信息及软件的解密分析文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:Admin@SybaseBbs.com

QQ|Archiver|PowerBuilder(PB)BBS社区 ( 鲁ICP备2021027222号-1 )

GMT+8, 2024-4-26 04:11 , Processed in 0.059905 second(s), 8 queries , MemCached On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表