asp.netのログイン画面作成例
クラスライブラリのコードは以下の通りです。
using System;
Generic;
Linq;
Web; using System;
Data.SqlClient; using System;
SqlClient; using System;
Data;
/// <summary>
//// Summary description of CommonClass
/// </summary>
public class CommonClass
{
public CommonClass()
{
}
/// <summary>
//// Database connection class
/// </summary>
//// <returns> connection object</returns>
public SqlConnection GetConnection()
{
string myStr = ConfigurationManager.AppSettings["ConnectionString"].ToString();
SqlConnection myConn = new SqlConnection(myStr);
return myConn;
}
/// <summary>
/// Popup box
/// </summary>
/// <param name="TxtMessage">Popup alert message </param>
/// <param name="Url">Go to address after dialog is closed</param>
/// <returns></returns>
////
public string MessageBox(string TxtMessage,string Url) {
string str;
str = "<script language=javascript>alert('"+TxtMessage+"');location='"+Url+"'</script>";
return str;
}
/// <summary>
//// Used to perform add, delete and change functions
/// </summary>
/// <param name="sqlStr"> SQL statement for operation </param>
/// <returns> success returns TRUE, failure returns FALSE</returns>
////
public Boolean ExecSQL(string sqlStr) {
SqlConnection myConn = GetConnection();
myConn.Open();
SqlCommand myCmd = new SqlCommand(sqlStr,myConn);
try
{
myCmd.ExecuteNonQuery();
myConn.Close();
}
catch {
myConn.Close();
return false;
}
return true;
}
/// <summary>
//// Returns the dataset of the data source
/// </summary>
/// <param name="sqlStr">Operation SQL statement</param>
/// <param name="TableName">Data table name</param>
/// <returns> DataSetDataSet</returns>
public DataSet GetDataSet(string sqlStr, string TableName) {
SqlConnection myConn = GetConnection();
myConn.Open();
SqlDataAdapter adapt = new SqlDataAdapter(sqlStr, myConn);
DataSet ds = new DataSet();
adapt.Fill(ds, TableName);
myConn.Close();
return ds;
}
/// <summary>
/// Verify login to prevent SQL injection attacks
/// </summary>
/// <param name="loginName">username</param>
/// <param name="loginPwd">password</param>
/// <returns></returns>
public int checkLogin(string loginName,string loginPwd) {
SqlConnection myConn = GetConnection();
SqlCommand myCmd = new SqlCommand( "select count(*) from tb_User where Name=@loginName and PassWord=@loginPwd",myConn);
myCmd.Parameters.Add(new SqlParameter("@loginName",SqlDbType.VarChar,20));
myCmd.Parameters["@loginName"].Value = loginName;
myCmd.Parameters.Add(new SqlParameter("@loginPwd", SqlDbType.VarChar, 50));
myCmd.Parameters["@loginPwd"].Value = loginPwd;
myConn.Open();
int i = (int)myCmd.ExecuteScalar();
myCmd.Dispose();
myConn.Close();
return i;
}
/// <summary>
//// Implementing random captcha
/// </summary>
/// <param name="n">number of captchas</param>
//// <returns> return the generated random number</returns>
public string RandomNum(int n) {
string strchar = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s, t,u,v,w,x,y,z";
string[] VcArray = strchar.Split(',');
string VNum = "";
int temp = -1;
Random rand = new Random();
for (int i=1; i < n + 1; i++) {
if (temp ! = -1) {
rand = new Random(i*temp*unchecked((int)DateTime.Now.Ticks));
}
int t = rand.Next(61);
if (temp ! = -1 && temp == t) {
return RandomNum(n);
}
temp = t;
VNum += VcArray[t];
}
return VNum;
}
}
.aspxのコードは以下の通りです。
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Login.aspx.cs" Inherits="Login" %>
<!DOCTYPE html PUBLIC "-/W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd ">.XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd ">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<style type="text/css">
.tbl_login{ padding:10px; margin:10px;}。
.tbl_login td{ padding:10px; border:1px solid gray;}.
</style>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Table ID="Table1" runat="server" CssClass="tbl_login" >.Abstract:テーブルID="Table1"runat="server"。
<asp:TableRow runat="server">
<asp:TableCell>adminName:</asp:TableCell>
<asp:TableCell><asp:TextBox ID="txt_name" runat="server"></asp:TextBox></asp:TableCell>.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX;
</asp:TableRow>
<asp:TableRow runat="server">
<asp:TableCell> 管理者パスワード:</asp:TableCell>
<asp:TableCell><asp:TextBox ID="txt_pwd" runat="server" TextMode="Password"></asp: TextBox></asp:TableCell>
</asp:TableRow>
<asp:TableRow ID="TableRow1" runat="server">
<asp:TableCell>Captcha:</asp:TableCell>
<asp:TableCell><asp:TextBox ID="txt_code" runat="server" ></asp:TextBox></asp:TableCell>.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX.XXX;
<asp:TableCell style="border:1px solid silver;">
<asp:Label ID="lab_Code" runat="server" Text="8888"></asp:Label></asp:TableCell>
</asp:TableRow>
</asp:Table>
<asp:Button ID="btn_login" runat="server" Text="Login"
οnclick="btn_login_Click1" />
<asp:Button ID="btn_cancel" runat="server" Text="cancel".Button ID="btn_cancel" runat="server"Text="cancel"
οnclick="btn_cancel_Click1" />
</div>
</form>
</body>
</html>
.aspx.csのコードは以下の通りです。
using System;
Generic;
Linq;
Web;
UI;
WebControls;
public partial class Login : System.Web.UI.
UI.
CommonClass cc = new CommonClass();
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack) {
this.lab_Code.Text = cc.RandomNum(4);
}
}
protected void btn_login_Click1(object sender, EventArgs e)
{
if (txt_name.Text.Trim() == "" || txt_pwd.Text.Trim() == "")
{
Response.Write(cc.MessageBox("Login name and password cannot be empty! ", "Login.aspx"));
}
else
{
if (txt_code.Text.Trim() == lab_Code.Text.Trim())
{
int IntUserIn = cc.checkLogin(txt_name.Text.Trim(), txt_pwd.Text.Trim());
if (IntUserIn > 0)
{
Response.Write("<script language=javascript> window.open('AdminIndex.aspx');window.close();</script>");
}
else
{
Response.Write(cc.MessageBox("Login name or password error! ", "Login.aspx"));
}
}
else
{
Response.Write(cc.MessageBox("Captcha error! ", "Login.aspx"));
}
}
}
protected void btn_cancel_Click1(object sender, EventArgs e)
{
Response.Write("<script>window.close();location='javascript:history.go(-1)';</script>");
}
}
テストは次のように動作します。
関連
-
[解決済み] System.Web.HttpException (0x80004005) のトラブルシューティング方法です。ファイルが存在しません" のトラブルシューティングは?
-
[解決済み] allowDefinition='MachineToApplication' として登録されたセクションをアプリケーションレベルを超えて使用するとエラーになる。
-
[解決済み] キーワードがサポートされていないデータソース
-
[解決済み] IIS7.0で「HTTPエラー500.19 - 内部サーバーエラー」を解決するには [終了しました]。
-
[解決済み] ASP.NETのセッションが期限切れ、または見つからなかった → Session.SessionIDが変更されたため(Reporting Services)
-
[解決済み] ASP.NETでページを更新するにはどうすればよいですか?(コードで勝手に再読み込みさせる)。
-
[解決済み] Visual Studio 2017のエラーです。Unable to start program, An operation is not legal in current state.
-
[解決済み] クリスタル・レポート データソースを変更すると「ドキュメントの保存に失敗しました」と表示される
-
[解決済み] ORA-04067: 実行されませんでした、パッケージ本体が存在しません。
-
[解決済み] jquery の post 呼び出しから asp.net ページに html マークアップを送信する際に、潜在的に危険な Request.QueryString 値がクライアントから検出されました。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] リクエストの最大長を超えました。
-
[解決済み] レイアウトページ"~/Views/Shared/_Layout.cshtml "では、以下のセクションは定義されていますが、レンダリングは行われていません。"スクリプト"
-
[解決済み] vti_cnf」「_vti_pvt」「_vti_script」「_vti_txt」フォルダは何ですか?
-
[解決済み] IIS7.5で静的ファイルハンドラによってスクリプトが提供されない
-
[解決済み] 403 - 閲覧禁止です。アクセスが拒否されました。提供された資格情報を使用してこのディレクトリまたはページを表示する権限がありません。
-
[解決済み] パフォーマンスカウンターにアクセスすると「レジストリキー'Global'へのアクセスは拒否されました」と表示される。
-
[解決済み] ASP.Net - App_Data & App_Code フォルダ?
-
[解決済み] ASP.Netのdll.refreshファイルとは何ですか?
-
[解決済み] SQL ServerでPDFファイルをバイナリオブジェクトとして保存すること、イエスかノーか?
-
Asp.NET ラジオボタンの使用方法