Why Not Automation
Why Not Automation
There are two questions that our customers ask us.
The first one is Do your products require that Microsoft Office be installed in order for them to run? The short simple answer is no. Aspose and Aspose components are totally independent and are not affiliated with, nor authorized, sponsored or otherwise approved by Microsoft Corporation.
The question that typically follows next is Why should we use Aspose products instead of Microsoft Office Automation? This question cannot be answered as easily. The shortest answer we could give is that there are many reasons, the main reason is that Microsoft itself strongly recommends against Office Automation from software solutions.
As stated above, there are several reasons why Aspose components are a better alternative to automation. Some of the key reasons are:
- Security
- Stability
- Scalability/speed
- Price
- Features
Below is a better elaboration on each of the key points. Also be sure to visit the Additional Information section which provides link to independent user evaluations.
Security
The following is a direct quote from the above referenced Microsoft Article:
“Office Applications were never intended for use server-side, and therefore do not take into consideration the security problems that are faced by distributed components. Office does not authenticate incoming requests, and does not protect you from unintentionally running macros, or starting another server that might run macros, from your server-side code. Do not open files that are uploaded to the server from an anonymous Web! Based on the security settings that were last set, the server can run macros under an Administrator or System context with full privileges and compromise your network! In addition, Office uses many client-side components (such as Simple MAPI, WinInet, MSDAIPP) that can cache client authentication information in order to speed up processing. If Office is being automated server-side, one instance may service more than one client, and because authentication information has been cached for that session, it is possible that one client can use the cached credentials of another client, and thereby gain non-granted access permissions by impersonating other users.”
Aspose products are very secure. Aspose components run in the same user context as all ASP.NET applications, under the ASPNET user. Therefore, Aspose components do not pose a potential risk to vital system resources. Furthermore, when a document is opened by an Aspose component, macros are not automatically run. Aspose components were built with the goal of allowing developers to create, manipulate and save Office files. None of the risks associated with the Microsoft Office package are inherent to Aspose components.
Stability
The following is a direct quote from the above referenced Microsoft Article:
“Office 2000, Office XP and Office 2003 use Microsoft Windows Installer (MSI) technology to make installation and self-repair easier for an end user. MSI introduces the concept of “install on first use”, which allows features to be dynamically installed or configured at runtime (for the system, or more often for a particular user). In a server-side environment this both slows down performance and increases the likelihood that a dialog box may appear that asks for the user to approve the install or provide an appropriate install disk. Although it is designed to increase the resiliency of Office as an end-user product, Office’s implementation of MSI capabilities is counterproductive in a server-side environment. Furthermore, the stability of Office in general cannot be assured when run server-side because it has not been designed or tested for this type of use. Using Office as a service component on a network server may reduce the stability of that machine and as a consequence your network as a whole. If you plan to automate Office server-side, attempt to isolate the program to a dedicated computer that cannot affect critical functions, and that can be restarted as needed.”
Since Aspose components are packaged into a single DLL, there will never be a need to install any additional parts or pieces for them to function. Aspose components are only utilized by .NET applications and there is no portion of the component code designed to wait on a human response. Aspose components have been thoroughly tested and are extremely stable. Aspose components are used by Companies such as: IBM, Hilton, Reader’s Digest, Bank of America and many more.
Scalability/Speed
The following is a direct quote from the above referenced Microsoft Article:
“Server-side components need to be highly reentrant, multi-threaded COM components with minimum overhead and high throughput for multiple clients. Office Applications are in almost all respects the exact opposite. They are non-reentrant, STA-based Automation servers that are designed to provide diverse but resource-intensive functionality for a single client. They offer little scalability as a server-side solution, and have fixed limits to important elements, such as memory, which cannot be changed through configuration. More importantly, they use global resources (such as memory mapped files, global add-ins or templates, and shared Automation servers), which can limit the number of instances that can run concurrently and lead to race conditions if they are configured in a multi-client environment. Developers who plan to run more then one instance of any Office Application at the same time need to consider Pooling or Serializing Access to the Office Application for avoiding potential Deadlocks or Data Corruption.”
Aspose components are highly scalable and lightening fast. Office applications were not designed to be simultaneously used by 100s and 1000s of users. However, Aspose components are designed for just that. Our components are a true .NET solution and perform flawlessly whether on a single server, powering a single application or on a load balanced Web Form powering an enterprise-wide application.
Price
When an application utilizes Microsoft Office Automation, a copy of Microsoft Office must be purchased for each machine that runs the application. There are many times that an application may need to create or manipulate an office file but does not require the user to have Microsoft Office. Aspose offers a very Cost Effective and royalty-free redistribution license that will allow deployment to an unlimited number of users with no licensing worries.
Features
Aspose components provide everything needed for managing Office files plus much more. They are designed with the philosophy of allowing developers to accomplish the greatest results with the least amount of work. Unlike Office Automation, Aspose components provide many powerful and time-saving functions. For instance, Aspose.Cells offers developers the ability to import data from a DataTable or DataView directly into an Excel file. Aspose.Words offers a similar feature that allows developers to populate a Word (that is Mail Merge) document directly from any .NET data object. Every Component in the Aspose family offers their own set of unique and powerful features.
The best part of purchasing an Aspose component (or component suites like Aspose.Total) is having access to our development teams. Our development teams realize that if there is a feature that your company needs, more than likely other companies will need it as well. While not every feature request can be added, our teams try to be very open-minded and flexible when assisting. That mind set is what has helped Aspose components to become as powerful as they are. If there are additional features that you need from Office Automation objects, your chances of having them added are very, very low.
Conclusion
While this article has covered many of the key points why Aspose components are a better choice than Office Automation, there are many, many more. This article primarily addresses only the most key points. All of the different Aspose components offer a risk-free, no-obligation Evaluation Version. We encourage you to take advantage of that Evaluation to better see what Aspose can do for your applications.