
いつも参考にさせていただいております。
現在、aspで作成したweb環境を運用しております。
その中で抽出したデータをExcelに出力する処理がありますが、これを以下の方法で行っております。
====================================
response.buffer = true
response.ContentType = "application/vnd.ms-excel"
response.AddHeader "content-disposition", "inline; filename=dynamic.xls"
~
response.flush
response.end
====================================
ただ、「Excel2013」であることから、出力されたExcelを開くたびにバージョン不一致の警告(ファイル形式と拡張子が一致しません)が表示されて不便です。
よって、Excel出力をExcelオブジェクトを用いた方法に変更しようと考えております。
====================================
'ファイルシステムオブジェクト生成
Set oFs = Server.CreateObject("Scripting.FileSystemObject")
'テンポラリファイル名取得
sFileName = Split(oFs.GetTempName, ".")
'エクセルファイル名にする
sXlsName = sFileName(0) & ".xls"
'テンプレートが保存されているフォルダの物理パスを取得
sPath = oFs.GetFolder(Server.MapPath("/hogehoge/")).ParentFolder
'エクセルのオブジェクトを生成
Set oXls = Server.CreateObject("Excel.Application")
'エクセルのテンプレートファイルを開く
Set oTmp = oXls.Workbooks.Open(sPath & "\temlate\template.xls")
~
====================================
ここからが質問です。
Excelオブジェクト作成時、エラーになってオブジェクトの作成が失敗します。
====================================
【オブジェクト作成を「Server.CreateObject」で行った場合】
Set oXls = Server.CreateObject("Excel.Application")
⇒ 以下のエラーが表示されます。
Server オブジェクト エラー 'ASP 0177 : 80080005'
Server.CreateObject に失敗しました
【オブジェクト作成を「CreateObject」で行った場合】
Set oXls = CreateObject("Excel.Application")
⇒ 以下のエラーが表示されます。
Microsoft VBScript 実行時エラー エラー '800a01ad'
ActiveX コンポーネントはオブジェクトを作成できません。: 'Excel.Application'
====================================
いろいろなサイトを情報をもとに対応しましたが、解決の糸口が見えない状況です。
====================================
【今まで試みた対応】
(1)コンポーネントサービスの「DCOMの構成」にて、「Microsoft Excel Application」の「起動とアクティブ化のアクセス許可」に「EveryOne」を追加。
(2)以下のフォルダを用意してフォルダのアクセス許可に「EveryOne」を追加。
C:\Windows\System32\config\systemprofile\Desktop
C:\Windows\SysWOW64\config\systemprofile\Desktop
(3)オブジェクト作成時、「Excel.Application」を「Excel.Application.15」に変更。
====================================
なお、開発環境は以下となります。
====================================
【開発環境】
OS:windows 8.1 64bit
IIS:8.5
Excel:2013
その他:(1)aspを使用(.netではありません)
(2)「windows 8.1」はあくまでテスト環境です。
正常に動作することを確認後、本番環境「Win2008Server R2」に組み込む予定です。
====================================
私事ではありますが、スケジュール的に押し迫っております。
お忙しいところ申し訳ありませんが、解決方法のご教授をお願いいたします。
以上です。
No.1ベストアンサー
- 回答日時:
残念ながら、何重もの理由で、そのソリューションは成立しません。
・Excelのようなマルチスレッド未対応のオブジェクトをWebサーバで走らせると、確実に暴走するか、エラーで停止します。ExcelやAcrobatなど、何でも同じです。
・エラーが起きた後、メモリからオブジェクトが抹消されないため、あっという間にメモリリークを起こし、サーバがハングします。
・そもそも、ソフトウェアベンダは、Excelなどのアプリケーションをサーバ上で稼働させるライセンシーを認めていません。
・64biot OSのうえでレガシーASPが正常に動作する保証はありません。そもそも、32bitの2003サーバでさえ、ASPを動作させるためには多数の依存ライブラリをインストールする必要がありました。
FileSystemObjectやDictionaruObjectは間違いなく落ちます。
・Windows8.1/64bitと、Windows 2008R2サーバでは、IISのバージョンや動作スキームが完全に異なっており、32ビット依存コンポーネントのインストール状況が違います。
また、上記のセキュリティ設定も、サーバOSは根本的に異なります。
自分ならさっさと諦めて、その部分だけASPX仕様に変更し、Excel生成用のWebライセンスつき市販ライブラリを購入してカタをつけます。
Excel Creator
http://www.adv.co.jp/product/product_excelcreato …
Webサーバ上で正しいExcelデータを生成するということは、非常にコストのかかるタスクなのですよ。
それが予算の関係で不可能なら、CSVで我慢してもらうか、Office XLSXを解読して生成するか、HTMLかWell FormedなXMLを生成し、レスポンスヘッダを詐称して強引にエクセルに認識させる(要するに現在ご提示のNGな方法)かすることです。
回答になってなくて申し訳ありませんが、「やっても無駄」というお答えしかできません。
あしからず。
ご回答いただきありがとうございます。
そうですか、私がやろうとしていたことは、ある意味、非現実的なことなのですね。
別方法を含めて再検討します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
【教えて!goo ウォッチ 人気記事】風水師直伝!住まいに幸運を呼び込む三つのポイント
記事を読む>>
-
ASPでCSVファイルを作成しダウンロードさせる
Microsoft ASP
-
ASPからEXCELに出力する
Microsoft ASP
-
ASPから既存のexcelブックを開きたいです
Microsoft ASP
-
4
ASPからJavaScriptへの受け渡し方法は?
Microsoft ASP
-
5
CreateObject(Excel.Application")でVBScript実行時エラー"
Microsoft ASP
-
6
[ASP]If~Else If~End If 対 Case
Microsoft ASP
-
7
aspで作成するcsvファイルで、excelのセル内で、改行をさせるには
Microsoft ASP
-
8
【ASP.NET】ページ遷移してもGridView内の値を保持する方法
その他(プログラミング・Web制作)
-
9
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
10
ASP.NETでのメッセージ画面を出すには
Microsoft ASP
-
11
IUSR でCreateObject(Excel.Application")ができない。"
Microsoft ASP
-
12
Webページ上のボタン等の位置を移動したい。
Microsoft ASP
-
13
ASP.NETとC#でWebフォームを呼び出したり閉じたりする方法について
Microsoft ASP
-
14
VBSでをエスケープする文字は?"
その他(プログラミング・Web制作)
-
15
VBのReturnの使い方
Visual Basic(VBA)
-
16
batファイル実行後、cmdを自動終了させたい
Windows 7
-
17
HTMLからフォルダを開きたい
HTML・CSS
-
18
ASP.Net 条件により自身を閉じるには
Microsoft ASP
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
読み取り/実行は可能でコピー不...
-
5
スイッチングハブのMACアドレス...
-
6
bashで15分前と現在のエポック...
-
7
bat 同名ファイルコピー時にリ...
-
8
ONUとONTの違いを教えてください
-
9
RTX1200とL2TPクライアントの設...
-
10
セグメントを越えてのプリンタ...
-
11
自作pcについて
-
12
マウントしたディスクにcpで、...
-
13
50KBは何文字に相当するのでし...
-
14
ネジ、ボルト等の在庫管理について
-
15
背面ケースファンがきちんと回...
-
16
”Tortoise SVN” と ”Subversio...
-
17
アジャイル開発のタスクが定時...
-
18
TortoiseSVNにおける削除ファイ...
-
19
【緊急】ASPでのExcel出力方法...
-
20
分電盤の208Vとのいみは?
おすすめ情報
公式facebook
公式twitter