欢迎光临
我们一直在努力

通用权限管理工具,支所有ADO(包括ODBC)支持的数据库,不管用什么编程都行,VC/BCB/VB/PB/Delphi-数据库专栏,其他相关

建站超值云服务器,限时71元/月

下面是一部分说明:

请细请到这里下载exedemo测试版
通用权限管理工具的创作动机权限管理是mis软件中很重要的一环。很多国内较出名的mis软件厂商都设计了较完善的也具有自己特色的权限管理模块。但对于很多没那么规范的软件商(包括个人或小创作团体),他们经常是接到一单,设计一套权限管理系统,每套都不同;有的则不够重视,随便写上一段,哪里都拷过去用;有的也曾费尽心机,但结果总不能令自己满意。
其实仔细想一下,每套软件的权限虽然各不相同,但其实所需实现的功能是相同的。权限管理是mis软件中可代码重用性最高的一个模块,也是重复开发率最高的一个模块。
做一个最通用的权限管理模块,支持尽可能多的数据库后台,支持尽可能多的前台开发工具,尽最大可能方便软件工作者设计维护和最终用户使用,当然,还要保证权限管理技术的先进性,即注重灵活性的安全性。基于这样的设想,我参考了多种权限管理系统后,设计实现了这一个通用权限管理工具。
我不敢说:减少代码重用,从我做起。但也希望自己的工作能为大家带来方便。
希望大家喜欢这个工具。有bug一定烦劳报告一下,我们一起来完善它!关于通用权限管理工具支所有ado(包括odbc)支持的数据库,不管用什么编程都行,vc/bcb/vb/pb/delphi , 这是吹牛吗?一点也不!本软件创作期间即考虑到数据库兼容的问题,重要脚本绝对符合sql_92标准。大部份工作后台进行,稍加改动适应也是轻而易举。
所有购买dll版的用户,均赠送sql脚本及与exe版一样或相似的调用代码示例,共以下几种:
delphi6.0
c++builder5.0
vb5.0
pb7.0使用及购买协议本通用权限管理系统的exe版免费提供用户测试使用, 购买dll版费用为rmb100元整,提供dll、sql脚本和delphi、bcb、vb、pb调用的原程序示例. 购买dll的delphi6源代码费用为rmb500元整.不管是免费的, 购买的, 程序、源程序及sql脚本的版权为作者所有. 用户购买所得的文件或代码、脚本只限于用户自己或本单位研发、发布系统使用, 不得免费或有偿再次发布、公布. 如不同意以上协议, 作者将不接受购买. 联系作者来信/汇款地址:
321409 浙江省缙云县大源镇稠门一村10号 李岳金收
招商银行一卡通帐户:057150424609
主页地址:http://elsesoft.home.sohu.com
emailto:llii@163.net
开寅软件工作室 ©1999-2001
用户权限管理这就是用户权限管理的窗口,(如果不用ado事务处理,下面将没有”取消”和”保存”按钮)
请注意,这里我为了方便,很多地方都设了1、2、3,其实都可以设为字符串型数据,长度在20个字节以内,应该都够用了。另外,在添加组名称后,在组权限设置列表下应自动显示出可设置的权限项目,如果不是,则说明dbms不能良好的支持ado事务,请取消ado事务后重新进入。

你可以自己选择先添加用户还是先添加权限组,系统均会作完善处理。
一个用户按照设置不同,有三种状态,分别是”正常”、”过期”和”禁用”,只有处于””正常状态下的用户才能对系统登录成功。一个用户可以设置允许几个权限组的权限,他能在任一个权限组中允许的权限项目检测中通过。
对每一个权限组,你可以按功通、职责不同选取相应的权限项目。
组权限列表中的分组的作用和权限组的作用是相辅相承的:如果它的子项目全部没有选择,它也就没有选择,如果其中有一个或多个或全部选择了,它就被允许。你可以在进入一大模块之前检测用户有没有进入组的权限,如果有就放行,没有就不必进入了,因为他进去了也无事可做。

请输入用户id、用户姓名、密码,及指定是否有效和有效使用期限。
其中密码可以为空,也可以长达几十个字符。
用户id与现有id重复时将不能添加。

编辑用户信息时,不能更改用户id,如要更改,请删除后重新添加。

添加权限组只要输入不与现有组名称重复的就行了。
开寅软件工作室 ?1999-2001
函数声明软件设计者完全掌握权限管理不需要再绞尽脑汁, 使用通用权限管理工具dll版,只需声明10个函数即可, 若是也让我沾一下你的光彩, 多声明一个showabout也才11个。

