質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.33%

  • C#

    7707questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

  • REST

    148questions

    REST(Representational State Transfer)はwebアプリケーションの構築スタイルの一種です。HTTP GET/POSTによってリクエストを送信し、レスポンスはXMLで返されます。SOAPのようなRPCの構築と比べるとサーバからクライアントを分離することが出来る為、人気です。

  • WCF

    14questions

    Windows Communication Foundation

WCFのテスト時エラーが出ます→「リモート サーバーから予期しない応答が返されました: (400) Bad Request。」

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,215

RI_KU

score 16

■Visual Studo2010
■.netFramework3.5
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

■PjStartStatusRestApp(サービス(Iサービスを実装)とIサービスが入っているプロジェクト)
対象フレームワーク.NET Framework3.5

■restSample(Form1.cs, App.configが配置されている)
対象フレームワーク.NET Framework3.5

■/pjRestWeb(webサイトかつweb.configが配置されている)
対象フレームワーク.NET Framework4.0

webサイトと対象フレームワークを合わせても変わりませんでした。
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/
【Form1.cs】
『int result = service.PjStrSttsUpdater(mode.Text, code.Text, すsubcode.Text);』の部分で掲題のエラーが発生します。
フォームのボタンを押したらテキストボックスの文字列を取得して、DBの更新結果をラベルに表示するだけの簡単な処理なので、フォームのボタンをポチポチ連打していたら突然発生しました。

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
usingnamespace】.PjStatusRestApp;
using System.IO;
using System.Runtime.Serialization;
using System.ServiceModel.Activation;
using System.ServiceModel.Web;
using System.Web;
using System.Diagnostics;

namespacenamespace】.restSample
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            this.label1.Text = "return";
            this.mode.Text = string.Empty;
            this.pjsbno.Text = string.Empty;
            this.pjcode.Text = string.Empty;
            this.labelReslt.Text = string.Empty;
        }

        private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                // 20170313 UIに記述
                var factory = new WebChannelFactory<IPjStartApplication>(new Uri(ConfigUtil.GetSISetting("PjStartApplication.Url")));
                var service = factory.CreateChannel();
******************************ココ**********************
                int result = service.PjStrSttsUpdater(mode.Text, code.Text, subcode.Text);
******************************************************
                string resultMessage = string.Empty;
                if (result == 200) resultMessage = "正常終了";
                else if (result == 400) resultMessage = "パラメータ不正";
                else if (result == 401) resultMessage = "申請ステータスが同じ";

                // 結果の表示
                labelReslt.Text = resultMessage;

                // ここまで
            }
            catch (Exception ex)
            {
                // エラーだった場合はイベントログに内容を出力
                LogWriter.CreateInstance().Write(LogLevel.Error, ex.Message, ex);
            }
        }
    }
}

クライアント側(このフォームからテキストを送っています)
App.config

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.serviceModel>
    <client>
      <endpoint name="PjStartApplicationClientEndpoint" address="http://localhost:55723/【path】/PjStrSttsUpdater" binding="webHttpBinding" contract="【namespace】.PjStartApplication"/>
    </client>
  </system.serviceModel>
</configuration>

サーバ側 web.config

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.web>
    <compilation debug="true" targetFramework="4.0"/>
  </system.web>

  <system.serviceModel>
    <serviceHostingEnvironment aspNetCompatibilityEnabled="true"/>
    <services>
      <service name="【namespace】.PjStartApplication" behaviorConfiguration="NewBehavior">
        <endpoint address="" behaviorConfiguration="ServiceBehavior" binding="webHttpBinding" bindingConfiguration="" contract="【namespace】.IPjStartApplication"/>
      </service>
    </services>
    <behaviors>
      <endpointBehaviors>
        <behavior name="ServiceBehavior">
          <webHttp/>
        </behavior>
      </endpointBehaviors>
      <serviceBehaviors>
        <behavior name="NewBehavior">
          <serviceMetadata httpGetEnabled="true"/>
        </behavior>
      </serviceBehaviors>
    </behaviors>
    <bindings/>
  </system.serviceModel>
</configuration>

ブラウザを起動してテストしているわけではないですが、一応ブラウザのキャッシュクリアも試したのですが、ダメでした。

調べても有力な情報を見つけることができず一日詰まっております。。。

<<2017/03/17 17:09 追記>>
■Interface

