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

Reacting to URL parameters

The URL parameters are used to pass information to Visualforce pages that the page or controller can then react to. For example, setting a record ID parameter into the URL for a page that uses a standard controller causes the controller to retrieve the record from the database and make it available to the page.

In this recipe, we will create a Visualforce search page to retrieve all accounts where the name contains a string entered by the user. If the parameter name is present in the page URL, a search will be run against the supplied value prior to the page being rendered for the first time.

Getting ready

This recipe makes use of a custom controller, so this will need to be created before the Visualforce page.

How to do it...

  1. Navigate to the Apex Classes setup page by clicking on Your Name|Setup|Develop|Apex Classes.
  2. Click on the New button.
  3. Paste the contents of the SearchFromURLController.cls Apex class from the code download into the Apex Class area.
  4. Click on the Save button.
  5. Next, create the Visualforce page by navigating to the Visualforce setup page, clicking on Your Name|Setup|Develop|Visualforce Pages.
  6. Click on the New button.
  7. Enter SearchFromURL in the Label field.
  8. Accept the default SearchFromURL that is automatically generated for the Name field.
  9. Paste the contents of the SearchFromURL.page file from the code download into the Visualforce Markup area.
  10. Click on the Save button to save the page.
  11. Navigate to the Visualforce setup page by clicking on Your Name|Setup|Develop|Visualforce Pages.
  12. Locate the entry for the SearchFromURL page and click on the Security link.
  13. On the resulting page, select which profiles should have access and click on the Save button.

How it works...

Opening the following URL in your browser retrieves all accounts where the Name field contains the text ni :  https://<instance>/apex/SearchFromURL?name=ni.

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

The constructor of the custom controller is the first method to be called when a Visualforce page is retrieved. This attempts to extract a value for the parameter Name from the page URL, and if one has been supplied, executes the search:

public SearchFromURLController() 
{ 
  searched=false; 
  String nameStr= 
    ApexPages.currentPage().getParameters().get('name'); 
  if (null!=nameStr) 
  { 
      name=nameStr; 
      executeSearch(); 
  } 
} 

Note

Note that the constructor also sets the value retrieved from the URL in the Name property. This property is bound to the input field on the page, and causes the input field to be prepopulated with the value retrieved from the URL when the page is first rendered.

The action method that executes the search is as follows:

public PageReference executeSearch() 
{ 
  searched=true; 
  String searchStr='%' + name + '%'; 
  accounts=[select id, Name, Industry, Type from Account where name LIKE :searchStr]; 
     
  return null; 
} 

Note

Note that searchStr is constructed by concatenating the search term with the % wildcard characters; this allows the user to enter a fragment of text rather than full words. Also, note that the concatenation takes place outside the SOQL query and the resulting variable is included as a bind expression in the query. If the concatenation takes place directly in the SOQL query, no matches will be found. This approach also helps to defend against SOQL injection attacks, as any text input by the user is surrounded by characters that stop embedded database commands from being executed.

See also

  • The Passing parameters between Visualforce pages recipe in this chapter shows how URL parameters can be used to maintain the state across pages that do not share the same controller.
主站蜘蛛池模板: 北宁市| 万宁市| 房产| 聂荣县| 苏尼特左旗| 屯留县| 利川市| 连南| 肇庆市| 镇安县| 湖口县| 惠来县| 普洱| 巴楚县| 伊吾县| 尉氏县| 凉山| 鸡泽县| 朝阳市| 油尖旺区| 卢湾区| 图们市| 长宁县| 独山县| 蒲江县| 衡南县| 日照市| 肥东县| 托克托县| 定兴县| 吉水县| 曲水县| 珲春市| 大兴区| 永靖县| 靖远县| 陆河县| 文安县| 贵港市| 太和县| 石狮市|