Introducing ColdFusion MX

Welcome to ColdFusion MX! ColdFusion is one of the easiest-touse programming languages, yet it can build the most powerful, extensible Web applications in the world. ColdFusion’s elegant simplicity is appreciated by both novice programmers who want a fast start on building real-world applications and experienced developers coming from complicated Web technologies such as Active Server Pages. You may be wondering how much effort learning ColdFusion takes. This really is up to you, because the more time that you spend with ColdFusion, the better you become with it. If you already know a little HTML and you just want to build a simple Web site that presents your collection of antique whistles to the world, you can probably be online with your first application in anywhere from three days to a week. A few more weeks of diligent practice are likely to see you selling your whistles over the Internet, and in a year, who knows . ? You may start building WorldWhistleExchange.com! You need to know surprisingly little before diving into ColdFusion, but the more experience that you have with other programming languages, the better. If you know a little HTML and you understand how the Internet works, you’re good to get started. If you’ve heavily programmed in a language such as C++ or Java, you’re home free, because you’re already familiar with solid programming concepts. If you’re just beginning your first foray into the world of programming and the Internet, be aware that you need to spend plenty of time going over the basics that we present in Part I of this book. You should also get involved in your local ColdFusion user group, which is sure to be an excellent resource for learning new techniques. The bottom line is that anyone can learn ColdFusion—it’s just a matter of trying.

