在 ORACLE APEX 中"end user"用户时隐藏维护页面



我想隐藏维护页面并设置"最终用户"的规定 我正在oracle apex中创建应用程序。目前我有 2 个用户帐户:一个是名为 A 的管理员,一个是名为 B 的最终用户.管理员可以编辑、插入和删除数据,但最终用户不能这样做。最终用户可以做的只是查看数据。

目前,两者都可以看到所有页面,最终用户可以执行所有操作。如何存档?我找到了有关身份验证方案的信息,这可能与我的问题有关。但我不知道怎么写。请提出解决方案。

一个简单的选项是创建一个函数,说明某个用户是否是最终用户。例如:

create table users
(username   varchar2(30),
user_role  varchar2(20)
);
insert into users (username, user_role)
select 'Little', 'Admin'   from dual union all
select 'Foot'  , 'EndUser' from dual;
create or replace function f_is_end_user (par_app_user in varchar2)
return boolean
is
l_one number(1);
begin
select max(1) 
into l_one
from users
where username = par_app_user
and user_role = 'EndUser';
return l_one = 1;
end;
/

测试:

SQL> begin
2    dbms_output.put_line(case when f_is_end_user('&par_app_user') then 'it is end user'
3                              else 'it is NOT end user'
4                         end);
5  end;
6  /
Enter value for par_app_user: Little
it is NOT end user
PL/SQL procedure successfully completed.
SQL> /
Enter value for par_app_user: Foot
it is end user
PL/SQL procedure successfully completed.

为管理员用户创建相同的函数。

现在,转到共享组件、授权方案,然后创建一个新方案:

  • 将其命名为"end_user">
  • 类型:返回布尔值的PL/SQL函数
  • 功能主体:return f_is_end_user(:APP_USER);
  • 错误消息:"您无权执行此操作。

对"管理员"用户执行相同的操作。

回到您的应用程序。导航到页面并设置其授权方案

  • 例如,如果不想让最终用户查看页面,请将其设置为{Not end_user}
  • 您也可以对任何项目执行此操作;如果您不想让最终用户使用"保存"按钮,则可以修改按钮的"授权方案"属性。

很容易,不是吗?

最新更新