ASMXサービスに問題があります。POSTメソッドを使用すると、エラー「500-内部サーバーエラー」が返されます。しかし、GETメソッドを使用すると、非常にうまく機能します。IISログを表示し、次の状況を確認しました。
2013-01-16 00:00:06 212.158.165.217 GET /service.asmx/GetStopSalesAndQuotes2 Login=xxxxx&Password=xxxxx=&checkPoint=2013-01-08T14:22:56Z 80 -
85.12.229.170 Mozilla/4.0+(compatible;+Windows+NT+5.1;+SV1);+ross-tur.ru;+8-800-100-99-30+(ext.+501); 500 0 0 140
2013-01-16 00:00:06 212.158.165.217 POST /service.asmx - 80 -
62.80.175.194 Mozilla/4.0+(compatible;+MSIE+6.0;+MS+Web+Services+Client+Protocol+4.0.30319.296) 500 0 0 31
私はこの問題を探して解決しようとしました。
最初にweb.configを調べましたが、必要なタグが見つかりました。
<add name="HttpGet"/>
<add name="HttpPost"/>
セカンダリweb.configにいくつかのタグを追加して、デバッグモードをオンにしようとしました。
<system.diagnostics>
<trace autoflush="true" />
<sources>
<source name="System.Web.Services.Asmx">
<listeners>
<add name="AsmxTraceFile" type="System.Diagnostics.TextWriterTraceListener" initializeData="local.log" traceOutputOptions="LogicalOperationStack, DateTime, Timestamp, ProcessId, ThreadId" />
</listeners>
</source>
</sources>
<switches>
<add name="System.Web.Services.Asmx" value="Verbose" />
</switches>
</system.diagnostics>
しかし、ログは作成されていません。アプリケーションには権利がないと思いました。
サイトの管理者のログイン/パスを指定して管理者権限を付与しようとしましたが、問題が解決せず、ログがまだ作成されていません。
このエラーをデバッグしようとした他の方法:
- カスタムエラーモードをオフにし、「true」状態でトレースを有効にします。
<system.web> <customErrors mode="Off"/> <trace enabled="true" requestLimit="10" pageOutput="false" traceMode="SortByTime" localOnly="false"/> </system.web>
- また、traceおよびpolicyTraceオプションを有効にしようとしました。
<microsoft.web.services2> <diagnostics> <trace enabled="true"/> <policyTrace enabled="true"/> </diagnostics> <security> <timeToleranceInSeconds>86400</timeToleranceInSeconds> <securityTokenManager type="Megatec.MasterService.TourMLLogic.PasswordProvider, ServiceComponents, Version=1.0.0.0, Culture=neutral" qname="wsse:UsernameToken" xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"/> </security> </microsoft.web.services2>
しかし、結果はありません。IISの構成に問題があると思います。私を助けてください。
PSすみません私の悪い英語=)