SFDC:关于with sharing和without sharing 关键字声明Apex类,涉及到的CRUD/FLS/SHARING的个人总结

2023-11-10 07:50

本文主要是介绍SFDC:关于with sharing和without sharing 关键字声明Apex类,涉及到的CRUD/FLS/SHARING的个人总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在Salesforce实际开发中,开发者或多或少都会遇见由于操作者权限不足导致的代码报错等BUG,那么到底该如何规避这些问题呢?

关于本篇文章我想叙述的重点在于 fls/crud 对VF端渲染的影响:

首先,为了测试准备好测试代码以及测试用户。

VF PAGE:注意两个pageblock对应的是同一个对象的两个字段,每一个pageblock内对应的是同一个字段的不同展现形式(不同的标签)


CONTROLLER:


1.当我用户的简档对于Account的权限为:all no。

页面无内容展示。

2.当我用户的简档对于Account的权限为:

页面展示:

会发现,apex:inputfield无效,并且这个时候对于SLA__C字段都看不见,原因是什么?

既然看不见 ,那我们就要往字段级别考虑,由于该用户对Account有读取权限,那么我们首先要检查字段的级别:


Name:


SLA__C:


经过对比发现我们的猜想是对的!这里要额外注意的是inputtext不受FLS控制。

那么说到这里,你可能有疑惑,


接下来点击保存后:日志报错:

System.VisualforceException: 创建访问权限因为 Account 而被拒绝,控制器操作方法可能无法执行。

这个错误的原因:当你对一个对象没有创建的权限时,你可以在controller里new xxx(),此时如果你在前台用apex:inputxxx 标签渲染改对象,那么save之后系统首先会将这个错抛出来;如果你没引用只是在后台new object ,并保存 这个object,那么不会有任何问题!

3.当权限调整为:


结果同2。


4.当权限调整为:


结果略有不同的是,inputfield 生效了。

首先总结一下关于crud和fls在VF页面的控制(不论是否声明):

(1)当你对一个对象没有查看权限,那么你在前台是渲染不出数据来的

(2)当你有编辑对象的权限时,VF的apex:inputxxx 是enforce 你 遵守FLS级别的控制!

(3)在controller内,及时你没有这个字段的权限,你是一样可以拿到的!

不知道大家看到这里能否理解(第一次写SF博客,还请见谅)。。。


最后上一个总结(只说明一下with/without/no declare 的作用):你可能会疑惑为什么你没有说 是否声明sharing对于页面渲染的问题。经过我的测试是没有区别的,具体结果还需各位自己亲身验证一下最好!

关于sharing的类声明,其实我的理解就是Force.com 对你 所获取记录的控制(你能看到多少记录那就意味着你能拿到多少记录)。那么说到这里你可能会问,拿到记录你能都编辑么?答案肯定的告诉你:能(无论你是否有编辑和创建记录的权限,不涉及页面)。类级别的代码不enforce你的权限。

但是!!!卖个关子:

        这里留一个题,既然类不强制你的权限,那么当我在后台保存一个查找字段的时候与 声明sharing 有无关系?如果有,原因是什么?

声明一下:本篇文章的内容都属于个人的总结,如果有纰漏或者错误的地方欢迎大家提出,本人联系方式QQ34697865.

文章后期维护!

如有雷同纯属巧合嘻嘻嘻


















这篇关于SFDC:关于with sharing和without sharing 关键字声明Apex类,涉及到的CRUD/FLS/SHARING的个人总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/381324

相关文章

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Python程序的文件头部声明小结

《Python程序的文件头部声明小结》在Python文件的顶部声明编码通常是必须的,尤其是在处理非ASCII字符时,下面就来介绍一下两种头部文件声明,具有一定的参考价值,感兴趣的可以了解一下... 目录一、# coding=utf-8二、#!/usr/bin/env python三、运行Python程序四、

Java 关键字transient与注解@Transient的区别用途解析

《Java关键字transient与注解@Transient的区别用途解析》在Java中,transient是一个关键字,用于声明一个字段不会被序列化,这篇文章给大家介绍了Java关键字transi... 在Java中,transient 是一个关键字,用于声明一个字段不会被序列化。当一个对象被序列化时,被

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有

Linux区分SSD和机械硬盘的方法总结

《Linux区分SSD和机械硬盘的方法总结》在Linux系统管理中,了解存储设备的类型和特性是至关重要的,不同的存储介质(如固态硬盘SSD和机械硬盘HDD)在性能、可靠性和适用场景上有着显著差异,本文... 目录一、lsblk 命令简介基本用法二、识别磁盘类型的关键参数:ROTA查询 ROTA 参数ROTA

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)