namespacenamespace】.PjStatusRestApp
{
    /// <summary>
    /// 状況更新サービス
    /// </summary>
    [ServiceContract]
    public interface IPjStartApplication
    {
        /// <summary>
        /// 状況更新
        /// </summary>
        /// <param name="PjStrSttsUpdater"></param>
        [OperationContract]
        [WebInvoke(
            Method = "POST",
            BodyStyle = WebMessageBodyStyle.Wrapped,
            //RequestFormat = WebMessageFormat.Json,
            //ResponseFormat = WebMessageFormat.Json,
            UriTemplate = "PjStrSttsUpdater")]
        int PjStrSttsUpdater(string mode, string code, string subcode);

    }
}

■サービス

namespacenamespace】.PjStatusRestApp
{
    [AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Required)]
    public class PjStartApplication : IPjStartApplication
    {
        public int PjStrSttsUpdater(string mode, string code, string subcode)
        {
            {
                #region 更新処理
                using (SqlConnection cnn = "Connection取得処理")
                {
                    string connectionString = string.Empty;
                    connectionString = "DB接続用文字列";
                    cnn.ConnectionString = connectionString;
                    cnn.Open();
                    SqlCommand cmd = new SqlCommand();
                    cmd.Connection = cnn;
                    cmd.CommandType = CommandType.StoredProcedure;

                    cmd.CommandText = "[dbo].[PjStartStatusUpdate]";
                    cmd.Parameters.Clear();
                    cmd.Parameters.Add("@MODE", System.Data.SqlDbType.NVarChar).Value = mode;
                    cmd.Parameters.Add("@CODE", System.Data.SqlDbType.NVarChar).Value = code;
                    cmd.Parameters.Add("@SUBCODE", System.Data.SqlDbType.NVarChar).Value = subcode;

                    // Return
                    cmd.Parameters.Add("ReturnValue", System.Data.SqlDbType.Int);
                    cmd.Parameters["ReturnValue"].Direction = System.Data.ParameterDirection.ReturnValue;

                    // 実行
                    cmd.ExecuteNonQuery();
                    int returnValue = (int)cmd.Parameters["ReturnValue"].Value;
                    // 戻り値の出力
                    // Debug.WriteLine(returnValue);
                    return returnValue;
                #endregion
                }
            }
        }
    }
}
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • tamoto

    2017/03/17 16:18

    > ポチポチ連打していたら突然発生した気がします 気がしますじゃなくて、「連打すると」発生するのか、必ずしもそうではないのか、はっきりして下さい。仮に連打しなくても発生するのであれば、回答の内容がまるっきり変わると思いますよ。

    キャンセル

  • RI_KU

    2017/03/17 16:28

    連打してたらいきなり発生しました。書き直します。ありがとうございます。

    キャンセル

  • tamoto

    2017/03/17 16:43

    修正ありがとうございます。もう一つですが、「キャッシュクリアも試したのですが、ダメでした。」とあるので、連打による「不具合の再現性はある」ということで良いんですよね?だとすると、見た感じPjStrSttsUpdaterメソッド内部のほうに問題があると予想されます。根本的な解決をしたい場合はそちらの方に手を入れる必要があると思います。

    キャンセル

  • RI_KU

    2017/03/17 17:15

    追記いたしました。インターフェースのコメントアウト部Request, ResponseFormat....もコメントアウトを、片方ずつ外す、両方外すなどして実行しましたが変わりませんでした。

    キャンセル

回答 1

check解決した方法

0

申し訳ありません。自己解決いたしました。
VS2010のソリューションエクスプローラ上でwebサイト(web.configが置いてある場所)のポート番号を変えることで一時的に解決できました。
やはりキャッシュか何かの問題だったのでしょうか。ポート番号を変えただけなのでボタンを連打したらまた起こりそうですが・・・・。

ありがとうございました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.33%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • C#

    7707questions

    C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

  • REST

    148questions

    REST(Representational State Transfer)はwebアプリケーションの構築スタイルの一種です。HTTP GET/POSTによってリクエストを送信し、レスポンスはXMLで返されます。SOAPのようなRPCの構築と比べるとサーバからクライアントを分離することが出来る為、人気です。

  • WCF

    14questions

    Windows Communication Foundation

  • トップ
  • C#に関する質問
  • WCFのテスト時エラーが出ます→「リモート サーバーから予期しない応答が返されました: (400) Bad Request。」