![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?8acaa2e)
いつも参考にさせていただいております。
現在、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で質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) このVBAでExcelアプリケーションを作成は必要ですか? 3 2023/07/19 21:13
- Visual Basic(VBA) エクセルのマクロを使ってメールを送る方法について教えてください 2 2022/03/29 01:36
- Visual Basic(VBA) VBA アドインについて お詳しい方 ご教授をお願いします。 相談事項 現在以下の対応を実施した所、 1 2022/11/02 16:53
- Visual Basic(VBA) vba メモリ節約 3 2022/09/16 21:45
- Visual Basic(VBA) access count数を変数に格納 2 2022/03/30 19:21
- Visual Basic(VBA) 【VBA】Excelの特定範囲のセルを画像で保存したい 2 2023/01/25 13:06
- Excel(エクセル) マクロの付いたExcelが開けません 3 2023/02/01 10:54
- Visual Basic(VBA) VBAでファイルを開くプログラムがエラーです 2 2023/02/21 16:56
- Visual Basic(VBA) Excel VBAについて、 フォルダ内のファイルを全て開きたい場合、 FSOを使えば、Dirは使わ 1 2023/01/27 13:18
- Visual Basic(VBA) 複数のcsvファイルをExcelに一括変換したい 2 2023/03/03 12:44
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
ASPから既存のexcelブックを開きたいです
Microsoft ASP
-
IUSR でCreateObject(Excel.Application")ができない。"
Microsoft ASP
-
ASPでExcelファイルを開く場合
Microsoft ASP
-
-
4
ASPによるEXCELファイルの操作
Microsoft ASP
-
5
ASPプログラミングでADODB.Connection (0x800A0E79)エラーが発生
Microsoft ASP
-
6
ASPでCSVファイルを作成しダウンロードさせる
Microsoft ASP
-
7
エラー 'ASP 0115' について
Microsoft ASP
-
8
隠しフィールドをVBScriptでの受取る方法
Microsoft ASP
-
9
ASPで画面間のパラメタ受け渡し
Microsoft ASP
-
10
ASPの変数の値をJAVA Script内で使用したいのですが
Microsoft ASP
-
11
ASPでこんなエラーが出たんですけど、理由が分かりません・・
Microsoft ASP
-
12
FileExitsについて
Microsoft ASP
-
13
ASPからJavaScriptへの受け渡し方法は?
Microsoft ASP
-
14
CreateObject(Excel.Application")でVBScript実行時エラー"
Microsoft ASP
-
15
javascriptでASPにデータを渡す
JavaScript
-
16
オブジェクト生成エラー
Microsoft ASP
-
17
ASP内で他のASPファイルを読み込む方法
Microsoft ASP
-
18
SqlDataSource SelectCommand の書き方
Microsoft ASP
-
19
VistaのIISで動作するASPのExcel処理
Microsoft ASP
-
20
SQLDataSourceのSQL文を変えて・・・
Microsoft ASP
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ファイルが開けません
-
Symantec AntiVirusのエラーで...
-
net timeコマンドでアクセスエ...
-
【緊急】ASPでのExcel出力方法...
-
SQL接続ACCESSにPCからはODBCエ...
-
マザーボード ドライバとは必ず...
-
P6X58D-E SSD RAID0構築
-
自作pcについてです CPUとマザ...
-
マザーボード交換後のドライバ...
-
win7が新規インストールできません
-
WinPCのIntel Management Engin...
-
「インテル ドライバー & サポ...
-
マザボZX-NC68GMのLANドライバ...
-
マザーボードドライバをインス...
-
パソコンパーツのHDDが値上がり...
-
ハードディスク交換(シリアルA...
-
ブートメニューにSSDが表示され...
-
先日自作pcを作ったんですが 「...
-
Asrock Z370 Pro4のドライバは...
-
【至急】 RTX2080Sを組んだので...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【緊急】ASPでのExcel出力方法...
-
net timeコマンドでアクセスエ...
-
ファイルが開けません
-
steamがダウンロードできない
-
IIS7.0でのCGIエラー 502
-
SQL接続ACCESSにPCからはODBCエ...
-
プリントサーバが見えなくなる
-
apacheがたまに起動しない
-
httpdのエラーが出ます
-
「i phonenoの製造国の確認の仕...
-
CentOSでrsyncを使用したバック...
-
遅延書き込みデータの紛失
-
RAID1とRAID5の信頼性について
-
検索しても分からなかったので...
-
アドビリーダーのエラーの件
-
Owncloudを自宅サーバで動かし...
-
サーバーエラー(有効なIPがな...
-
Symantec AntiVirusのエラーで...
-
DNSエラーって?
-
gooのページにスクリプトがかか...
おすすめ情報