官术网_书友最值得收藏!

Adding a launch page

When a Visualforce page is deployed to production, only users whose profiles have been given access via the security settings will be able to access the page. Any user with a profile that does not have access will receive an Insufficient Privileges error, which is not a good experience and can lead users to think that the page is crashing.

A better solution is to check whether the user has access to the page and if they do not, present a user-friendly message that explains the situation and directs them to where they can get more help.

In this recipe we will create a launch page accessible to all profiles that checks if the user has access to the protected page. If the user has access, they will be transferred to the protected page, while if they don't, they will receive an explanatory message.

How to do it…

This recipe requires a second user login. Ensure that this is not created with the System Administrator profile, as that profile has access to all Visualforce pages regardless of the security settings.

  1. Navigate to the Visualforce setup page by clicking on Your Name | Setup | Develop | Pages.
  2. Click on the New button.
  3. Enter Protected in the Label field.
  4. Accept the default Protected that is automatically generated for the Name field.
  5. Paste the contents of the Protected.page file from the code download into the Visualforce Markup area.
  6. Click on the Save button to save the page.
  7. Navigate to the Visualforce setup page by clicking on Your Name | Setup | Develop | Pages.
  8. Locate the entry for the Protected page and click on the Security link.
  9. On the resulting page, ensure that the profile of your second user does not have access to the Protected page.
  10. Log in using your second user credentials and attempt to access any account record. You will receive an error message as shown in the following screenshot:
  11. Next, create the launch page controller by navigating to the Apex Classes setup page by clicking on Your Name | Setup | Develop | Apex Classes.
  12. Click on the New button.
  13. Paste the contents of the LaunchController.cls Apex class from the code download into the Apex Class area.
  14. Click on the Save button.
  15. Navigate to the Visualforce setup page by clicking on Your Name | Setup | Develop | Pages.
  16. Click on the New button.
  17. Enter Launch in the Label field.
  18. Accept the default Launch that is automatically generated for the Name field.
  19. Paste the contents of the Launch.page file from the code download into the Visualforce Markup area.
  20. Click on the Save button to save the page.
  21. Navigate to the Visualforce setup page by clicking on Your Name | Setup | Develop | Pages.
  22. Locate the entry for the Setup page and click on the Security link.
  23. On the resulting page, give access to all of the profiles and click on the Save button.

How it works…

Log in using your second user credentials and open the following URL in your browser: https://<instance>/apex/Launch.

Here, <instance> is the Salesforce instance specific to your organization, for example, na6.salesforce.com.

The resulting page displays a friendly error message detailing that your user does not have access to the page, and renders a clickable link to request access.

The Launch page declaration contains an action attribute.

<apex:page controller="LaunchController" action="{!allowAccess}">

This invokes the allowAccess action method in the controller before the page is rendered.

public PageReference allowAccess()
{
PageReference pr=Page.Protected;
   try
   {
       pr.getContent();
        }
   catch (Exception e)
   {
       pr=null;
   }
        
        return pr;
    }

The allowAccess method attempts to retrieve the contents of the protected page programmatically. If the contents are retrieved successfully, it returns the page reference for the Protected page, which redirects the user to that page. If an exception occurs, the method returns null, which leaves the user on the Launch page and displays the friendly error message.

主站蜘蛛池模板: 个旧市| 新田县| 水城县| 平江县| 东兰县| 永顺县| 卢氏县| 许昌市| 漳平市| 顺义区| 临高县| 大石桥市| 武清区| 马边| 资阳市| 纳雍县| 神农架林区| 靖江市| 和静县| 皮山县| 东乡族自治县| 临汾市| 南丹县| 雅江县| 娱乐| 鹿泉市| 凉城县| 漳浦县| 武汉市| 金塔县| 凌海市| 五河县| 通化县| 长兴县| 泰宁县| 广灵县| 额敏县| 当雄县| 河源市| 古丈县| 林西县|