Welcome!

ColdFusion Authors: Yakov Fain, Maureen O'Gara, Nancy Y. Nee, Tad Anderson, Daniel Kaar

Related Topics: ColdFusion

ColdFusion: Article

Extending ColdFusion with Java

Extending ColdFusion with Java

Last month I introduced you to Lucene and then showed you how you can access the Jakarta Lucene APIs using native CFML scripting syntax. This month I'm going to show you how easy it is to create a Java CFX tag that performs the same functions as the two tags I illustrated last month: <cf_luceneindex> and <cf_lucenesearch>.

As a short review of last month and as many of you know already, one of the many reasons to use ColdFusion MX is that it comes standard with the majority of the tools you'll need to write full-featured, dynamic Web applications. Tags like <cfquery> and <cfmail> make it relatively simple to query a relational database and send e-mail. In the same way, you can use <cfsearch> and <cfindex> to create and search Verity full text indexes.

There are, however, a couple of situations when you can't use the full text searching capabilities of Verity. The ability to run ColdFusion MX on the Apple OS X operating system, while a boon to developers who code on the Apple platform, does not include the ability to use Verity. Programmers who work in a hybrid J2EE/ColdFusion MX environment (possibly using ColdFusion MX for J2EE) cannot natively use the Verity search capabilities in the J2EE environment. Finally, programmers who need customized searching and indexing capabilities may find the standard Verity integration limiting.

Enter Lucene, an open source full-text searching framework from the Apache Jakarta project, which, when combined with ColdFusion MX, can be run on Apple OS X, programmatically accessed by both J2EE and ColdFusion MX developers, and fully customized and extended. Additionally, when accessed with the Java CFX API, Lucene can be utilized in ColdFusion 5, 4.x, and possibly earlier versions.

In this article, I'll discuss CFX tags in general, walk through the CFX API, and then jump into the creation of two Java classes that combine the CFX and Lucene APIs into two CFX tags: <cfx_luceneindex> and <cfx_lucenesearch>. Finally, I'll conclude with some tricks and hints to help you when writing CFX tags in Java.

This article is not intended to be an in-depth introduction to the Lucene API, to Java programming, or to writing C++ CFX tags. If you're interested in learning more about the internal workings of Lucene, one of SYS-CON's sister publications, Java Developer's Journal, featured an article entitled, "Search-Enable Your Application with Lucene," see the resources section at the end of this article.

If you're new to Java, I'd suggest heading to your local bookstore to pick up one of the many Java books for beginners. Finally, if you're looking for information on writing C++ CFX tags, check out the CFX C++ documentation link, also in the resources section at the end of this article.

While I'll try to cover the basics of writing a Java CFX tag, if you'd like more information about Java and C++ ColdFusion CFX tags, I encourage you to check out the "Building Custom CFXAPI Tags" resource in the CFMX documentation (see resources section for the URL); included in the documentation are sample CFX tags for browsing ZIP file archives, creating JPEG images, and using sockets.

What Are CFX Tags?
If you've worked with ColdFusion for any length of time, you know that ColdFusion provides almost everything (if not everything!) you need to rapidly build dynamic Web applications. Sooner or later you'll come to a situation where you need something that ColdFusion doesn't provide out of the box. But don't fret! With some knowledge of Java or C++, you can create a CFX tag that wraps up the extra functionality you need into an easy-to-use CFX that you can then access using the standard tag-based syntax. In short then, a CFX tag is a compiled Java or C++ module that performs a task that ColdFusion doesn't natively offer.

