【茶包射手專欄】ReportViewer 2008 on IIS7

在測試ReportViewer 2008的過程中,遇到一個問題。

我的作業環境是Windows 2008,用Visual Studio 2008開啟在IIS7上的現有Web Site,新增一個WebForm.aspx,從工具箱拖入ReportViewer,按控件右上角的Report Wizard隨意做了一個ObjectDataSource,一切看來順利得很,但一檢視網頁,噴出一堆Javascript錯誤: (共22個,底下列了幾個)

  • RSClientController is not defined
  • ReportViewerHoverButton is not defined
  • document.getElementById("ReportViewer1_ctl01_ctl01_ctl00_ctl00").Controller is undefined
  • document.getElementById("ReportViewer1").ClientController is undefined
  • ReportViewerLink is not defined

用Firebug一查,原來網頁中引用很多類似Reserved.ReportViewerWebControl.axd?OpType=Resource&Version=9.0.30729.1&Name=Microsoft.Reporting.WebForms.Scripts.ReportViewer.js的URL,用來載入控件所需的JS、圖檔等等,但全部傳回HTTP 404,以找不到檔案收場,看來是Reserved.ReportViewerWebControl.axd這個HttpHandler沒被正確地註冊所致。

Google到一篇不錯的文章,依著提示摸索一番(但文中"2.Type: Microsoft.Reporting.Microsoft.Reporting.WebForms.HttpHandler, ...."誤寫了多餘的Microsoft.Reporing,應為Microsoft.Reporting.WebForms.HttpHandler才正確,被這個筆誤給攪和了一陣子),總算把問題解決了。

背後真正的問題是這樣的,Visual Studio 2008在你拖入ReportViewer時會自動在web.config的system.web中加入HttpHandler Mapping:

<add path="Reserved.ReportViewerWebControl.axd" verb="*" type="Microsoft.Reporting.WebForms.HttpHandler, Microsoft.ReportViewer.WebForms, Version=9.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" validate="false" />

但問題來了,在IIS7上ASP.NET有兩種執行模式,Classic Mode及Integrated Mode,web.config裡HttpHandler等設定也變成有兩區,system.web是給Classic Mode用的,system.webServer是給Integrated Mode用的。

VS2008自動加入HttpHandler設定只改了system.web區(大概是因為IIS7比VS2008晚發展),卻沒一併在system.webServer區新增設定,而我的WebApp設定是用Integrated Mode執行,這下子等於沒註冊Reserved.ReportViewerWebControl.axd,自然以HTTP 404收場。

前述文章中開啟IIS管理UI加入HttpHandler Mapping的動作,背後便是在system.webServer加入以下的HttpHandler設定:

<add name="Reserved-ReportViewerWebControl-axd" path="Reserved.ReportViewerWebControl.axd" verb="*" type="Microsoft.Reporting.WebForms.HttpHandler, Microsoft.ReportViewer.WebForms, Version=9.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" resourceType="Unspecified" preCondition="integratedMode" />

真相大白了,收隊!

歡迎推文分享:
Published 02 February 2009 01:45 PM 由 Jeffrey
Views: 21,305



意見

# lxy said on 11 August, 2010 12:21 PM

ok

# 安溪本山茶叶 said on 12 August, 2010 08:50 PM

哈 原来是这样 领悟了

你的看法呢?

(必要的) 
(必要的) 
(選擇性的)
(必要的) 
(提醒: 因快取機制,您的留言幾分鐘後才會顯示在網站,請耐心稍候)

5 + 3 =

搜尋

Go

<February 2009>
SunMonTueWedThuFriSat
25262728293031
1234567
891011121314
15161718192021
22232425262728
1234567
 
RSS
創用 CC 授權條款
【廣告】
twMVC
最新回應
  • 2010-08-12 安溪本山茶叶
    【茶包射手專欄】ReportViewer 2008 on IIS7
    哈 原来是这样 领悟了
  • 2010-08-11 lxy
    【茶包射手專欄】ReportViewer 2008 on IIS7
    ok

Tags 分類檢視
關於作者

一個醉心技術又酷愛分享的Coding魔人,十年的IT職場生涯,寫過系統、管過專案, 也帶過團隊,最後還是無怨無悔地選擇了技術鑽研這條路,近年來則以做一個"有為的中年人"自許。

文章典藏
其他功能

這個部落格


Syndication