我想隐藏维护页面并设置关于“最终用户”的规定,我在 oracle apex 中创建应用程序。现在我有 2 个用户帐户:一个是名为 A 的管理员,一个是名为 B 的最终用户。管理员可以编辑、插入和删除数据,但最终用户不能这样做。最终用户可以做的就是查看数据。
现在两者都可以看到所有页面,最终用户可以做任何事情。怎么存档呢?我找到了有关身份验证方案的信息,这可能与我的问题有关。但我不知道怎么写。请提出解决方案。
我想隐藏维护页面并设置关于“最终用户”的规定,我在 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.
为管理员用户创建相同的功能。
现在,转到共享组件、授权方案,并创建一个新方案:
return f_is_end_user(:APP_USER);
对“管理员”用户执行相同操作。
回到您的应用程序。导航到页面并设置其Authorization Scheme。
{Not end_user}
很容易,不是吗?