trouble shooting

EclipseのXMLエディタ一行目でDTDエラー「参照ファイルにエラーが含まれています」

投稿日:2019年7月10日

事象

checkstyleのルールXMLをEclipseで開くと一行目にエラーマーク。

カーソルを合わせた時のメッセージ。

XMLのデータ構造整合性をチェックするDTD(Data Type Definition)がおかしい?

参照ファイルにエラーが含まれています 
(http://checkstyle.sourceforge.net/dtds/configuration_1_3.dtd)。
 For more information, right  click on the message in the Problems View and select "Show Details..."

DTDのURLにブラウザでアクセスすると正しい.dtdファイルが普通に落ちてくるので初見では「?」となります。

原因

EclipseのXMLエディタはDTDを落としに行って、初っ端リクエストで200以外が帰ってきた時はエラーにする仕様の為です。

今回はsourceforge.net → sourceforge.ioへと301リダイレクトが2回応答され、3回目のcheckstyle.orgでようやく200が帰ってきている通信内容でした。

1:http://checkstyle.sourceforge.net/dtds/configuration_1_3.dtd (301 : Move Permanently)
2:https://checkstyle.sourceforge.io/dtds/configuration_1_3.dtd (301)
3:https://checkstyle.org/dtds/configuration_1_3.dtd (200)

対処

最初からDTDのURLを、HTTPステータス200を返してくれるURL、この場合だと3回目のリクエストの「https://checkstyle.org/dtds/configuration_1_3.dtd」にしておくことで解消されます。

まとめ

この事象はEclipse初期から存在しています。

リダイレクトが終わるまで待っててくれてもいいんじゃないですかEclipseさん、とずっと思っていたけど出来るだけ早くリダイレクト先に移行しておいた方がいいですし、ローカルDTDを参照するのも新版に追従出来ていない感があるので割り切るようにしていました。

とは言えメッセージから内容が伝わり難いことは間違いなく、初見で遭遇するとなんでやねん状態になること請け合いです。

301が帰ってきたら「リダイレクトが返却されました。https://~~にDTDのURLを変更してください。」とかメッセージを出すくらいのサービス精神があってもいいんじゃないかなぁ、と思っていますが、XML自体がオワコン風潮ですから改善を期待するよりエラーナレッジを持っておく方が現実的な対処かも。

-trouble shooting
-, ,

執筆者:

関連記事

PuppeteerでGoogle検索すると「UnhandledPromiseRejectionWarning: Error: Node is either not visible or not an HTMLElement」

Puppeteerを新規インストールしてGoogle検索すると大概失敗、稀に成功します。 公式サンプルのGoogle Developers検索は動くのにGoogle検索は何でしっかり動かんの?となりま …

Typescript3.0以下の環境で発生する「Cannot find name ‘unknown’」に対処する

目次1 事象2 原因3 対処4 まとめ 事象 Typescript2.3.4を使っている息の長いWebシステムでnpm installをし直し、tscビルドし直したらトランスパイルエラーが発生。「un …

adb devicesコマンドでAndroid端末を認識しない

目次1 事象2 原因3 解決 事象 USB接続するAndroidによって以下のエラーが出たりします。 C:\src\ionic\awsomeapp>adb devices List of dev …

Metabaseの登録データベース削除時に入力を求められて消せない

分析対象として登録したデータベースを一覧から削除する際に入力値を求められ、何を入れていいか分からずプチはまりました。 結論から述べると入力する文字は「delete」でした。 事象 Metabase(v …

Apple PayのMerchant Doamin設定がPendingになり、Verifiedにならなかった原因

開発しているWebシステム上でApple Payによるクレジットカード選択が出来るようにするには「Apple Developer Program」で「Merchant Domain」を設定します。 O …

 

shingo.nakanishi
 

東京在勤、1977年生まれ、IT職歴2n年、生涯技術者として楽しく生きることを目指しています。デスマに負けず健康第一。