top of page
ColdFusion
What is it?
-
It enables us to create powerful server-side web applications very quickly
-
It has much less code than other technologies such as ASP, PHP etc.
-
ColdFusion Markup Language (CFML), is a scripting language for web development that runs on the JVM, the .NET framework, and Google App Engine.
-
CFML language composed of tags & functions.
-
ColdFusion was originally designed to make it easier to connect simple HTML pages to a database.
data:image/s3,"s3://crabby-images/aa318/aa318c4f66bc18960998518d2ef80297e4168d80" alt=""
Features:
-
ColdFusion enables us to build a large, complex, and dynamic website.
-
We can build a website that does things such as:
-
Publish web services
-
Query a database
-
Allow users to upload files
-
Allow users to upload files​​
-
Publish web services
-
Allow users to upload files
-
FTP files to/from another server
-
and more
History
-
Developed by Adobe Systems.
-
Created by J. J. Allaire in 1995.
-
Implemented language: java
ColdFusion Installation
-
To build ColdFusion applications, you first need to install the ColdFusion server.
-
Below are the steps for installation of ColdFusion.
Step 1
-
Download the ColdFusion application from the official website.
-
Fill out the official details to get logged in with an account to download.
-
3 versions of Coldfusion:
-
ColdFusion Enterprise
-
ColdFusion Production
-
ColdFusion Builder (IDE + Server)
data:image/s3,"s3://crabby-images/7458d/7458d547342f17dac0f946eee0051e19b7af5a21" alt=""
Step 2
-
Open the installer.
-
Accept the agreement & conditions.
-
Select Developer Edition > Next.
-
Select Server Configuration > Next.
-
Browse a path for installing.
data:image/s3,"s3://crabby-images/65aa8/65aa800e9e0bb210540e2dc3d9525806fc17eb8a" alt=""
Step 3
-
Select IIS (Internet Information Service) as a web server for ColdFusion
data:image/s3,"s3://crabby-images/e4926/e4926a9f45f910a7d47caf7dd1330dfc4add5303" alt=""
ColdFusion​​
data:image/s3,"s3://crabby-images/3b786/3b7865793079efc8a075d3ec2d03614cdbedfa88" alt=""
IIS
data:image/s3,"s3://crabby-images/84095/840953e37f2636c98e15417455330b14a750a5d1" alt=""
IIS Server
Manual Configure IIS or Apache
Apache Server
-
Set a listening port number for server.
-
Here we set 8500 as listening port from the HTTP request.
-
Set username & password for Administrative control of the server.
data:image/s3,"s3://crabby-images/005df/005dfb21d7295f30a5faadf4fea9758f3ea5111c" alt=""
Step 3
-
After installation setup completed, click ok to open the ColdFusion Administrator.
-
Log in with the password on the browser.
data:image/s3,"s3://crabby-images/b465c/b465ca8f158a3e04878f18cf8ac4ac5c318c8220" alt=""
Setup ColdFusion with Sublime
-
There are different IDE available for ColdFusion,
-
It has inbuilt server, integrated build and more fuctionalities.
-
Eg.
-
ColdFusion Builder
-
Eclipse
-
etc
data:image/s3,"s3://crabby-images/8f175/8f17561c0a33f01f482fa6594b46970e621dc124" alt=""
ColdFusion Builder​​
data:image/s3,"s3://crabby-images/664a4/664a47b35d1316cc19b6b35b3db8fa611d4c586d" alt=""
Eclipse
-
But for smooth function with lightweight, we work with the Sublime editor.
-
Sublime can not detects ColdFusion codes.
-
There are 2 ways of installation the ColdFusion package.
-
Manual (Download Coldfusion package + Install in Sublime)
-
Package Control in Sublime Text Editor.
data:image/s3,"s3://crabby-images/a3bb2/a3bb26799ad29ae0004d378ddecbb37f7a264cc6" alt=""
Sublime Text Editor
data:image/s3,"s3://crabby-images/e4926/e4926a9f45f910a7d47caf7dd1330dfc4add5303" alt=""
ColdFusion
Step 1
-
For the Package Control of Sublime do as below:
-
Choose Tools > Install Package.
data:image/s3,"s3://crabby-images/0833b/0833bd353e5dee0a41ff6257030f32618a20c047" alt=""
Step 2
-
To open Command Palette, choose Tools> Command Palette or press Ctrl + Shift + P.
-
Type & select Package Control: Install Package.
data:image/s3,"s3://crabby-images/0181c/0181c87bfba4ea05e04a77c8888e7083ae281af2" alt=""
-
press Ctrl + Shift + P.
-
Type Install Package
-
Install the above
Step 3
-
Then type & choose "CFML".
-
This will install the excellent CFML package.
-
Restart the Sublime Text to get the complete things done.
data:image/s3,"s3://crabby-images/1c844/1c844d3f4b362a8e89448ea3bb0fbdbd41dcdc1e" alt=""
The Hello World
-
All the.cfml files should be kept in ColdFusion directory.
-
Here we have written two files;
-
form.cfm
-
action.cfm
Step 1
-
The CFML (ColdFusion markup language) support all HTML tags.
-
Here are two pages are written on Sublime Text Editor.
-
form.cfm file:
data:image/s3,"s3://crabby-images/cae88/cae88de1316ee1a1f223990b49232e48fa3ad43c" alt=""
form.cfm
-
Here is can read the data from the HTML form.
-
We used <cfoutput> ColdFusion tags, and #form.fname# for reading variable form requested form.
data:image/s3,"s3://crabby-images/f4eff/f4eff30613d90a98fb3d3df51c38eda552896248" alt=""
ColdFusion tag
ColdFusion Variable
form.cfm
-
We need to keep those files on the wwwroot folder of ColdFusion path.
data:image/s3,"s3://crabby-images/9e300/9e30000d986a5098d794fc2e28e7b3131eb21de9" alt=""
-
Type the localhost:8500/helloworld/form.cfm on browser.
-
Here is the output on the Browser looks like.​
data:image/s3,"s3://crabby-images/9dcbc/9dcbc727c3b9a4bb20d4c5c668ab07d2dd4e346c" alt=""
-
After clicking Submit, response page of action.cfm, got the #varName# from form.cfm
data:image/s3,"s3://crabby-images/686d2/686d2777a35f8fdb941c1e2751cf767c6dae05b8" alt=""
Syntax
-
CFML consists of a number of opening and closing tags, attributes & values like HTML.
-
Also has some symbols to execute the variables.
-
All these syntaxes is interpreted by the ColdFusion server.
data:image/s3,"s3://crabby-images/a6d71/a6d7132794b22587bed770901d6c71abbbd810b5" alt=""
CFML tags
Attribute
Value
HTML tags
CFML variable
Variable & Datatypes
Variables
-
Variables stores value.
-
For example, we could store user's name inside a variable and many more.
-
In CMFL, there are we can declare a variable.
-
Using <cfset> tag
-
Using <cfparam> tag
-
The <cfset> tag is used to declare a variable.
-
To output the variable, you need to surround the variable name with hash "#".
-
Here <cfset> tag to declare a variable called first name and the assigned value of Varun to it.
data:image/s3,"s3://crabby-images/bf98c/bf98c0d3a4dedae7ca7157580f498f81b4864679" alt=""
-
The <cfparam> tag creates a variable if it does not already exist.
-
We can assign default value using the default attribute.
-
The syntax of declaring variable using <cfparam> is as below.
data:image/s3,"s3://crabby-images/5bb1c/5bb1c34cada844bf485d9ed956babbe719ae2fba" alt=""
Datatype
-
In ColdFusion, there are different types of data we can work with.
-
But we can not declare with a specific datatype i.e. typeless datatype.
-
All the variables can be either local or global.
Variable Scope
-
A scope determines where the data is saved and where it is available.
-
Each of the variables we created in out application belongs to one of these scopes.
-
Here are some scopes:
-
Here is an example of showing the detail of Server scope using the <cfdump> tag.
data:image/s3,"s3://crabby-images/112fb/112fbe6b08b1ae234a4e0a9dcdc805ddeece8c9b" alt=""
To display on browser
Scop Variable
Data Stucture
-
ColdFusion takes care of the connection to a database server.
-
No need to write the code for making a connection to DB.
-
The queries are being sent through a database-connector.​
-
These queries are written in SQL.
Structure
-
A structure is a complex data type.
-
Stores multiple values with multiple keys.
-
Two ways to create ColdFusion Structure.
-
The Explicit Notation: Uses multiple <sfset> statements to create Structure.
-
The Implicit Notation: Uses single <sfset> statement to create Structure.
-
Here we used, the <cfscript> tag, inside where we can write the code with like other programs.
data:image/s3,"s3://crabby-images/cc9be/cc9be14174bd8ff91d04873488903059c357f5c4" alt=""
Structure
-
Here are some structure manipulation functions.
Array
-
An array is simply an ordered stack of data items with the same data type.
-
Using an array, we can store multiple values under a single name.
data:image/s3,"s3://crabby-images/94206/94206cd74d1fbc8edf61bdc7bee44fe460e10da4" alt=""
Array
-
Here are some ColdFusion functions for array manipulation.
Conditional Execution
-
A conditional statement is a piece of code that does one thing on a condition.
-
In ColdFusion, there are different types of conditions as below.
If statement
-
In this case, the piece of code will execute with one condition.
-
there are <cfif> tag is used for if condition.
-
For elseif and else condition, we can use <cfelseif> and <cfelse> respectively.
data:image/s3,"s3://crabby-images/04d7d/04d7d2d06660619b9d53c0681c4adbda797808be" alt=""
Condition
-
<cfelse> tag is used to do something if the condition is not met.
data:image/s3,"s3://crabby-images/ccee0/ccee0c90d46ff507d6ba245ac68b9bac89d9745b" alt=""
-
<cfelseif> tag to perform another condition.
-
It works when if the condition did not meet.
data:image/s3,"s3://crabby-images/3ec4e/3ec4e7611296f8e502560395359201bbdc2d6b3d" alt=""
Condition Operator
-
EQ: Equal To
-
NOT EQ: Not Equal To
-
LT: Less Than
-
GT: Greater Than
-
GTE: Greater Than or Equal To
-
LTE: Less Than or Equal To
ColdFusion Loop
-
A ColdFusion loop is a block of code that executes for a specified number of times.
-
Or once for each element in an object, while a condition is true.
-
We use <cfloop> tag to perform a loop.
-
This tag has a different attribute for different performance.
data:image/s3,"s3://crabby-images/34473/34473fd9831d53dcd35b8bee9cb910779324ab25" alt=""
-
ColdFusion has different types of loops. Here are some of them.
ColdFusion Loop
Index Loop
Conditional Loop
Query Loop
List Loop
File Loop
Index Loop
-
An index loop is a loop that continues for a specified number of times.
-
It iterates 'from' attribute to 'to' attribute.
-
Here we use 3 attributes:
-
from: starting index
-
to: ending index
-
index: holds the counter
data:image/s3,"s3://crabby-images/3989d/3989dc2ef155156d31f3b41bfc92922b46743dfe" alt=""
Conditional Loop
-
A conditional loop executes while a condition is true.
-
We use 'condition' attribute to specify the condition.
-
In following the example, we used RandRange function to stop the iteration.
data:image/s3,"s3://crabby-images/b77fb/b77fbc44b6a0ec93a2de32af84c0e3a4f42e4c0c" alt=""
Query Loop
-
We can loop over the query result in ColdFusion.
-
<cfquery> tag is used for iterate for the number of rows it found
data:image/s3,"s3://crabby-images/30578/30578cb5fb3f8b876f7717cdd7ba0408288d0b82" alt=""
List Loop
-
It can loop over a list of variables.
-
It has 2 attributes.
-
list: Stores numbers of the variable.
-
delimiter: Used as a separator in the list.
data:image/s3,"s3://crabby-images/10b8e/10b8e8a6e0bf03a5ac2af644f064caf5a89910b2" alt=""
File Loop
-
A ColdFusion loop is a block of code that executes for a specified number of times.
-
Or once for each element in an object, while a condition is true.
-
We use <cfloop> tag to perform a loop.
-
This tag has a different attribute for different performance.
Functions In ColdFusion
-
A function is a self-contained block of code.
-
After execution of a function, it returns a value.
-
It has over 250 built-in functions for string-manipulations, date functions, array functions, mathematical functions and many more.
-
Here are some ColdFusion build-in functions.
data:image/s3,"s3://crabby-images/8c682/8c6820b9be7f44f1921e27512fbaa74be0bc8103" alt=""
User-defined Function
-
ColdFusion also provides the ability for you to create your own functions.
-
There are 2-ways of doing this:
-
Using CFScript
-
Using <cffunction> tag
-
He we are going to create a function using <cffunction> tag.
< function call >
home.cfm
< cffunction >
​
​
​
​
< /cffunction >
//code
userFunction.cfm
-
The following is the example of the making of a function using <cffunction> tag.
-
The function name must be unique.
data:image/s3,"s3://crabby-images/21e7e/21e7e48cc6c4873ecfec93ca4667cb592f4714bf" alt=""
home.cfm
userFunction.cfm
-
On home.cfm has a function; functionName() along with argument 555.
-
When we call the function, it will go to userFunction.cfm for execution.
-
We can keep any task to perform.
-
Here that function has a query to get a specific record.
data:image/s3,"s3://crabby-images/4e59e/4e59ed78fb745265eb0d1718b4d8a0da03ee0556" alt=""
Read/Write Files
-
In ColdFusion, we can upload a file to the server.
-
The read & write operation can be performed.
-
All the three operation can be done using <cffile> tag & some properties for read/write.
Read a File
-
In ColdFusion, we can upload a file to the server.
-
The read & write operation can be performed.
-
All the three operation can be done using <cffile> tag & some properties for read/write/append.
Write a File
-
Using <cffile> tag, we can create a file.
-
We can fill it with the simple string or content of the variable.
-
Action attribute can have a different value.
-
Write, for overriding the new value.
-
Read, for reading the file.
-
Append, for adding value with the old file.
data:image/s3,"s3://crabby-images/972a4/972a442abff228429af61b04dbec670bfd74aed0" alt=""
Append/Write/Read
-
The output on the browser looks as below.
-
After submitting the form, it goes to another page & there it writes the data to a file.
data:image/s3,"s3://crabby-images/30bda/30bda81bea8e8de98fa64e76e5fdac2d4dce1643" alt=""
Graphics Function
-
To manipulate image operation, we need to create ColdFusion image.
-
Here we will use the <cfimage> tag with some attributes and functions.
-
There are 5 steps for drawing/manipulating an image.
Step 1: Create a canvas image
-
Use the ImageNew function to create a ColdFusion image that is 700 pixels wide and 250 pixels high.
data:image/s3,"s3://crabby-images/951dc/951dc4324c8f93debb7119f34353d554c51dfdd8" alt=""
Step 2: Set the drawing color
-
Set the current drawing color for ColdFusion image.
-
All the graphics operations use the specified color.
data:image/s3,"s3://crabby-images/53c92/53c92a127ce1e938366decd993428b9d28ba42d8" alt=""
Step 3: Turn on antialiasing (Optional)
-
Switches antialiasing on or off in rendered graphics.
-
We will use a function ImageSetAntialiasing(myImage, "on")
data:image/s3,"s3://crabby-images/ceb03/ceb03714f6eed7b2736bde2e1578b6ccaff7647f" alt=""
data:image/s3,"s3://crabby-images/cb32a/cb32adc76048f34680bd056a0738d567b77acbda" alt=""
Set antialiasing,
Step 4: Draw a shape
-
Here we will draw any shape on the canvas image.
-
In that function, we can fill the shape with color.
-
There are different image drawing function to create different shapes.
data:image/s3,"s3://crabby-images/d49f2/d49f2ae64fbb5f1f6a05c75fee4476c5ba978f53" alt=""
To draw a line,
-
To draw an, the ImageDrawArc function has the been implemented.
data:image/s3,"s3://crabby-images/9de87/9de871f447e0b179e3d60bb216a551daf7d45450" alt=""
To draw an Arc (eg. circle, eclipse),
-
To draw Rectangle or square, imageDrawRect is used.
data:image/s3,"s3://crabby-images/6d8b4/6d8b410105efb6e003b87a89783ef3e62e084c3c" alt=""
To draw an Rectangle,
-
Set the values for the x and y coordinates for the connected line segments.
-
We need to create x & y array for the imageDrawLines function.
data:image/s3,"s3://crabby-images/ca038/ca038b8a5e9dcd4871b9ef9e7baa3af408aeafb7" alt=""
To draw Lines(eg. triangle, star etc),
Step 5: Display the image on browser
-
<cfimage> tag creates an image that can be manipulated by image functions.
-
Here we display the image on the browser.
data:image/s3,"s3://crabby-images/75cbf/75cbf4a1870097564429fbf949d0316ada818de8" alt=""
Display the image on browser,
Exercise 6
-
Draw a Line, Circle, Rectangle & star.
data:image/s3,"s3://crabby-images/7d340/7d34008cac70085d28a59f21af886b573518af9d" alt=""
1. Create a canvas image
2. Set a drawing color
3. Set antialiasing
4. Draw shapes on canvas
5. Display the canvas on the browser
data:image/s3,"s3://crabby-images/dbccc/dbccc8352cbf05c3abc082fd807ec7629df3e4b4" alt=""
ColdFusion & Database
-
ColdFusion takes care of the connection to a database server.
-
No need to write the code for making a connection to DB.
-
The queries are being sent through a database-connector.​
-
These queries are written in SQL.
Data Source Name
data:image/s3,"s3://crabby-images/6ec48/6ec48b88dc64b654b6f287a309d8d779ea8199f6" alt=""
-
SQL statement
-
Address of database server
-
Database name
-
Username & password
data:image/s3,"s3://crabby-images/f15e5/f15e5814cd0249eab92f25ad19868948cb1e81a8" alt=""
data:image/s3,"s3://crabby-images/fe048/fe0483be534bc1d5a4809e872b1a33207401bc08" alt=""
BirenDB
data:image/s3,"s3://crabby-images/fe048/fe0483be534bc1d5a4809e872b1a33207401bc08" alt=""
User
data:image/s3,"s3://crabby-images/1f132/1f1322b7263635b92ce66eb34c5db8c321aff5a8" alt=""
SPS
Create a Connection to Database
-
In ColdFusion, we need to provide DSN (Data Source Name) details to ColdFusion Server.
-
ColdFusion has preinstalled database drivers.
-
In this case, we are using MySQL database.
-
Here ColdFusion does not have MySQL driver.
-
We downloaded the mySql-connector.jar file from the internet & put that in ColdFusion library; C:\ColdFusion2016\cfusion\lib
data:image/s3,"s3://crabby-images/ba10f/ba10f0130489e5803593639e1f3cf5f1aebbc78e" alt=""
-
Download MySQL-connector.jar
-
Put it in cfusion/lib folder.
-
Go to the ColdFusion administrator panel, localhost:8500/CFICE/administrator/index.cfm on browser.
-
Log in with the administrator password.
-
Click on DataSource under Data & Service menu on left.
-
Select the Data Source name & Select a database driver.
-
In this case, MySQL is the data source name & MySQL 5 is the driver.
-
Click on Add.
data:image/s3,"s3://crabby-images/2f718/2f7188a6e058aa0040553b637a334652309dc53a" alt=""
Give a name Datasource name
Select a Database Driver
-
Here provide the Database name, server, port number, username & password.
-
We entered the MySQL database details here & Submit.
data:image/s3,"s3://crabby-images/d711e/d711ed466812ea76eae4ed8c2e49ba24966167c2" alt=""
Database name on the MySQL Server
localhost:3306
username & password of MySQL Server
Datasource name
-
Data source updated successfully message appeared on the screen.
-
Check the status of the Connected Data Sources for MySQL.
-
Log out from this page.
data:image/s3,"s3://crabby-images/ebad6/ebad636a3298bf9e4e1267a44e9fc19f4e101714" alt=""
Status is ok
After the successful update of DB, click Logout
Retrieve Data from Database
-
In birnDB database on MySQL server, Employees table is located.
-
We will retrieve the data using CFML program.
data:image/s3,"s3://crabby-images/86159/86159839061a309cf010f90e8aeea92cf3870e2b" alt=""
-
Here is the CFML for retrieving the data from Employees table of MySQL database.
-
<cfquery>: For sending query to database.
-
datasource: Attribute for which database we want to send a query.
-
name: is an attribute for getting the query result.
-
resultset: is an attribute for getting more query result.
-
query: Attribute used for looping over multiple rows from a query result in <cfoutput> tag.
-
group: Attribute for grouping the query result.
Looping over query result
data:image/s3,"s3://crabby-images/61556/61556f08c11b510867168e6cff835a6e2c41f6ff" alt=""
SQL query to the database
-
After putting the SelectFromDatabase.cfm file on the wwwroot/helloworld folder, we can access the page on the server.
-
The data from the database is in the below table.
-
We used the looping condition the on query property inside of the <cfoutput> tag.
data:image/s3,"s3://crabby-images/8fb09/8fb09e9ebfc42851e1531d5dd7eb6fdbbc33d5ef" alt=""
data:image/s3,"s3://crabby-images/c0b49/c0b49ad1fec5d670b23c98b93fcf14121ef6564f" alt=""
bottom of page