中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 数据库开发 > 数据库综合
登录口令加密函数、用户登录主Form实现方法和具体代码
作者:未知 时间:2005-07-27 23:37 出处:CSDN 责编:chinaitpower
              摘要:登录口令加密函数、用户登录主Form实现方法和具体代码
create函数PWD:
create FUNCTION PWD(sdpassword varchar2) RETURN varchar2 IS 
  len   number; 
  szpwd varchar2(20); 
BEGIN 

   len:=length(sdpassword); 
   for i in 1..len loop 
     szpwd:=szpwd|| 
                 chr(ascii(substr(sdpassword,i,1))+(len-i)*i*i+len); 
   end loop; 
   return(szpwd); 

END; 


具体使用:
1.在Block中加一Trriggers:Key-Others,代码:null; 防止用户用Shift + F7非法进入。
2.在OK确定Button加一When-Button-Pressed,代码:
DECLARE
   szpwd         VARCHAR2 (20);         --密码
   szjmpwd       VARCHAR2 (20);         --加密码
   szjs          VARCHAR2 (10) := '4';  --角色
BEGIN
   SELECT PASSWORD, js
     INTO szpwd, szjs
     FROM prid01                       --权限管理中的用户登记表
    WHERE userid = :login.userid;

   szjmpwd := pwd (NVL (:login.PASSWORD, '@'));

   IF szpwd = szjmpwd THEN
      :GLOBAL.userid := :login.userid;
      :GLOBAL.username := :login.username;
      :GLOBAL.js := szjs;
      :GLOBAL.PASSWORD := :login.PASSWORD;
      :GLOBAL.nls_lang := :login.nls_language;
      --init_menu;            --初始化菜单权限
      --init_nav;             --初始化工具条上的ERP流程图权限
      --init_nav_hr;         --初始化工具条上的人力资源模块流程图权限
      GO_BLOCK ('MAIN');
      --SET_ITEM_PROPERTY('NO_DISPLAY_NEXT_TIME',VISIBLE,PROPERTY_TRUE);
      --SET_ITEM_PROPERTY('NO_DISPLAY_NEXT_TIME',ENABLED,PROPERTY_TRUE);
      --EXECUTE_TRIGGER('HINT');   --执行每日一帖小程序
   ELSE
      messagebox.messagebox (nls_error (nls_lang, '00004')); 
                    --这是我自做的多语言messagebox,你们可用你们的
      GO_ITEM ('LOGIN.password');
   END IF;
EXCEPTION
   WHEN NO_DATA_FOUND THEN
      messagebox.messagebox (nls_error (nls_lang, '00007'));
                    --这是我自做的多语言messagebox,你们可用你们的
      GO_ITEM ('LOGIN.userid');
   WHEN OTHERS THEN
      messagebox.messagebox (SQLERRM);
END;

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有