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

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

新規登録して質問してみよう
ただいま回答率
85.48%
C#

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

Q&A

解決済

1回答

4962閲覧

C#でのデータベースを利用したログイン認証について

mogumogu

総合スコア12

C#

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

0グッド

0クリップ

投稿2016/09/08 07:40

編集2016/09/09 07:51
コード ```###前提・実現したいこと C#を使って、Visual Studio2015でWebログイン認証を作っています。 入力された氏名とパスワードをローカルのデータベースを検索して参照し、合致すればログインできるようにしたいです。 https://support.microsoft.com/ja-jp/kb/314145を参考に作りました。 ###該当のソースコード ```ここに言語を入力 namespace LoginTest { public partial class login : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { } protected void LoginForm_Authenticate(object sender, AuthenticateEventArgs e) { try { //データベース接続を確立する。 string sConnectionString; sConnectionString = "Data Source=(localdb)/ProjectsV13;Initial Catalog=ProjectManagement;Integrated Security=True;Connect Timeout=10;Encrypt=False;TrustServerCertificate=True;ApplicationIntent=ReadWrite;MultiSubnetFailover=False;"; SqlConnection objConn = new SqlConnection(sConnectionString); objConn.Open(); //データベースとDatasetオブジェクトの間のリンクを表すDataAdapterを作成。 SqlDataAdapter MS = new SqlDataAdapter("SELECT NAME, PWD FROM dbo.MSTAFF", objConn); //DataSetオブジェクトを宣言してインスタンスを作成。 DataSet PM = new DataSet("ProjectManagement"); //DataSetにデータを読み込む MS.FillSchema(PM, SchemaType.Source, "dbo.MSTAFF"); MS.Fill(PM, "dbo.MSTAFF"); MS.MissingSchemaAction = MissingSchemaAction.AddWithKey; MS.Fill(PM, "dbo.MSTAFF"); DataTable dt; dt = PM.Tables["dbo.MSTAFF"]; //DataTableのRowsコレクションに含まれるすべてのDataRowオブジェクトを読み込み。 foreach (DataRow drCurrent in dt.Rows) { Console.WriteLine("{1}{3}", drCurrent["NAME"].ToString(), drCurrent["PWD"].ToString()); } Console.ReadLine(); //入力されたユーザー名とパスワードが、データベースのNAMEとPWDと一致した場合のみ if (this.loginForm.UserName == dt.Rows[1].ToString() && this.loginForm.Password == dt.Rows[3].ToString()) { //初期画面に遷移 e.Authenticated = true; } else { e.Authenticated = false; } objConn.Close(); } catch (SqlException ex) { } } } }

###試したこと
デバッグを実行してみましたが、コードが動いているかどうかよくわかりません。
どこがおかしいのでしょうか?

gusao様への追記:
例外の内容は、
SQL Server への接続を確立しているときにネットワーク関連またはインスタンス固有のエラーが発生しました。サーバーが見つからないかアクセスできません。インスタンス名が正しいこと、および SQL Server がリモート接続を許可するように構成されていることを確認してください。 (provider: 名前付きパイプ プロバイダ, error: 40 - SQL Server への接続を開けませんでした)
例外が発生した行は、catch (SqlException ex)の行でした。

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

omochi

2016/09/08 07:59

ソースコードはコードブロックを利用して記述してください
mogumogu

2016/09/08 08:01

すみませんでした。コードブロックでコードを書き直しました。
Tak1wa

2016/09/08 14:28

LoginForm_Authenticateはログインコントロールのイベントハンドラとして設定はされていますか?そもそもデバッグ実行して際にPage_Loadが動いているのは確認できているのでしょうか。 デバッグ実行の仕方がそもそもわからないのか、認証部分だけなぜか動かないのか、現状を整理してください
mogumogu

2016/09/09 01:06

LoginForm_Authenticateはログインコントロールのイベントハンドラとして設定されています。Page_Loadは動いています。 その後、デバッグ実行したところsql接続ができずsqlExceptionに飛んでいることが分かりました。sqlサーバーへの接続ができていないようです。
gusao

2016/09/09 05:16

例外の内容と、どの行で例外が発生したのかを質問文に記載してください。
guest

回答1

0

ベストアンサー

接続文字列の
Data Source=(localdb)/ProjectsV13;...

Data Source=(localdb)\ProjectsV13;...
にしてみてもダメですか?
(スラッシュ/ではなく、円マーク\)

円マークそのままだとエスケープシーケンスとして扱われてしまうので、
変数にセットする際は@をつけてください。
具体的には以下です。

c#

1sConnectionString = @"Data Source=(localdb)\ProjectsV13;...";

投稿2016/09/09 08:27

gusao

総合スコア185

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mogumogu

2016/09/13 00:09

返答が遅くなり申し訳ありません。 ご教示いただいた@を追加したことで、処理が流れるようになったようです。 エスケープシーケンスの件は大変勉強になりました。 ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問