pdf125 trang | Chia sẻ: tlsuongmuoi | Lượt xem: 2278 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Introducing ColdFusion MX, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
CHURVIS, HELMS, AREHART, & CHURVIS If ColdFusion MX can do it, you can do it too . . . As e-business continues to grab market share, you’re continually challenged to create faster, cheaper, and more reliable e-commerce Web applications. ColdFusion MX offers the quickest, most reliable way to build and deploy them, and this comprehensive reference guides you from writing your first application all the way through the complexities of integrating with Web services, Flash, Java, COM, and XML. From installation to database connection configuration, from tag and function usage to code reuse, it’s like having your personal team of experts on call. Inside, you’ll find complete coverage of ColdFusion MX • Create highly interactive, database-driven Web sites with ColdFusion’s intuitive, tag-based programming language • Build and deploy content publishing systems, online stores, business reporting applications, self-service solutions, and more • Easily create and use Web services and ColdFusion Components • Integrate applications with other technologies like Java, COM, and XML • Learn how — and why — to document your code, handle source version control, and integrate security, testing, and performance • Discover how to use ColdFusion with databases, Web services, and Flash Remoting • Extend ColdFusion applications with features like task scheduling, file operations, Verity text searching, and charting Shelving Category: Internet / Web Site Design Reader Level: Beginning to Advanced System Requirements: PC running Windows 98, Windows 2000, Windows NT4 (SP6a or later) or Windows XP. See the What’s on the CD-ROM Appendix for details and complete system requirements. ISBN 0-7645-4622-8 $49.99 USA $74.99 CANADA £37.50 UK C o l d F u s i o n M X Invigorate your Web sites with ColdFusion’s rich development language Activate the power of ColdFusion to build more robust applications Integrate CFMX with powerful technologies like Flash, JSP, XML, and COM Adam Phillip Churvis, Hal Helms, Charles Arehart, and David Churvis ,!7IA7G4-fegcci!:p;o;t;T;T Trial software and code listings on CD-ROM w w w . w i l e y . c o m / c o m p b o o k s / Logical Data Model (LDM) CategoryCode (PK)(FK) varchar(4) NOT NULL ItemNumber (PK)(FK) varchar(15) NOT NULL CategoryInventoryItem Physical Data Model (PDM) InventoryItem ItemNumber VARCHAR(15) NOT NULL ParentItemNumber VARCHAR(15) NULL Description VARCHAR(40) NOT NULL UnitPrice NUMERIC(12,2) NOT NULL Category CategoryCode VARCHAR(4) NOT NULL CategoryName VARCHAR(20) NOT NULL InventoryItem ItemNumber (PK) varchar(15) NOT NULL ParentItemNumber varchar(15) NULL Description varchar(40) NOT NULL UnitPrice numeric(12,2) NOT NULL Category CategoryCode (PK) varchar(4) NOT NULL CategoryName varchar(20) NOT NULL 100% O N E H U N D R E D P E R C E N T COMPREHENSIVE AU THO R I TAT I V E WHAT YOU NEED O N E H U N D R E D P E R C E N T Bonus CD-ROM • Trial versions of Adalon Developer Edition, CommerceBlocks, DataFactory, LoRCAT, SourceOffSite, and Macromedia ColdFusion Server MX, plus other software • Author files, code listings and samples, and real-world applications you can use • Searchable e-version of the book ColdFusion MX Bible Perfect Bind • Trim: 7 3/8 x 9 1/4 • • 4 color process • Yellow prints 110y 15m • + spot varnish (see spot varnish pdf) • Matte laminate *85555-ABJGHg 100% C O M P R E H E N S I V E ® C o l d F u s i o n M X ® ® BONUS CD-ROM AND COMPANION WEB SITE Software samples on CD-ROM plus more resources online Learn database modeling, triggers, and stored procedures Company.cfc ... Model Layer ColdFusion Components Controller Layer Flash Remoting Gateway View Layer Flash Movie 1 2 3 4 5 User chooses company, which triggers change handler funcion getCompany() function GetCompany_Result(companyRecord) { companyName_txt.text = companyRecord.items[0].CompanyName; address_txt.text = companyRecord.items[0].Address; city_txt.text = companyRecord.items[0].City; state_txt.text = companyRecord.items[0].State; zipCode_txt.text = companyRecord.items[0].ZipCode; 6 Flash movie's GetCompany_Results() ActionScript function populates movie fields from returned record, which is received as an object named companyRecord ActionScript getCompany() calls GetCompany(companyID) in gateway Gateway routes request with company ID to . . . (Company.cfc).GetCompany() Gateway routes responnse with compRec to . . . (FlashMovie).GetCompany_Result() This is one view element... ...and this is a second view element. Choose Company: ABC Company, Inc. Company Name: ABC Company, Inc. Address: 1234 Main Street City: Atlanta State: GA Zip Code: 30303 Create a complete Flash Remoting application Companion Web site at www.wiley.com/compbooks/churvis provides code samples, useful links, and more 546228 Cover 1/22/03 12:26 PM Page 1 ColdFusion® MX Bible 546228 FM.F 1/31/03 3:07 PM Page i 546228 FM.F 1/31/03 3:07 PM Page ii ColdFusion® MX Bible Adam Phillip Churvis, Hal Helms, Charles Arehart, David Churvis 546228 FM.F 1/31/03 3:07 PM Page iii LIMIT OF LIABILITY/DISCLAIMER OF WARRANTY: WHILE THE PUBLISHER AND AUTHOR HAVE USED THEIR BEST EFFORTS IN PREPARING THIS BOOK, THEY MAKE NO REPRESENTATIONS OR WARRANTIES WITH RESPECT TO THE ACCURACY OR COMPLETENESS OF THE CONTENTS OF THIS BOOK AND SPECIFICALLY DISCLAIM ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. NO WARRANTY MAY BE CREATED OR EXTENDED BY SALES REPRESENTATIVES OR WRITTEN SALES MATERIALS. THE ADVICE AND STRATEGIES CONTAINED HEREIN MAY NOT BE SUITABLE FOR YOUR SITUATION. YOU SHOULD CONSULT WITH A PROFESSIONAL WHERE APPROPRIATE. NEITHER THE PUBLISHER NOR AUTHOR SHALL BE LIABLE FOR ANY LOSS OF PROFIT OR ANY OTHER COMMERCIAL DAMAGES, INCLUDING BUT NOT LIMITED TO SPECIAL, INCIDENTAL, CONSEQUENTIAL, OR OTHER DAMAGES. ColdFusion® MX Bible Published by Wiley Publishing, Inc. 909 Third Avenue New York, NY 10022 www.wiley.com Copyright © 2003 by Wiley Publishing, Inc., Indianapolis, Indiana Library of Congress Number: 2001093600 ISBN: 0-7645-4622-8 Manufactured in the United States of America 10 9 8 7 6 5 4 3 2 1 1B/SQ/QS/QT/IN Published by Wiley Publishing, Inc., Indianapolis, Indiana Published simultaneously in Canada No part of this publication may be reproduced, stored in a retrieval system or transmitted in any form or by any means, electronic, mechanical, photocopying, recording, scanning or otherwise, except as permitted under Sections 107 or 108 of the 1976 United States Copyright Act, without either the prior written permission of the Publisher, or authorization through payment of the appropriate per-copy fee to the Copyright Clearance Center, 222 Rosewood Drive, Danvers, MA 01923, (978) 750-8400, fax (978) 750-4470. Requests to the Publisher for permission should be addressed to the Legal Department, Wiley Publishing, Inc., 10475 Crosspoint Blvd., Indianapolis, IN 46256, (317) 572-3447, fax (317) 572-4447, E-Mail: permcoordinator@wiley.com. For general information on our other products and services or to obtain technical support, please contact our Customer Care Department within the U.S. at 800-762-2974, outside the U.S. at 317-572-3993 or fax 317-572-4002. Wiley also publishes its books in a variety of electronic formats. Some content that appears in print may not be available in electronic books. Trademarks: Wiley, the Wiley Publishing logo and related trade dress are trademarks or registered trademarks of Wiley Publishing, Inc., in the United States and other countries, and may not be used without written permission. ColdFusion is a trademark or registered trademark of Macromedia, Inc. in the United States and/or other countries. All other trademarks are the property of their respective owners. Wiley Publishing, Inc., is not associated with any product or vendor mentioned in this book. is a trademark of Wiley Publishing, Inc. 546228 FM.F 1/31/03 3:07 PM Page iv About the Authors Adam Churvis is a database and scalability specialist with more than 20 years of software-industry experience in many languages and database platforms. He is the founder and President of Productivity Enhancement, a full-service consulting, train- ing, and commercial-software development firm, which is entering its 18th year in business and is also the parent company of ColdFusionTraining.com, which pro- vides the most advanced and intensive ColdFusion training in the world. Adam is a member of Team Macromedia and also serves as a current board member and for- mer President of the Atlanta ColdFusion User Group, and he enjoys speaking at other CFUGs as well. He has a wife, whom he worships, three children, three cats, and lots and lots of computers. He can be reached at adam@ProductivityEnhancement.com. Hal Helms is an internationally-known speaker, writer, and trainer on Java, ColdFusion, and best practices in software development. Hal writes the popular “Occasional Newsletter” available at halhelms.com, and you can reach him at hal@techspedition.com. Charles Arehart is the founder and CTO of SysteManage, based in Laurel, Maryland. A Macromedia certified advanced developer and instructor, Charles is also a member of Team Macromedia who has logged more than 5 years with ColdFusion and more than 20 years in IT. His monthly “Journeyman” column appears in ColdFusion Developer’s Journal, where he’s a technical editor. He is a regular speaker at developer conferences, seminars, and user group meetings worldwide, and also provides training and short-term consulting. You can reach him at carehart@systemanage.com. David Churvis is a software-development specialist who got his start in object- oriented programming at the age of eight. He has worked in HyperCard, SuperCard, FutureBasic, CFML, VTML/WIZML, Transact/SQL, PL/SQL, Delphi, C, C++, C#, Java, JSP, JavaScript, VBScript, and DHTML. David is Vice President of Development for Productivity Enhancement and is the chief programmer behind the CommerceBlocks line of modular ColdFusion development tools and LoRCAT, the Load Reduction and Concentration Analysis Tool for ColdFusion. 546228 FM.F 1/31/03 3:07 PM Page v Credits Senior Acquisitions Editor Sharon Cox Project Editor Sharon Nash Technical Editor Jen and Peter deHaan Copy Editor William A. Barton Editorial Manager Mary Beth Wakefield Vice President and Executive Group Publisher Richard Swadley Vice President and Executive Publisher Bob Ipsen Executive Editorial Director Mary Bednarek Project Coordinator Nancee Reeves Graphics and Production Specialists Melissa Auciello-Brogan, Beth Brooks, Jennifer Click, Joyce Haughey, Stephanie D. Jumper, Jeremey Unger Quality Control Technician Susan Moritz, Charles Spencer Permissions Editor Carmen Krikorian Media Development Specialist Travis Silvers Proofreading and Indexing TECHBOOKS Production Services 546228 FM.F 1/31/03 3:07 PM Page vi Adam Churvis: This book is dedicated to my uncle, Lionel Bernard Watkins II, and to the Marine Military Academy, for teaching me the most important Code of all. Semper Fidelis, Marines. Hal Helms: To Stan Cox, whose ideas never fail to inspire me. Charles Arehart: Begin to weave and God will give you the thread – German Proverb. David Churvis: I dedicate this book to Anne Granville, Neil Nichols, Pat Greeson, and Ed Coleman, the best schoolteachers I ever had. Thanks for never accepting anything less than my best and thanks for always believing in me. 546228 FM.F 1/31/03 3:07 PM Page vii 546228 FM.F 1/31/03 3:07 PM Page viii Preface ColdFusion has come a long way since its inception. Way back in 1995, AllaireCorporation came out with Version 1 of ColdFusion, and even then, develop- ers loved it and could see its potential. Several versions and one very important merger with Macromedia later, ColdFusion MX has positioned itself as a leading Web-application server, integrating many different Internet technologies, including XML, Web services, and Java. ColdFusion, at its core, is a server-side scripting environment that enables you to quickly get your sites up and running with much less code than the equivalent ASP, JSP, or PHP application requires but, at the same time, is even more powerful than these other languages. In fact, ColdFusion MX scripts are compiled into Java classes, and those Java classes are executed by an embedded version of JRun, Macromedia’s powerful J2EE server. This book is intended as a comprehensive tour of ColdFusion MX: It’s broad enough to give you a feel for everything that ColdFusion MX can do, but it’s deep enough that you can use the knowledge that you gain from this book to develop truly pow- erful ColdFusion applications. Whether you are a beginner or an expert, you should have the ColdFusion MX Bible in your reference library. How This Book Is Organized The scope of this book is rather broad and takes a natural progression, starting with a basic introduction, then moving on to using databases and the ColdFusion language itself before discussing more advanced concepts. The last part is the lan- guage reference, which has been organized very differently than most other refer- ences. There are nine parts to this book. Part I: Getting Started with ColdFusion MX The first part of the book incorporates seven chapters relating to the most basic aspects of ColdFusion. After a brief introduction, we provide a tutorial on building (and understanding) your first ColdFusion MX application. The rest of Part I focuses on the basics of the language itself, the underlying technology, and an intro- duction to using SQL effectively with ColdFusion. The last two chapters in Part I go into more detail about using forms and testing your code. 546228 FM.F 1/31/03 3:07 PM Page ix x ColdFusion MX Bible Part II: Using ColdFusion MX with Databases ColdFusion would be nearly useless without some kind of database as its backend. Part II starts with a chapter on database design, moves on to a discussion about using databases with ColdFusion, and then spends two whole chapters on effective and advanced database techniques. Even if you think that you know everything about databases, don’t skip this part of the book. Part III: The ColdFusion MX Language Part III focuses on the ins and outs of the ColdFusion language. The ten chapters in this section move from simple variables to complex variables such as arrays and structures before covering advanced topics such as user-defined functions, custom tags, state management, and exception handling. Part IV: ColdFusion MX Components, Web Services, and Flash Integration Part IV covers the new cutting-edge features of ColdFusion MX that can change the way that you write ColdFusion applications forever. The six chapters in Part IV should be read in order, because each builds on the concepts described in the pre- ceding chapter. Part IV starts out with two chapters about understanding and build- ing ColdFusion components and then discusses how and why you should move portions of your existing code to components. The last three chapters discuss Web services, Flash Remoting, and server-side ActionScript. Part V: Integrating ColdFusion MX with Other Technologies ColdFusion MX is most powerful if it’s extended with other technologies such as Java, COM, and XML. Part V consists of four chapters covering Java objects, JSP, EJB, COM, WDDX and XML, and some of the tags that ColdFusion uses to communi- cate with external systems. Spend some extra time on Chapter 30, as XML is about to become a big part of your development life. Part VI: Extending Your ColdFusion MX Applications Part VI covers additional features that you can use to extend ColdFusion, such as task scheduling, file operations, Verity, and charting, as well as some of the commu- nity resources and development tools that help make application development go much faster than normal. 546228 FM.F 1/31/03 3:07 PM Page x xiPreface Part VII: ColdFusion MX Development Practices Sometimes, how you code is as important as the code itself. Part VII covers important topics that are often overlooked, such as code documentation and testing, and also contains a discussion of Fusebox 3 written by none other than the Fusebox master himself, Hal Helms. The part also contains chapters about source-code control, effec- tive use of ColdFusion Studio, and integrating security into your applications. Part VIII: ColdFusion MX Administration Part VIII is comparatively short, but it’s packed with information about getting the most out of ColdFusion MX by tweaking its server settings. Part VIII is split into two chapters, the first covering all the settings available in ColdFusion Administrator and the second going into more detail about approaching specific settings and sets of options. Part IX: ColdFusion MX Language Reference Most language references use the format provided by Macromedia: an alphabetical listing of tags and functions (with tags separated from functions) and a separate list of categories. Part IX turns this model on its ear. Each section of the language (vari- ables, databases, forms, and so on) has its own chapter, and tags and functions are listed together in each chapter. This way, if you are working on a problem regarding database queries, you see all the tags and functions that are most often used to handle database queries in one place, which means that you nay also see what you’ve been missing in the language (such as, for example, CFOBJECTCACHE). If you need an alphabetical reference, we also provide a traditional alphabetized listing of all tags and functions with page references, and many tags cross-reference others so that, no matter what you’re looking for, you can easily find it. CD-ROM The CD-ROM that accompanies this book supplies you with a great deal of addi- tional material including author code listings and samples, many software applica- tions, and a PDF eBook version of the final book. The CD-ROM Appendix at the end of the book gives full details of all these items. 546228 FM.F 1/31/03 3:07 PM Page xi xii ColdFusion MX Bible How To Get The Most Out Of This Book Treat this book as you would a novel and not a cookbook. Most people, on picking up the ColdFusion MX Bible, would probably look up the one specific subject that they want to learn about and go directly there. Although this approach is certainly a valid one if you have a specific problem to solve, we recommend that, at some point, you start from the very beginning and work your way all the way through the book. If you are not a beginner, feel free to skip all of Part I but read everything after that. We recommend this approach even for advanced developers, because many people first starting out in ColdFusion unintentionally pick up some bad habits that remain with them even after they become better developers. The information contained in this book is based on sound development practices born of many years of experi- ence in many different languages and technologies. The first thing that we want to do is help you understand how ColdFusion works and how to get the most out of it, and the second is to make sure that no bad habits come back to haunt you. What the Icons Mean Throughout this book, you will find icons in the margins that highlight special or important information. Keep an eye out for the following icons: A Caution icon indicates a procedure that could cause difficulty or even data loss; pay careful attention to Caution icons to avoid common and not-so-common pro- gramming pitfalls. Cross-Reference icons point to additional information about a topic, which you can find in other sections of the book. A Note icon highlights interesting or supplementary information and often con- tains extra bits of technical information about a subject. Tip icons draw attention to handy suggestions, helpful hints, and useful pieces of advice. Tip Note Cross- Reference Caution 546228 FM.F 1/31/03 3:07 PM Page xii Acknowledgments We would like to take this opportunity to thank Sharon Cox, our AcquisitionsEditor, and Sharon Nash, our Project Editor, for making this project come together and for not making voodoo dolls of us when we missed submission deadlines. This book would not have achieved its high level of quality without the work diligently performed by its technical editors, Peter and Jen deHaan, and its copy editor, William Barton. If not for their dedicated involvement on these chapters, the end result would have been a book of measurably lower quality. We respectfully request to work with them again on all future Wiley books. We would also like to thank Alan Preston, Tom Donovan, and Raymond Camden at Macromedia for their excellent technical support and advice during the making of this book. Thanks also to the CFUG (ColdFusion User Group) and MMUG (Macromedia User Group) leaders who pour lots of unpaid hours into supporting their groups and the new technologies that Macromedia continues to give us. You are the backbone of the Macromedia development community, and the praises that you deserve would fill a book all by themselves. A special note of thanks to Michael Dinowitz, the father of the ColdFusion commu- nity, who has quite literally put his very life into the ColdFusion community. The countless hours that he has given us through developing and maintaining the House of Fusion Web site (www.houseoffusion.com) and its critically important mailing lists, the many speaking engagements that he has supported, and the father-like caring that he continues to have for everyone with a development prob- lem can never be sufficiently repaid. This praise is but a small token of what is due this truly admirable man. Behind every great man is a great woman, and Judith Dinowitz proves this axiom yet again. Judith’s tireless efforts running Fusion Authority (www.fusionauthority. com) have resulted in an accurate, up-to-the-minute account of everything ColdFusion on which many readers rely. And finally, thanks go out to you, the readers of this book, who make writing it all worthwhile. — Adam Churvis and David Churvis 546228 FM.F 1/31/03 3:07 PM Page xiii xiv ColdFusion MX Bible Thanks to my co-authors and to the indomitable folks at John Wiley & Son who made sure that you’re holding this book in your hands. — Hal Helms I can now appreciate better why so many authors thank their editors. What forbear- ance, with charm! Our two Sharon’s (Nash and Cox) were beacons in the night bringing this ship to port after more than 2 years at sea. Thanks too, of course, to Hal for bringing me on board initially and to Adam for captaining us through the rough seas. Last, and certainly not least, my love and inordinate gratitude to my wife Kim for her very own special patience through it all. — Charles Arehart 546228 FM.F 1/31/03 3:07 PM Page xiv Contents at a Glance Preface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ix Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xiii Part I: Getting Started with ColdFusion MX. . . . . . . . . . . . . . . . . 1 Chapter 1: Introducing ColdFusion MX. . . . . . . . . . . . . . . . . . . . . . . . . . 3 Chapter 2: Writing Your First ColdFusion MX Application . . . . . . . . . . . . . . 13 Chapter 3: Using ColdFusion MX Tags and Functions. . . . . . . . . . . . . . . . . 63 Chapter 4: Understanding Servers and Clients . . . . . . . . . . . . . . . . . . . . 77 Chapter 5: Learning a Little SQL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 Chapter 6: Using ColdFusion Forms . . . . . . . . . . . . . . . . . . . . . . . . . . 109 Chapter 7: Testing Your Code. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 Part II: Using ColdFusion MX with Databases . . . . . . . . . . . . . . 137 Chapter 8: Database Design Issues. . . . . . . . . . . . . . . . . . . . . . . . . . . 139 Chapter 9: Putting Databases to Work . . . . . . . . . . . . . . . . . . . . . . . . . 181 Chapter 10: Using Advanced Database Techniques . . . . . . . . . . . . . . . . . 205 Chapter 11: More Advanced Database Techniques . . . . . . . . . . . . . . . . . 251 Part III: The ColdFusion MX Language . . . . . . . . . . . . . . . . . . 289 Chapter 12: Understanding ColdFusion Variables . . . . . . . . . . . . . . . . . . 291 Chapter 13: Constructing Flow Control . . . . . . . . . . . . . . . . . . . . . . . . 305 Chapter 14: Creating Lists and Arrays . . . . . . . . . . . . . . . . . . . . . . . . . 317 Chapter 15: Working with Structures . . . . . . . . . . . . . . . . . . . . . . . . . 333 Chapter 16: Scripting ColdFusion with CFSCRIPT . . . . . . . . . . . . . . . . . . 353 Chapter 17: Building User-Defined Functions. . . . . . . . . . . . . . . . . . . . . 363 Chapter 18: Writing Custom Tags . . . . . . . . . . . . . . . . . . . . . . . . . . . 375 Chapter 19: Maintaining State . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 399 Chapter 20: Form Validation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 407 Chapter 21: Handling Exceptions. . . . . . . . . . . . . . . . . . . . . . . . . . . . 429 Part IV: ColdFusion MX Components, Web Services, and Flash Integration . . . . . . . . . . . . . . . . . . . . . . . . . . . . 447 Chapter 22: Understanding ColdFusion MX Components . . . . . . . . . . . . . . 449 Chapter 23: Building Your First ColdFusion Components . . . . . . . . . . . . . . 487 Chapter 24: Migrating Custom Tags and UDFs to Components. . . . . . . . . . . 551 Chapter 25: Building Web Services with ColdFusion MX . . . . . . . . . . . . . . 557 546228 FM.F 1/31/03 3:07 PM Page xv Chapter 26: Flash Remoting Services . . . . . . . . . . . . . . . . . . . . . . . . . 569 Chapter 27: Using Server-Side ActionScript. . . . . . . . . . . . . . . . . . . . . . 591 Part V: Integrating ColdFusion MX with Other Technologies . . . . . 597 Chapter 28: Integrating ColdFusion MX and Java . . . . . . . . . . . . . . . . . . 599 Chapter 29: Integrating COM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 621 Chapter 30: Integrating ColdFusion MX with XML and WDDX . . . . . . . . . . . 637 Chapter 31: Communicating via Mail, FTP, and HTTP . . . . . . . . . . . . . . . . 681 Part VI: Extending Your ColdFusion MX Applications . . . . . . . . . 705 Chapter 32: Adding Useful ColdFusion MX Features to Your Application. . . . . 707 Chapter 33: Charting Data with ColdFusion MX . . . . . . . . . . . . . . . . . . . 729 Chapter 34: Leveraging Nifty Custom Tags . . . . . . . . . . . . . . . . . . . . . . 741 Chapter 35: Tools to Enhance the Development Environment . . . . . . . . . . . 751 Part VII: ColdFusion MX Development Practices . . . . . . . . . . . . 767 Chapter 36: Documenting Your Code . . . . . . . . . . . . . . . . . . . . . . . . . 769 Chapter 37: Fusebox Basics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 779 Chapter 38: Advanced Fusebox . . . . . . . . . . . . . . . . . . . . . . . . . . . . 803 Chapter 39: Handling Source-Code Version Control . . . . . . . . . . . . . . . . . 845 Chapter 40: Integrating Security . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853 Chapter 41: ColdFusion Studio and HomeSite+ Tips and Tricks . . . . . . . . . . 873 Chapter 42: Testing and Performance . . . . . . . . . . . . . . . . . . . . . . . . . 897 Part VIII: ColdFusion MX Administration . . . . . . . . . . . . . . . . . 937 Chapter 43: An Overview of ColdFusion MX Administrator . . . . . . . . . . . . 939 Chapter 44: Configuration Tips and Tricks . . . . . . . . . . . . . . . . . . . . . . 969 Part IX: ColdFusion MX Language Reference . . . . . . . . . . . . . . 979 Chapter 45: Introduction to the Language Reference . . . . . . . . . . . . . . . . 981 Chapter 46: Designing Your Application Framework. . . . . . . . . . . . . . . . . 989 Chapter 47: General Use Tags and Functions . . . . . . . . . . . . . . . . . . . . . 991 Chapter 48: Working with Variables . . . . . . . . . . . . . . . . . . . . . . . . . . 997 Chapter 49: Flow Control. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1037 Chapter 50: Exception Handling . . . . . . . . . . . . . . . . . . . . . . . . . . . 1047 Chapter 51: Forms . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1051 Chapter 52: Databases and Queries . . . . . . . . . . . . . . . . . . . . . . . . . 1061 Chapter 53: Custom Tags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1071 Chapter 54: ColdFusion Scripting . . . . . . . . . . . . . . . . . . . . . . . . . . . 1073 546228 FM.F 1/31/03 3:07 PM Page xvi Chapter 55: Working with Systems Outside ColdFusion . . . . . . . . . . . . . . 1075 Chapter 56: Controlling Server Output and Whitespace . . . . . . . . . . . . . . 1087 Chapter 57: Verity. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1091 Chapter 58: Mail. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1095 Chapter 59: Charting, Reporting, and Logging . . . . . . . . . . . . . . . . . . . 1099 Chapter 60: Files and Directories . . . . . . . . . . . . . . . . . . . . . . . . . . . 1105 Chapter 61: The Registry. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1121 Chapter 62: Security . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1123 Chapter 63: Functions, Components, & Web Services . . . . . . . . . . . . . . . 1127 Appendix: What’s on the CD-ROM . . . . . . . . . . . . . . . . . . . . . . . . . . 1135 Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1139 546228 FM.F 1/31/03 3:07 PM Page xvii 546228 FM.F 1/31/03 3:07 PM Page xviii Contents Preface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ix Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xiii Part I: Getting Started with ColdFusion MX 1 Chapter 1: Introducing ColdFusion MX . . . . . . . . . . . . . . . . . . . 3 Why a Tag-Based Language? . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 ColdFusion Can Be Extended In Many Ways . . . . . . . . . . . . . . . . . . . 4 What You Need To Get Started . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 An Overview of What’s New in ColdFusion MX. . . . . . . . . . . . . . . . . . 6 Tag-based user defined functions . . . . . . . . . . . . . . . . . . . . . . 6 ColdFusion components . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 Flash Remoting services . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 Web services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 Native XML handling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 Simplified security. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 Simplified Verity administration . . . . . . . . . . . . . . . . . . . . . . . 9 Simplified locking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 Java Server Pages integration . . . . . . . . . . . . . . . . . . . . . . . . 9 Extended graphing capabilities. . . . . . . . . . . . . . . . . . . . . . . 10 Enhanced query of queries . . . . . . . . . . . . . . . . . . . . . . . . . 10 Enhanced structured exception handling . . . . . . . . . . . . . . . . . 10 Enhanced debugging capabilities . . . . . . . . . . . . . . . . . . . . . 11 Enhanced regular expressions . . . . . . . . . . . . . . . . . . . . . . . 11 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Chapter 2: Writing Your First ColdFusion MX Application . . . . . . . 13 Your First ColdFusion Application . . . . . . . . . . . . . . . . . . . . . . . . 13 Some terms . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 What you’ll need . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Preparing your Web environment . . . . . . . . . . . . . . . . . . . . . 14 Setting up the database . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Planning Program Flow. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Think in terms of processes . . . . . . . . . . . . . . . . . . . . . . . . 15 Think in terms of data . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Setting Up the Framework For Your Application . . . . . . . . . . . . . . . . 16 546228 FM.F 1/31/03 3:07 PM Page xix xx ColdFusion MX Bible Adding a Company to the Database . . . . . . . . . . . . . . . . . . . . . . . 17 Building the company add form . . . . . . . . . . . . . . . . . . . . . . 17 Building the company add action template . . . . . . . . . . . . . . . . 19 The finished template . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 What just happened? . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 Getting a List of Companies . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Building the company list . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Using a SELECT statement . . . . . . . . . . . . . . . . . . . . . . . . . 25 Displaying the results of a query . . . . . . . . . . . . . . . . . . . . . . 25 Modifying a Company in the Database . . . . . . . . . . . . . . . . . . . . . . 26 Choosing a company to edit . . . . . . . . . . . . . . . . . . . . . . . . 26 Building the company edit form . . . . . . . . . . . . . . . . . . . . . . 27 Building the company edit action template. . . . . . . . . . . . . . . . 30 What just happened? . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 Removing a Company From the Database . . . . . . . . . . . . . . . . . . . . 33 Choosing a company to delete . . . . . . . . . . . . . . . . . . . . . . . 33 Creating the company delete form . . . . . . . . . . . . . . . . . . . . . 34 Confirming the deletion of a company before performing the action . . . . . . . . . . . . . . . . . . . . . . 36 Creating the company delete action template . . . . . . . . . . . . . . 36 Using a DELETE statement . . . . . . . . . . . . . . . . . . . . . . . . . 36 Adding a New Employee to the Database . . . . . . . . . . . . . . . . . . . . 36 Building the employee add form . . . . . . . . . . . . . . . . . . . . . . 37 Creating the employee add action template . . . . . . . . . . . . . . . 39 What was that CFSELECT tag? . . . . . . . . . . . . . . . . . . . . . . . 40 Getting a List of Employees . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 Creating the employee list . . . . . . . . . . . . . . . . . . . . . . . . . 41 Using DateFormat() to make the date look natural to the user . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 Modifying an Employee in the Database . . . . . . . . . . . . . . . . . . . . . 43 Choosing an employee to edit . . . . . . . . . . . . . . . . . . . . . . . 43 Building the employee edit form . . . . . . . . . . . . . . . . . . . . . . 44 Creating the employee edit action template . . . . . . . . . . . . . . . 47 Removing an Employee From the Database . . . . . . . . . . . . . . . . . . . 47 Choosing an employee to delete . . . . . . . . . . . . . . . . . . . . . . 47 Building the employee delete form . . . . . . . . . . . . . . . . . . . . 48 Creating the employee delete action template . . . . . . . . . . . . . . 50 Creating a Launch Pad . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 Making Your Application Better. . . . . . . . . . . . . . . . . . . . . . . . . . 52 Creating a footer at the bottom of every page . . . . . . . . . . . . . . 52 Showing a company’s employees . . . . . . . . . . . . . . . . . . . . . 52 Making direct links to the add, view, and delete forms . . . . . . . . . 54 Redirecting the user back to the company list . . . . . . . . . . . . . . 56 Sending a welcome e-mail to a new employee . . . . . . . . . . . . . . 56 Setting a cookie in the employee list. . . . . . . . . . . . . . . . . . . . 57 Extending Your Application by Using a Custom Tag . . . . . . . . . . . . . . 59 Writing the custom tag . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 Calling the custom tag . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 Extending the custom tag with attributes. . . . . . . . . . . . . . . . . 60 546228 FM.F 1/31/03 3:07 PM Page xx xxiContents Congratulations!. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 Chapter 3: Using ColdFusion MX Tags and Functions . . . . . . . . . . 63 ColdFusion Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 Using operators. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 Using function calls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 Pound Signs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 Where and where not to use pound signs. . . . . . . . . . . . . . . . . 69 Knowing where and where not to use CFOUTPUT . . . . . . . . . . . . 71 How to escape pound signs . . . . . . . . . . . . . . . . . . . . . . . . . 72 Using CFOUTPUT blocks of code. . . . . . . . . . . . . . . . . . . . . . 73 How to Use Tags. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74 Empty tags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74 Paired tags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74 Shorthand closing syntax . . . . . . . . . . . . . . . . . . . . . . . . . . 74 Comments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 Chapter 4: Understanding Servers and Clients . . . . . . . . . . . . . . 77 What Is a Server, and What Is a Client?. . . . . . . . . . . . . . . . . . . . . . 77 CFML and JavaScript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 Integrating CFML and JavaScript . . . . . . . . . . . . . . . . . . . . . . . . . 80 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 Chapter 5: Learning a Little SQL . . . . . . . . . . . . . . . . . . . . . . 83 An Overview of Relational Databases . . . . . . . . . . . . . . . . . . . . . . 83 An Overview of Structured Query Language (SQL). . . . . . . . . . . . . . . 87 SELECT Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 INSERT Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95 UPDATE Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 DELETE Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 Chapter 6: Using ColdFusion Forms. . . . . . . . . . . . . . . . . . . . 109 Implementing Client-Side Validation . . . . . . . . . . . . . . . . . . . . . . 109 Using CFINPUT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 Where you cannot use CFINPUT . . . . . . . . . . . . . . . . . . . . . 111 Using CFSELECT. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 Using check boxes and radio buttons . . . . . . . . . . . . . . . . . . 114 Implementing Server-Side Validation . . . . . . . . . . . . . . . . . . . . . . 116 Graphical User Interface Widgets . . . . . . . . . . . . . . . . . . . . . . . . 117 CFSLIDER. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 CFTEXTINPUT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118 CFTREE. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118 Populating a CFTREE control from a query . . . . . . . . . . . . . . . 119 CFGRID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 120 546228 FM.F 1/31/03 3:07 PM Page xxi xxii ColdFusion MX Bible The Caveats of Using CFFORM. . . . . . . . . . . . . . . . . . . . . . . . . . 123 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123 Chapter 7: Testing Your Code. . . . . . . . . . . . . . . . . . . . . . . . 125 Development Testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 Test harnesses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 Unit testing with bad data . . . . . . . . . . . . . . . . . . . . . . . . . 126 Structured exception handling . . . . . . . . . . . . . . . . . . . . . . 127 Application testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128 How to test your application . . . . . . . . . . . . . . . . . . . . . . . 128 Testing your application with bad data . . . . . . . . . . . . . . . . . 129 Browser woes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130 Empty-nest testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132 Regression testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132 Load testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132 Debugging Your Code . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133 Debug settings. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133 Using CFDUMP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 134 The integrated debugger. . . . . . . . . . . . . . . . . . . . . . . . . . 135 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 135 Part II: Using ColdFusion MX with Databases 137 Chapter 8: Database Design Issues . . . . . . . . . . . . . . . . . . . . 139 Relational Database Basics . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139 What is a “relational database?” . . . . . . . . . . . . . . . . . . . . . 139 Describing relationships . . . . . . . . . . . . . . . . . . . . . . . . . . 144 Types of Relationships . . . . . . . . . . . . . . . . . . . . . . . . . . . 149 Creating your physical data model . . . . . . . . . . . . . . . . . . . . 152 Referential integrity. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 154 Normalization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 159 Denormalization. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161 Defaults. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 162 Check constraints. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 163 Creating a Scalable Database. . . . . . . . . . . . . . . . . . . . . . . . . . . 164 Index design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 164 Data Description Language (DDL) . . . . . . . . . . . . . . . . . . . . 170 Don’t try to get OLAP out of an OLTP database . . . . . . . . . . . . . 178 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179 Chapter 9: Putting Databases to Work . . . . . . . . . . . . . . . . . . 181 Understanding All Relational Result Sets . . . . . . . . . . . . . . . . . . . . 181 How to Visualize What is Possible and Impossible Within an SQL Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . 188 SQL’s processing order of precedence . . . . . . . . . . . . . . . . . . 189 How and when to use GROUP BY, HAVING, and DISTINCT. . . . . . . 194 546228 FM.F 1/31/03 3:07 PM Page xxii xxiiiContents Structured Exception Handling . . . . . . . . . . . . . . . . . . . . . . . . . 198 Query Caching . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201 Watch your memory! . . . . . . . . . . . . . . . . . . . . . . . . . . . . 203 You can’t use CFQUERYPARAM . . . . . . . . . . . . . . . . . . . . . . 203 Caching stored procedures . . . . . . . . . . . . . . . . . . . . . . . . 203 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 204 Chapter 10: Using Advanced Database Techniques . . . . . . . . . . 205 Transactions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205 Understanding transactions . . . . . . . . . . . . . . . . . . . . . . . . 206 Where to control a transaction . . . . . . . . . . . . . . . . . . . . . . 207 CFTRANSACTION and exception handling. . . . . . . . . . . . . . . . 209 Transaction isolation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211 Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 214 Horizontal and vertical masking . . . . . . . . . . . . . . . . . . . . . 215 Relational views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 216 Precompiling queries . . . . . . . . . . . . . . . . . . . . . . . . . . . . 216 Enhancing security . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 217 Caveats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 217 Stored Procedures. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 218 What is a stored procedure?. . . . . . . . . . . . . . . . . . . . . . . . 218 The three components of calling a stored procedure . . . . . . . . . 223 Oracle stored procedures and packages. . . . . . . . . . . . . . . . . 232 Practical things that you can do in using stored procedures . . . . . 242 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 250 Chapter 11: More Advanced Database Techniques. . . . . . . . . . . 251 Triggers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 251 Triggers and implicit transactions . . . . . . . . . . . . . . . . . . . . 252 Where DRI constraints alone just don’t do . . . . . . . . . . . . . . . 254 Getting the database to do the work for you . . . . . . . . . . . . . . 258 Affecting single and multiple rows . . . . . . . . . . . . . . . . . . . . 260 Instead-Of triggers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 265 Oracle triggers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 267 Practical things that you can do by using triggers . . . . . . . . . . . 270 Eliminating the Need for Post-Processing Data Within ColdFusion . . . . . 273 Effective Use of ColdFusion MX’s Enhanced Query of Queries . . . . . . . 275 Performing relational joins between ColdFusion query objects . . . 276 Querying a query object . . . . . . . . . . . . . . . . . . . . . . . . . . 278 Caveats and restrictions . . . . . . . . . . . . . . . . . . . . . . . . . . 279 Don’t be tempted to post-process data . . . . . . . . . . . . . . . . . 280 Getting multi-dimensional results. . . . . . . . . . . . . . . . . . . . . 280 Leveraging QoQ by using query caching. . . . . . . . . . . . . . . . . 284 Data Binding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 284 CFQUERYPARAM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285 Caveats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 286 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 286 546228 FM.F 1/31/03 3:07 PM Page xxiii xxiv ColdFusion MX Bible Part III: The ColdFusion MX Language 289 Chapter 12: Understanding ColdFusion Variables . . . . . . . . . . . 291 What Is Meant By Scope? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 291 Local Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 292 The Variables scope . . . . . . . . . . . . . . . . . . . . . . . . . . . . 292 The Attributes scope . . . . . . . . . . . . . . . . . . . . . . . . . . . . 293 The Caller scope . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 294 Global Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 294 Nonpersistent global variables . . . . . . . . . . . . . . . . . . . . . . 294 Persistent global variables. . . . . . . . . . . . . . . . . . . . . . . . . 296 Testing for Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 303 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 304 Chapter 13: Constructing Flow Control . . . . . . . . . . . . . . . . . . 305 If/ElseIf/Else Constructs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 305 Switch/Case Constructs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 306 Loop Constructs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 307 Looping a specified number of times. . . . . . . . . . . . . . . . . . . 308 Looping while a condition is true . . . . . . . . . . . . . . . . . . . . . 309 Looping over a query. . . . . . . . . . . . . . . . . . . . . . . . . . . . 310 Looping over a list . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 310 Looping over a structure. . . . . . . . . . . . . . . . . . . . . . . . . . 311 Breaking out of a loop . . . . . . . . . . . . . . . . . . . . . . . . . . . 311 Including One Template’s Code in Another . . . . . . . . . . . . . . . . . . 312 Redirecting the User to a Different Location . . . . . . . . . . . . . . . . . . 314 Stopping a Page’s Execution . . . . . . . . . . . . . . . . . . . . . . . . . . . 315 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315 Chapter 14: Creating Lists and Arrays . . . . . . . . . . . . . . . . . . 317 Using Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 317 Creating a list . . . . . . . . . . . . . . .

Các file đính kèm theo tài liệu này:

  • pdfcoldfusion_mx_bible_01_1767.pdf
Tài liệu liên quan