Access编程交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • 在Access中实现密码管..
  • 防止Access 2000..
  • 禁止使用SHIFT键打开M..
  • Access 2000数据..
  • 加解密文本的函数
  • 设置只有管理员才能改变Al..

最新文章

  • 获取字符的Unicode编..
  • Access对数据表进行加..
  • Access 下Base6..
  • Access VBA可用的..
  • 获取电脑的网卡物理地址
  • 在 Access 2010..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > 模块/函数/VBA/API/系统 > 加密解密安全
加密解密安全

Access如何能通过窗体访问表,但不能直接读取表?

问题:

 如何能通过窗体访问表,但不能直接读取表?
我需要让用户不能直接打开我的表,但是可以通过我编写的窗体来打开这些表,这样我就可以编程控制一些字段的数据了。

回答:


原理:

可以通过 ACCESS 自身的安全向导结合 JET SQL 中 SELECT 查询的 WITH OWNERaccess OPTION 声明来完成。
WITH OWNERaccess OPTION 在具有安全工作组的多用户环境中,使用该声明和查询给运行该查询的用户与查询所有者相同的权限。
A、你只要将某个表的所有者设定为某个自定义用户,而该用户属于管理员组,对表有读取、修改权限。
B、设定在默认情况下用户组都拥有打开窗体的权限,但没有读取表的权限
C、用WITH OWNERaccess OPTION来建立窗体的数据源,赋予普通用户拥有表的所有者才拥有的修改读取权限。这样使用者就只能通过你的窗体来访问数据表了。
D、发布的时候无需发布你的 MDW 文件,因为客户那里默认会以用户组的权限打开你的数据库,这样就达到你的目的了。


实际操作:

1、建立一个数据库,里面有1个表(表1),一个窗体(窗体1),设置“窗体1”的数据源为
SELECT * FROM 表1 WITH OWNERaccess OPTION 

 

2、请再参考一遍微软的文章中以下章节
《使用 Security Wizard 设置 access 数据库的安全性》
 

3、将其中的第8步的“是,要授予用户组一些权限”点上

4、赋予用户组“打开/运行”数据库的权限;赋予用户组“打开/运行”窗体1的权限,然后单击“下一步”,其他的照上面那篇文章做

5、用快捷方式附带工作组启动 MDB 文件,然后设置你的新管理员(以示例来说就是  frice )对 表1 的“管理”权限

6、完成后不要用快捷方式附带工作组启动,直接启动 MDB 文件看看效果如何?


7、再回头看一下 WITH OWNEERaccess OPTION 的帮助吧
WITH OWNERaccess OPTION 声明
在具有安全工作组的多用户环境中,使用该声明和查询给运行该查询的用户与查询所有者相同的权限。

语法
sqlstatement
    WITH OWNERaccess OPTION;

说明
WITH OWNERaccess OPTION 声明是可选的。

下列示例使用户能够查看工资信息(即使用户没有权限查看工资表),提供查询主人拥有的权限:

SELECT LastName,

FirstName, Salary

FROM Employees

ORDER BY LastName

WITH OWNERaccess OPTION;


如果用户无法创建表或添加,可使用 WITH OWNERaccess OPTION来运行 制表或追加查询。

如果要强制工作组安全性设置及用户的权限,不要包含 WITH OWNERaccess OPTION 声明。

此选项要求您必须访问与该数据库相关的 System.mdw 文件。它只在安全的多用户实现中才真正有用。

 


 

发布人:cg1-Access911  
分享到:
点击次数:  更新时间:2005-02-05 13:23:48  【打印此页】  【关闭】
上一条:Microsoft Office 2003 中的信息权限管理  下一条:在Access Table中存储密码的安全性



相关文章

  • • 获取字符的Unicode编码、Ascii码、及各种编码转换加密解密
  • • Access对数据表进行加密解密
  • • Access 下Base64位加密解密类模块(支持中文加解密和特殊符号)
  • • Access VBA可用的Base64编码/解码模块
  • • 获取电脑的网卡物理地址
  • • 在 Access 2010 中设置或更改 Access 2003 用户级安全机制
  • • ACCESS安全机制中的工作组管理员文件如果防止被替换
  • • ACCESS丢失MDW,还能还原用户与用户组及权限相关信息吗

热门文章

  • [2003-12-13] 找回忘了的密码的原理access数据库
  • [2008-11-07] 如何用二进制方式编辑 MDB 使 ACCESS 无法正常打开?access数据库
  • [2008-10-22] Access处理加了密码的MDB数据库文件access数据库
  • [2006-11-25] 处理加了密码的MDB数据库文件access数据库
  • [2003-12-12] 限制软件试用次数及时间access数据库
  • [2005-02-05] Microsoft Office 2003 中的信息权限管理access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

中山市天鸣科技发展有限公司 版权所有 1999-2023 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2025  www.metinfo.cn