Setup and Configuration
Before beginning, you'll need to make sure that your system (be it Unix, Linux, Windows, or Apple) is appropriately configured:

  • ColdFusion must be installed. You'll see that I'm using the ColdFusion MX integrated Web server running on port 8500 throughout the examples.
  • You'll need to download Lucene; binaries and source code are available on the Jakarta Apache site; you'll see links to those resources at the end of this document.
  • After downloading the Lucene JAR file, add the location of the JAR file to the classpath in ColdFusion Administrator (http://localhost:8500/cfide/administrator/, click on "Java and JVM" under "Server Settings", and type the full path to the location of the Lucene JAR file you downloaded). Make sure that you restart the ColdFusion service after saving your changes.
  • Create a folder in your /cfusionmx/wwwroot/ called "cfxlucene", into which you'll put the source code written during this article.
  • To compile the source code I've provided below, you'll need to have the Java 2 SDK installed on your system; I'm using J2SDK 1.4.1.
  • Finally, locate the "cfx.jar" file on your system. On my system with the default CFMX installation, the "cfx.jar" file is located at "C:\CFusionMX\lib\cfx.jar".

    Let's get started!

    Creating a Lucene Index Using the CFX API and Java
    If you've completed the setup and configuration steps above, open your favorite Java IDE (Notepad, VI, Eclipse, or even CF Studio all work just fine), create a new document, and save the document as "LuceneIndex.java". This file will contain the source code for the CFX tag that will perform the indexing of documents later in this article. The first items you'll need to add are the following Java import statements:

    import java.io.*;
    import java.util.*;
    import com.allaire.cfx.*;
    import org.apache.lucene.analysis.*;
    import org.apache.lucene.document.*;
    import org.apache.lucene.index.*;

    The lines of code above "import" the java.io and java.util libraries, the com.allaire.cfx library (which I'll explain in a bit), and three Lucene libraries - all of which you'll use when writing the LuceneIndex class. If you're new to Java, you can think of the previous import statements as doing something analogous to using <cfinclude> to include a file that contains one or more user-defined functions. Basically, I've just imported a number of Java functions (although in Java you only have "methods" on "objects", not "functions") into the LuceneIndex class.

    Next, you'll need to add the following line:

    public class LuceneIndex implements CustomTag {

    Without going into too much detail, this line of code says that the name of the class is "LuceneIndex" (the name of the file must match this name) and that it "implements" CustomTag. The word implements has a special meaning in Java; when you implement something, it means that the class you are writing will have a method with the same signature as each method in the class you are implementing (which is called an "interface"). In this case, I'm implementing the "CustomTag" interface, which has only one method:

    public void processRequest(Request req, Response res)

    Now that you understand interfaces (don't worry if you don't, interfaces and the "implements" keyword aren't that important to this article), you should know what the next line will be:

    public void processRequest(Request req, Response res) {

    Look familiar? It should! This is the method from the CustomTag interface that you must implement. Let's look a bit closer at it. There are two classes passed to this method: Request and Response. If you've done any work with ASP/VBScript or JSP, you might think that you understand these classes right away, but they aren't the same. We'll look at the Response class in the next section. The Request class contains seven methods, none of which deal with the "request" made by the browser (unlike the ASP request object or the JSP request object). I'm only going to cover two in this article: attributeExists() and getAttribute(), but if you're hungry for the details, you can read about all the methods by visiting the ColdFusion Java CFX reference resource at the end of this article. The method "getAttribute()" retrieves the value of the variable given as an attribute to the method. So, for example, if I wrote this in ColdFusion:

    <cfx_luceneindex path="c:\cfusionmx\wwwroot\cfdocs\">

    and I wanted to retrieve the value of the attribute "path" in the Java code, I'd write this:

    req.getAttribute("path")

    Simple right? In the same way, if I wanted to check that a specific attribute has been passed to the tag, I'd use the attributeExists() method. For instance, if I wanted to make sure that the attribute "path" has been passed to the Java code, I'd use a statement like this:

    req.attributeExists("path")

    Back to the LuceneIndex class. In order to index a directory or a file, you'll need to know which directory or file, where to create the index, whether to recurse the directories, and so on. To do so, you'll add the following lines of code:

    String indexName = req.getAttribute("indexName");
    String indexPath = req.getAttribute("indexPath");
    String directory = req.getAttribute("directory");
    String file = req.getAttribute("file");
    String urlpath = req.getAttribute("urlpath");

    For the sake of brevity, I'm not covering the error checking code, which you can see in the source code that you can (and should!) download below. Next, add a statement that checks to see if the user wants to "optimize" a Lucene index or "index" a directory of files:

    if (action.equalsIgnoreCase("index")) {

    Finally, you're ready to begin using Lucene to index a directory.

    Analyzer analyzer = new StopAnalyzer();
    IndexWriter writer;
    try {
    writer = new IndexWriter(indexPath, analyzer,
    bCreateIndex.booleanValue());
    if (req.attributeExists("directory")) {
    File f = new File(directory);
    if (f.exists() && f.isDirectory()) {
    indexDirectory(urlpath, f,
    recursive.booleanValue(), writer);
    }
    } else {
    File f = new File(file);
    indexFile(urlpath, f, writer);
    }
    writer.close();
    } catch (java.io.IOException e) {
    errors.add(e.toString());
    }

    Start by creating a Lucene Analyzer (in this case using the StopAnalyzer) object and a Lucene IndexWriter object, which are then used in the index process. You'll notice that the IndexWriter constructor and the indexFile()/indexDirectory() methods are wrapped in a try/catch block so that errors resulting from insufficient permissions and nonexistent directories/files are caught appropriately. I won't discuss indexFile() and indexDirectory() methods as they aren't pertinent to the topic at hand; you can find the source code for both methods in the LuceneIndex.java file.

    To optimize a Lucene index, add these short bits of code:

    StopAnalyzer analyzer = new org.apache.lucene.analysis.StopAnalyzer();
    IndexWriter writer;
    try {
    writer = new IndexWriter(indexPath, analyzer, false);
    writer.optimize();
    } catch (java.io.IOException ex) {
    ex.toString();
    }

    At this point, you're ready to save and compile LuceneIndex.java. Since I haven't included all the necessary code, I'd suggest that you download the source code and unzip the archive to

    [cfusionhome]/wwwroot/WEB-INF/classes/

    where [cfusionhome] is the directory that contains your ColdFusion MX installation. After completing that (and keeping in mind the location of both the cfx.jar and the lucene.jar file that you downloaded/located during the previous setup and configuration steps), you can compile LuceneIndex by bringing up a command prompt and typing the following from the [cfusionhome]\wwwroot\WEB-INF\classes\ directory:

    C:\CFusionMX\wwwroot\WEB-INF\classes>javac -classpath
    [path_to_lucene.jar];[path_to_cfx.jar] LuceneIndex.java

    substituting the appropriate values for [path_to_lucene.jar] and [path_to_cfx.jar] like I did in Figure 1.

     

    After successfully compiling LuceneIndex.java, you should have a file called "LuceneIndex.class" in the [cfusionhome]\wwwroot\WEB-INF\classes\ directory. In order to test out the code you've written so far, you need to make ColdFusion aware of its existence. To do that, log in to the ColdFusion Administrator, click on "CFX Tags" under "Extensions," and then click the "Register Java CFX" button. Enter the tag name (in this case "cfx_luceneindex"), the class name ("LuceneIndex"), and optionally, a description just like I have in Figure 2.

     

    You can then test the indexing and optimizing operations by running a CFML script that contains the following code:

    <cfx_luceneindex
    action="index"
    indexpath="c:\cfusionmx\wwwroot\cfxlucene\cfdocsindex\"
    bCreateIndex="true"
    directory="c:\cfusionmx\wwwroot\cfdocs\CFML_Reference\"
    urlpath="http://localhost:8500/cfdocs/CFML_Reference/"
    recursive="true">

    again, substituting the appropriate values for your environment. I included a sample script in the source code called "test_luceneindex.cfm" that contains code for indexing a file, indexing a directory, and optimizing an index. All set to search that index? Great! Let's move to the next section...

    Searching a Lucene Index Using the CFX API and Java
    As in the previous section, start by creating a new file using your IDE; save this one as "LuceneSearch.java". I'll start off the new class by importing the appropriate libraries, just as I did in the previous example:

    import java.util.*;
    import com.allaire.cfx.*;
    import org.apache.lucene.analysis.*;
    import org.apache.lucene.document.*;
    import org.apache.lucene.index.*;
    import org.apache.lucene.queryParser.*;
    import org.apache.lucene.search.*;

    Not much different there, you can move quickly to the next lines:

    public class LuceneSearch implements CustomTag {
    public void processRequest(Request req, Response res) {

    Again, use the "implements" keyword in the class definition, and then immediately add a method "processRequest()" that matches the method signature of the processRequest() method from the CustomTag class. After that use the req.getAttribute() method to retrieve the value of the attributes given in the tag:

    String indexPath = req.getAttribute("index");
    String queryString = req.getAttribute("keyword");
    String r_query = req.getAttribute("r_query");

    Perform some error checking (again removed for the sake of brevity) and then you're into the heart of the tag:

    IndexSearcher searcher = null;
    org.apache.lucene.search.Query luceneQuery = null;
    Hits hits = null;
    searcher = new IndexSearcher(IndexReader.open(indexPath) );
    Analyzer analyzer = new StopAnalyzer();
    luceneQuery = QueryParser.parse(queryString, "body", analyzer);
    //parse the hits = searcher.search(luceneQuery);

    String[] columns = { "URL", "TITLE", "SUMMARY" } ;
    com.allaire.cfx.Query q = res.addQuery(r_query, columns) ;

    for (int i = 0; i < hits.length(); i++) {

    Document doc = hits.doc(i);
    String doctitle = doc.get("title");
    String url = doc.get("url");
    String docSummary = doc.get("summary");

    int iRow = q.addRow() ;
    q.setData( iRow, 1, url) ;
    q.setData( iRow, 2, doctitle);
    q.setData( iRow, 3, docSummary);
    }

    This block of code creates an IndexSearcher object, a Lucene Query object, a Lucene Hits object, and an Analyzer object, all of which are used in various ways to parse the keyword into manageable bits and then search the index you created in the above example.

    Remember the Request and Response classes I mentioned? In this example you're going to use the Response object, which has four methods, only three of which you'll probably use on a regular basis. The addQuery() method enables you to return a ColdFusion query to the calling template, which is what you'll do in this example.

    Additionally, you can use the setVariable() method just like you might use the SetVariable function in ColdFusion - for example, to return a string or a number to the calling template. Finally, you can use the write() method to write text directly to the screen, just as you might use

    <cfoutput>Hello World!</cfoutput>

    or

    WriteOutput("Hello World!");

    when writing CFML code. Back to the last example, the portion of code that is pertinent to this article starts with these lines:

    String[] columns = { "URL", "TITLE", "SUMMARY" } ;
    com.allaire.cfx.Query q = res.addQuery(r_query, columns) ;

    The first line creates an array of String objects: "URL", "TITLE", and "SUMMARY"; each represents the name of a column in a query. This array is passed to the method addQuery() of the Response object, along with the "r_query" value. After creating the query, loop over each "hit" that Lucene returned, using a "for" loop, and then add the URL, the TITLE, and the SUMMARY to the query:

    q.setData( iRow, 1, url) ;
    q.setData( iRow, 2, doctitle);
    q.setData( iRow, 3, docSummary);

    where iRow is the row number and 1, 2, and 3 represent the number of the column you're adding a value to.

    I left out the error checking and try/catch statements so if you want to compile the code, again I'd suggest that you download and unzip the archive to the [cfusionhome]\wwwroot\WEB-INF\classes\ directory and then compile LuceneSearch.java by typing this from the command line:

    cd [cfusionhome]\wwwroot\WEB-INF\classes
    javac -classpath [path_to_lucene];[path_to_cfx] LuceneSearch.java

    substituting the appropriate values for [cfusionhome], [path_to_lucene], and [path_to_cfx]. After successfully compiling the Java class, you should register the CFX tag in the ColdFusion Administrator (i.e., click on CFX Tags under Extensions and click the "Register Java CFX" button, tag name should be "cfx_lucenesearch", tag class should be "LuceneSearch"). You should be able to test the search functionality using the included "test_lucenesearch.cfm" script in the source code archive, or by creating a simple script that looks like this:

    <cfx_lucenesearch
    r_query="r_query"
    index="c:\cfusionmx\wwwroot\cfxlucene\cfdocsindex\"
    keyword="software">

    Tips and Tricks
    As with any technology, there are things you need to watch out for. Here are a couple I found while working with Java CFX tags:

  • When using the Response object's write() method, the text is not written to the browser if you have <cfsetting enablecfoutputonly="true">. If you want to see error messages written by the tag or if the tag you've written uses the write() method, you must either (a) surround the tag invocation with a <cfoutput></cfoutput> block or (b) not use the <cfsetting enablecfoutputonly="true"> tag above the CFX tag invocation.
  • During development, you can use the DebugRequest, DebugResponse, and DebuqQuery objects to emulate your Java class being called from ColdFusion as a tag. The Building Custom CFXAPI Tags section of the documentation has directions on setting up your Java IDE for interactive debugging as well as an example of how you might use those classes. The LuceneIndex.java file in the source code archive also provides an example of the use of those classes.
  • According to the CFX Java tag documentation, changes to the class files located in the [cfusionhome]/wwwroot/WEB-INF/classes are automatically reloaded upon being changed. I did not observe this behavior; to view the change in the class file, I had to restart the ColdFusion MX service using the Services control panel applet.
  • When using a CFX Java tag in CFML, there is a special attribute called "reload" that supposedly controls whether or not ColdFusion will reload changes to the class file. The documentation states that by default the reload attribute is set to "Auto" and recommends that during development you set the reload attribute to "Always"; set it to "Never" to increase performance.

    Conclusion
    The Java CFX Tag API enables developers to extend ColdFusion almost anywhere Java can travel. I hope that this article has given you an excellent introduction to writing CFX tags in Java and gets you rolling on your own Java CFX projects. I'd encourage you to download and explore the source code below in which I've included error checking code, try/catch blocks, and attribute validation, and to explore Lucene further.

    Resources

  • Jakarta Lucene: http://jakarta.apache.org/lucene/
  • Jakarta Lucene Downloads: http://jakarta.apache.org/builds/jakarta-lucene/release/v1.2/
  • "Search-Enable Your Application with Lucene:" www.sys-con.com/java/article.cfm?id=1777
  • ColdFusion MX Documentation: http://livedocs.macromedia.com/cfmxdocs/
  • ColdFusion MX Documentation: Building Custom CFXAPI Tags: http://livedocs.macromedia.com/cfmxdocs/Developing_ ColdFusion_MX_Applications_with_CFML/CFXTags.jsp
  • ColdFusion MX Documentation: Developing CFX tags in C++: http://livedocs.macromedia.com/cfmxdocs/Developing _ColdFusion_MX_Applications_with_CFML/CFXTags7.jsp#1112325
  • ColdFusion MX Documentation: ColdFusion Java CFX Reference: http://livedocs.macromedia.com/ cfmxdocs/CFML_Reference/CFXRef_Java.jsp
  • More Stories By Aaron Johnson

    Aaron Johnson is a senior software engineer at Jive Software. He lives with his wonderful wife, young son and dog in a Portland, Oregon. You can find out more by reading his blog at http://cephas.net/blog/.

    Comments (3)

    Share your thoughts on this story.

    Add your comment
    You must be signed in to add a comment. Sign-in | Register

    In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.


    @ThingsExpo Stories
    Samsung VP Jacopo Lenzi, who headed the company's recent SmartThings acquisition under the auspices of Samsung's Open Innovaction Center (OIC), answered a few questions we had about the deal. This interview was in conjunction with our interview with SmartThings CEO Alex Hawkinson. IoT Journal: SmartThings was developed in an open, standards-agnostic platform, and will now be part of Samsung's Open Innovation Center. Can you elaborate on your commitment to keep the platform open? Jacopo Lenzi: Samsung recognizes that true, accelerated innovation cannot be driven from one source, but requires a...
    Explosive growth in connected devices. Enormous amounts of data for collection and analysis. Critical use of data for split-second decision making and actionable information. All three are factors in making the Internet of Things a reality. Yet, any one factor would have an IT organization pondering its infrastructure strategy. How should your organization enhance its IT framework to enable an Internet of Things implementation? In his session at Internet of @ThingsExpo, James Kirkland, Chief Architect for the Internet of Things and Intelligent Systems at Red Hat, will describe how to revoluti...
    The Internet of Things will greatly expand the opportunities for data collection and new business models driven off of that data. In her session at Internet of @ThingsExpo, Esmeralda Swartz, CMO of MetraTech, will discuss how for this to be effective you not only need to have infrastructure and operational models capable of utilizing this new phenomenon, but increasingly service providers will need to convince a skeptical public to participate. Get ready to show them the money! Speaker Bio: Esmeralda Swartz, CMO of MetraTech, has spent 16 years as a marketing, product management, and busin...
    SYS-CON Events announced today that Red Hat, the world's leading provider of open source solutions, will exhibit at Internet of @ThingsExpo, which will take place on November 4–6, 2014, at the Santa Clara Convention Center in Santa Clara, CA. Red Hat is the world's leading provider of open source software solutions, using a community-powered approach to reliable and high-performing cloud, Linux, middleware, storage and virtualization technologies. Red Hat also offers award-winning support, training, and consulting services. As the connective hub in a global network of enterprises, partners, a...
    P2P RTC will impact the landscape of communications, shifting from traditional telephony style communications models to OTT (Over-The-Top) cloud assisted & PaaS (Platform as a Service) communication services. The P2P shift will impact many areas of our lives, from mobile communication, human interactive web services, RTC and telephony infrastructure, user federation, security and privacy implications, business costs, and scalability. In his session at Internet of @ThingsExpo, Robin Raymond, Chief Architect at Hookflash Inc., will walk through the shifting landscape of traditional telephone a...
    BSQUARE is a global leader of embedded software solutions. We enable smart connected systems at the device level and beyond that millions use every day and provide actionable data solutions for the growing Internet of Things (IoT) market. We empower our world-class customers with our products, services and solutions to achieve innovation and success. For more information, visit www.bsquare.com.
    SYS-CON Events announced today that Matrix.org has been named “Silver Sponsor” of Internet of @ThingsExpo, which will take place on November 4–6, 2014, at the Santa Clara Convention Center in Santa Clara, CA. Matrix is an ambitious new open standard for open, distributed, real-time communication over IP. It defines a new approach for interoperable Instant Messaging and VoIP based on pragmatic HTTP APIs and WebRTC, and provides open source reference implementations to showcase and bootstrap the new standard. Our focus is on simplicity, security, and supporting the fullest feature set.
    How do APIs and IoT relate? The answer is not as simple as merely adding an API on top of a dumb device, but rather about understanding the architectural patterns for implementing an IoT fabric. There are typically two or three trends: Exposing the device to a management framework Exposing that management framework to a business centric logic • Exposing that business layer and data to end users. This last trend is the IoT stack, which involves a new shift in the separation of what stuff happens, where data lives and where the interface lies. For instance, it’s a mix of architectural style...
    SYS-CON Events announced today that SOA Software, an API management leader, will exhibit at SYS-CON's 15th International Cloud Expo®, which will take place on November 4–6, 2014, at the Santa Clara Convention Center in Santa Clara, CA. SOA Software is a leading provider of API Management and SOA Governance products that equip business to deliver APIs and SOA together to drive their company to meet its business strategy quickly and effectively. SOA Software’s technology helps businesses to accelerate their digital channels with APIs, drive partner adoption, monetize their assets, and achieve a...
    From a software development perspective IoT is about programming "things," about connecting them with each other or integrating them with existing applications. In his session at @ThingsExpo, Yakov Fain, co-founder of Farata Systems and SuranceBay, will show you how small IoT-enabled devices from multiple manufacturers can be integrated into the workflow of an enterprise application. This is a practical demo of building a framework and components in HTML/Java/Mobile technologies to serve as a platform that can integrate new devices as they become available on the market.
    SYS-CON Events announced today that Utimaco will exhibit at SYS-CON's 15th International Cloud Expo®, which will take place on November 4–6, 2014, at the Santa Clara Convention Center in Santa Clara, CA. Utimaco is a leading manufacturer of hardware based security solutions that provide the root of trust to keep cryptographic keys safe, secure critical digital infrastructures and protect high value data assets. Only Utimaco delivers a general-purpose hardware security module (HSM) as a customizable platform to easily integrate into existing software solutions, embed business logic and build s...
    Connected devices are changing the way we go about our everyday life, from wearables to driverless cars, to smart grids and entire industries revolutionizing business opportunities through smart objects, capable of two-way communication. But what happens when objects are given an IP-address, and we rely on that connection, sometimes with our lives? How do we secure those vast data infrastructures and safe-keep the privacy of sensitive information? This session will outline how each and every connected device can uphold a core root of trust via a unique cryptographic signature – a “bir...
    Internet of @ThingsExpo Silicon Valley announced on Thursday its first 12 all-star speakers and sessions for its upcoming event, which will take place November 4-6, 2014, at the Santa Clara Convention Center in California. @ThingsExpo, the first and largest IoT event in the world, debuted at the Javits Center in New York City in June 10-12, 2014 with over 6,000 delegates attending the conference. Among the first 12 announced world class speakers, IBM will present two highly popular IoT sessions, which will take place November 4-6, 2014 at the Santa Clara Convention Center in Santa Clara, Calif...
    Almost everyone sees the potential of Internet of Things but how can businesses truly unlock that potential. The key will be in the ability to discover business insight in the midst of an ocean of Big Data generated from billions of embedded devices via Systems of Discover. Businesses will also need to ensure that they can sustain that insight by leveraging the cloud for global reach, scale and elasticity.
    WebRTC defines no default signaling protocol, causing fragmentation between WebRTC silos. SIP and XMPP provide possibilities, but come with considerable complexity and are not designed for use in a web environment. In his session at Internet of @ThingsExpo, Matthew Hodgson, technical co-founder of the Matrix.org, will discuss how Matrix is a new non-profit Open Source Project that defines both a new HTTP-based standard for VoIP & IM signaling and provides reference implementations.

    SUNNYVALE, Calif., Oct. 20, 2014 /PRNewswire/ -- Spansion Inc. (NYSE: CODE), a global leader in embedded systems, today added 96 new products to the Spansion® FM4 Family of flexible microcontrollers (MCUs). Based on the ARM® Cortex®-M4F core, the new MCUs boast a 200 MHz operating frequency and support a diverse set of on-chip peripherals for enhanced human machine interfaces (HMIs) and machine-to-machine (M2M) communications. The rich set of periphera...

    SYS-CON Events announced today that Aria Systems, the recurring revenue expert, has been named "Bronze Sponsor" of SYS-CON's 15th International Cloud Expo®, which will take place on November 4-6, 2014, at the Santa Clara Convention Center in Santa Clara, CA. Aria Systems helps leading businesses connect their customers with the products and services they love. Industry leaders like Pitney Bowes, Experian, AAA NCNU, VMware, HootSuite and many others choose Aria to power their recurring revenue business and deliver exceptional experiences to their customers.
    The Internet of Things (IoT) is going to require a new way of thinking and of developing software for speed, security and innovation. This requires IT leaders to balance business as usual while anticipating for the next market and technology trends. Cloud provides the right IT asset portfolio to help today’s IT leaders manage the old and prepare for the new. Today the cloud conversation is evolving from private and public to hybrid. This session will provide use cases and insights to reinforce the value of the network in helping organizations to maximize their company’s cloud experience.
    The Internet of Things (IoT) is making everything it touches smarter – smart devices, smart cars and smart cities. And lucky us, we’re just beginning to reap the benefits as we work toward a networked society. However, this technology-driven innovation is impacting more than just individuals. The IoT has an environmental impact as well, which brings us to the theme of this month’s #IoTuesday Twitter chat. The ability to remove inefficiencies through connected objects is driving change throughout every sector, including waste management. BigBelly Solar, located just outside of Boston, is trans...
    SYS-CON Events announced today that Matrix.org has been named “Silver Sponsor” of Internet of @ThingsExpo, which will take place on November 4–6, 2014, at the Santa Clara Convention Center in Santa Clara, CA. Matrix is an ambitious new open standard for open, distributed, real-time communication over IP. It defines a new approach for interoperable Instant Messaging and VoIP based on pragmatic HTTP APIs and WebRTC, and provides open source reference implementations to showcase and bootstrap the new standard. Our focus is on simplicity, security, and supporting the fullest feature set.