Access交流中心

北京 | 上海 | 天津 | 重庆 | 广州 | 深圳 | 珠海 | 汕头 | 佛山 | 中山 | 东莞 | 南京 | 苏州 | 无锡 | 常州 | 南通 | 扬州 | 徐州 | 杭州 | 温州 | 宁波 | 台州 | 福州 | 厦门 | 泉州 | 龙岩 | 合肥 | 芜湖 | 成都 | 遂宁 | 长沙 | 株洲 | 湘潭 | 武汉 | 南昌 | 济南 | 青岛 | 烟台 | 潍坊 | 淄博 | 济宁 | 太原 | 郑州 | 石家庄 | 保定 | 唐山 | 西安 | 大连 | 沈阳 | 长春 | 昆明 | 兰州 | 哈尔滨 | 佳木斯 | 南宁 | 桂林 | 海口 | 贵阳 | 西宁 | 乌鲁木齐 | 包头 |

怎样取消数据库被打开时候自动关闭?

wwylove  发表于:2009-10-03 10:56:16  
复制

在网上下载了一个data,打开的时候需要密码,我输入密码,然后打开,但是data自动关闭了。请问怎样取消呢?点击下载此附件

 

Top
点燃一支烟 发表于:2009-10-03 11:31:53

点击下载此附件 

1、打开数据库的密码已经帮你取消;

2、造成关闭的原因是有一个名为AutoExec的宏,改宏运行了一段代码(可能是该代码设定了某种条件,当不满足时就关闭数据库),而该vba代码已被原作者加密了,需解密才能打开,这里将该宏删除了,该宏是一个特殊的宏,意味着一开数据库就自动运行它



点燃一支烟 发表于:2009-10-03 11:33:18
该数据库很多表都设置了隐藏,须在工具-选项里面勾选查看隐藏对象

点燃一支烟 发表于:2009-10-03 16:00:53

Public Function SetBypassProperty()
Const DB_Boolean As Long = 1
    ChangeProperty "AllowBypassKey", DB_Boolean, False
End Function

Public Function ChangeProperty(strPropName As String, varPropType As Variant, varPropValue As Variant) As Integer
    Dim dbs As Object, prp As Variant
    Const conPropNotFoundError = 3270

    Set dbs = CurrentDb
    On Error GoTo Change_Err
    dbs.Properties(strPropName) = varPropValue
    ChangeProperty = True

Change_Bye:
    Exit Function

Change_Err:
    If Err = conPropNotFoundError Then    ' Property not found.
        Set prp = dbs.CreateProperty(strPropName, _
            varPropType, varPropValue)
        dbs.Properties.Append prp
        Resume Next
    Else
        ' Unknown error.
        ChangeProperty = False
        Resume Change_Bye
    End If
End Function
这是模块PublicModule里面的代码,经破解后



点燃一支烟 发表于:2009-10-03 16:04:07
  这是宏的设计

点燃一支烟 发表于:2009-10-03 16:08:43
呵呵,原创者加了密码保护说明他的意思是“未经授权,不得引用”,是指不得引用做商业用途。所以请你谨慎使用。

点燃一支烟 发表于:2009-10-03 16:12:03
关闭的原因是因为 “quit”

符鸿敏 发表于:2009-10-03 20:23:47
 点燃一支烟 版主真是厉害和强大!佩服了,仰视了!

wwylove 发表于:2009-10-03 21:14:19

dengshaobin版主真的是太厉害了! 



wwylove 发表于:2009-10-03 21:20:08

是在想不明白的是,进去了data自动关闭,版主如何能够修改宏的和破解呢?

 我是抱着学习的目的来考虑的,也是初学者,想看看别人做系统是怎样设计表的,我深明大家都不容易,实在没有商业用途的意思,而且水平也不够应用到商业用途。



总记录:9篇  页次:1/1 9 1 :