本权限管理dll测试了四种通用mis开发工具的函数测试,均可使用。
c++builder、vb、pb请点击进入相应的页面查看,vc++我不熟, 但用的人全是高手, 我也就不献丑了, 照bcb的稍改一下就行。
下面以delphi的函数调用进行详细说明。

delphi(dll版提供本例本窗口的delphi6.0和c++builder5.0界面和代码)
强烈建议交付用户使用时更改dll的名称以及改声明dll的名称为相应的名称,以防止某些自以为是的人对其进行乱开发并破坏系统安全。

procedure showabout;stdcall; external qxdll.dll;
{这个不用说了吧?}
function connectdb(cnstr, user, pwd : pchar;
dt, enpwd : pchar): integer; stdcall; external qxdll.dll;
{连接数据库
参数说明:
cnstr : 就是上面要取得的连接参数
user : 登录数据库的用户id
pwd : 登录数据库的密码 
dt : 日期格式为yyyy-mm-dd, 为空时取计算机日期
enpwd : 密码加密因子
返回值 : 
0, 连接成功
1, 连接失败
}
procedure disconnectdb;stdcall; external qxdll.dll;
{断开数据库连接}
procedure editqxlist(tran : integer);stdcall;
{参数说明: 1 : 用事务处理, 0 : 不用事务处理}
{打开权限列表维护窗口, 可不用声明, 因为最终用户不需要}
procedure qxmanager(tran : integer); stdcall; external qxdll.dll;
{参数说明: 1 : 用事务处理, 0 : 不用事务处理}
{打开权限管理窗口, 这个最重要}
function logincheck(userid, pwd, dt, errstr : pchar;
syserr : integer) : integer;stdcall; external qxdll.dll;
{用户登录你的系统
参数说明:
userid : 登录到管理系统的用户名
pwd : 登录到管理系统的密码
dt : 同上一个函数,主要考虑到有的系统几天不关机,
好让软件知道刚才想登录的用户过期了没有
errstr : 如果用户登录失败, 你想在dll中显示自己的信息时使用,
可以为空字符串
syserr : 登录失败处理方式,
0, 由你的程序自己处理
1, 仅显示errstr所提供的信息
2, 由dll来显示出错信息 
返回值 : 
0, 登录成功
1, 用户被禁止使用
2, 用户使用期限已过
3, 密码不正确
4, 无此用户
}
function showloginform(cap, dt : pchar;
var userid: pchar;var sec : integer) : integer;stdcall;
{用本dll的登录对话框处理用户登录}
{参数说明:
cap : 登录对话框的标题
dt : 同上一个函数,主要考虑到有的系统几天不关机,
好让软件知道刚才想登录的用户过期了没有
userid : 返回刚才登录用户的userid的缓冲区
sec : 10以上, 按秒计限时登录, 10以下,按次计限次登录.
登录成功时返回userid的长度
返回值 : 
0, 登录成功
1, 登录限定次数已到
2, 登录限定时间已到
3, 用户取消
下面分别是两种限定的登录对话框图示:

}
function changuserpwd(userid,oldpwd,newpwd,dt : pchar): integer;stdcall;
{更改用户密码
参数说明:
userid : 登录到管理系统的用户名
oldpwd : 原来的密码
newpwd : 新密码
dt : 同上
返回值 : 
0, 更改成功
1, 用户被禁止使用,所以不能更改
2, 用户使用期限已过,所以不能更改
3, 密码不正确,所以不能更改
4, 无此用户,所以不能更改
5, 新旧密码相同,所以不更改
6, 不明原因致使修改不成功}
function showchanguserpwdform(userid,dt : pchar): integer;stdcall;
{用本dll的登录对话框处理密码更改
参数为用户id和日期
返回值:0 : 成功, 1 : 不成功
下面是用户改更密码对话框的图示:

}
function getusernamefromid(userid : pchar;
var username : pchar): integer;stdcall;
{取得相应用户id的用户名字
参数说明:
userid : 用户id
username: 返回检查到的用户名字的缓冲区
返回值:
0 : 没有取得这个id的名字,
其它 : 返回username的长度}
function userqxcheck(userid : pchar; qxid : integer;
errstr : pchar; syserr : integer) : integer; stdcall; external qxdll.dll;
{检查某用户是否可使用某一功能的权限
参数说明:
userid : 要检查权限的用户id
qxid : 要检查的权限id, 注意, 是整数型值
errstr : 同上一函数
syserr : 同上一函数

返回值 : 
0, 有使用此功能的权限
1, 没有使用此功能的权限

开寅软件工作室 ©1999-2001

 

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 通用权限管理工具,支所有ADO(包括ODBC)支持的数据库,不管用什么编程都行,VC/BCB/VB/PB/Delphi-数据库专栏,其他相关
分享到: 更多 (0)