ASP.NET银行大厅自助信息系统的开发与实现

摘    要

本毕业设计在基于银行业务大厅现有业务的基础上,针对自助银行的概念和其独有特点,通过.NET+SQL技术,开发一个简单的银行大厅自助信息系统,完成一些自助银行的业务需求如帐户信息查询、帐户挂失、自助交费、留言、新闻查询等功能

本论文从分析目前电子银行发展现状入手,具体深入地考察了当前自助银行的客户需求,详细说明了系统的结构设计,后台数据库的设计,系统功能设计,最后系统测试的效果,客观对整个系统进行了总结并对其提出修改意见。

关键字:帐户挂失;自助银行;.NET技术;C#语言;SQL SERVER数据库

3.1  功能需求

本论文根据自助银行实际功能和用户的实际需求,在.NET环境下为用户提供必要的功能服务,其系统分为以下三类用户:

(1)管理员用户:这是具有高级权限的一类用户,要求能够发布新闻和管理新闻;能够与用户进行交流,也就是要求能够通过发布留言形式处理用户的问题并且管理留言;要求能及时的处理用户的挂失申请。

(2)帐号用户:浏览自己的帐户信息,实现对帐户密码的管理;能够对自己的帐户活动进行细致的查询;能够实现帐户在紧急情况下的挂失处理;能够提供便捷服务,如简单的交费;要求浏览最近新闻,和发表看法。

(3)一般用户:要求浏览最近新闻,和发表看法。

4.1  系统结构简介

本文论述的银行大厅自助信息管理系统是基于B/S结构的数据库应用系统,具体反映为ASP+SQL技术的一种具体实现,根据B/S结构和用户实际应用特点,实现的功能主要可以在两类不同的机子上完成:Web服务器和自助机客户端。在客户端,主要实现使用用户的浏览功能和提交业务功能。在Web服务器上,主要来实现整个自助银行功能的后台处理及存储功能。后台数据库由一系列的具有相互关联的逻辑关系的表构成。还有一些存储过程和控件,用于实现其他的功能比如自动编号和图表生成。

4.2  具体功能模块划分

根据用户的需求分析和对系统功能的考量,得到如下的系统功能图:

5.1  用户登陆

5.1.1  储户登陆

图5-1 用户登陆页面

系统会自动判断身份证号,帐户号码,密码,验证码是否为空,还会验证身份证号是否符合国家规定的标准格式

//验证码的实现

asp:TextBox ID="txtCode" runat="server" Font-Size="0.8em" Width="74px" MaxLength="4"></asp:TextBox>

<img alt="点击刷新验证码" src="CodeImg.aspx" height="15" width="45" οnclick="this.src='CodeImg.aspx'" /></td>

if (txtCode.Text != Session["VerifyCode"].ToString())

{Response.Write("<script>alert('" + "验证码不正确!" + "');</script>");

return; }

5.1.2  管理员登陆

图5-2 管理员登陆页面

5.2  查询帐户信息


成功登陆系统过后,所要查询的帐户信息就会马上显示出来。存折类型会用红色字体注明,挂失时间和处理时间在帐户正常的时候不会有显示。信息显示采用.NET2005GridView控件(存折帐户相同):

5-3 帐户显示效果图

后台动作:

SQLstr = "select account as 帐户,balance as 帐户余额,estate as 帐户状态,firsttime as 挂失时间,secondtime as 处理时间 from account where ucard = '" + Session["logincard"].ToString() + "' and sort = '信用卡'";

//获取数据库连接字符串

strConnection = ConfigurationManager.AppSettings.Get("strConnection");

//建立数据库连接

myConnection = new SqlConnection(strConnection);

myAdapter = new SqlDataAdapter(SQLstr, myConnection);

//定义内存数据库

Dsak = new DataSet();

myAdapter.Fill(Dsak, "ak");

GVmyaccount_k.DataSource = Dsak.Tables["ak"];

GVmyaccount_k.DataBind();

追加显示多个帐户:用户可以通过继续输入帐户号码和密码添加更多的帐户进行查询,系统会自动搜寻数据库中是否存在此帐户。

5-4 帐户追加功能图

5.3  新闻浏览


用户可以浏览最近发布的几条新闻题目,其中新闻题目过多的时候,系统会分页显示它们。通过点选题目可以在新的页面看到新闻的具体内容。

5-5 新闻标题显示效果图


5-6 新闻内容显示效果图

管理员可以对新闻内容添加和删除。

5-7 新闻删除示意


5-8 新闻发布示意图

5.4  留言管理

任何权限的用户均可以发布留言,留言必须输入题目。只有管理员才能回复用户的留言,已回复留言的内容系统用黄色注明。

图5-9 处理回复留言


5-10 回复示意图

5.5  消费日志查询

用户通过设置时间起点和终点查询选择帐户的金额发生记录,可以作为帐户改变的日志记录。

5-11 帐户消费查询示意图

5.6  自助交费

本系统提供简单代收费管理功能,交费项目由管理员后台添加,用户需要选择需要交费的项目和输入自己的某个帐号和其密码(定期帐号不能进行交费),便可以缴纳不多于自己帐户余额的金额。交费金额精确到小数点后一位。

5-12 自助交费功能图

SQLstr = "select * from account where account = '" + DDLrepchargeaccount.Text + "'";

//获取数据库连接字符串和建立数据库连接省略……

myAdapter = new SqlDataAdapter(SQLstr, myConnection);

Dsbalance = new DataSet();

myAdapter.Fill(Dsbalance, "balance");

if(Convert.ToInt64(Dsbalance.Tables["balance"].Rows[0]["balance"].ToString())<Convert.ToInt64(TBrepchargemoney.Text))

{

Response.Write("<script language='javascript'>alert('你的帐户 " + DDLrepchargeaccount.Text + " 没有足够的余额来交纳此项费用');</script>");

return;

}

SQLstr = "INSERT INTO note(account,citem,csum) VALUES ('" + DDLrepchargeaccount.Text + "','" + DDLrepchargeitem.Text + "','" + TBrepchargemoney.Text + "')";

myCmd = new SqlCommand(SQLstr, myConnection);

myCmd.Connection.Open();

//异常捕获语句省略……

//扣除消费的金额

Lstr = "update account set balance = '" + Convert.ToString(Convert.ToInt64(Dsbalance.Tables["balance"].Rows[0]["balance"].ToString()) Convert.ToInt64(TBrepchargemoney.Text)) + "' where account = '" + DDLrepchargeaccount.Text + "'";

myCmd = new SqlCommand(SQLstr, myConnection);

myCmd.Connection.Open();

//异常捕获语句省略……

5.7  挂失处理

5.7.1  用户挂失申请和取消挂失申请

帐号挂失功能主要采用用户申请挂失,管理员批准挂失;处理完成后用户申请取消挂失,管理员批准的模式。一般用户申请挂失后24小时之内,银行要对申请作出回应,系统会自动记录申请提交的时间,和处理的时间,方便用户查看。


5-13 用户挂失申请和取消挂失申请图

//帐户状态改变处理

protected void GridViewreport_SelectedIndexChanged(object sender, EventArgs e)

{

SQLstr = "update account set estate = '挂失处理中',firsttime ='" + DateTime.Now.ToString() + "' where account = '" + GridViewreport.SelectedRow.Cells[1].Text + "'";

myCmd = new SqlCommand(SQLstr, myConnection);

myCmd.Connection.Open();

}

//异常捕获语句省略……

//帐户状态改变处理

protected void GridViewureport_SelectedIndexChanged(object sender, EventArgs e)

{

SQLstr = "update account set estate = '取消挂失中' where account = '" + GridViewureport.SelectedRow.Cells[1].Text.ToString().Trim() + "'";

myCmd = new SqlCommand(SQLstr, myConnection);

myCmd.Connection.Open(); }

//异常捕获语句省略……

5.7.2  管理员处理挂失和处理申请挂失


5-14 管理员处理挂失和处理申请挂失图

protected void GridViewadmindeluser_SelectedIndexChanged(object sender, EventArgs e)

{

SQLstr = "select * from account where account = '" + GridViewadmindeluser.SelectedRow.Cells[1].Text + "'";

myAdapter = new SqlDataAdapter(SQLstr, myConnection);

Dsuser = new DataSet();

myAdapter.Fill(Dsuser, "account");

}

if (Dsuser.Tables["account"].Rows[0]["estate"].ToString() == "挂失处理中")

{

SQLstr = "update account set estate = '挂失',secondtime ='" + DateTime.Now.ToString() + "' where account = '" + GridViewadmindeluser.SelectedRow.Cells[1].Text + "'";

}

else

{

SQLstr = "update account set estate = '正常',firsttime = null,secondtime = null where account = '" + GridViewadmindeluser.SelectedRow.Cells[1].Text + "'";

}

myCmd = new SqlCommand(SQLstr, myConnection);

myCmd.Connection.Open();


5-15 用户看到的帐户状态改变图

5.8  密码修改

5.8.1  用户帐户密码修改

系统会要求用户输入原有密码并确认后,便可以将旧有密码替换成新密码,系统会自动判断两次输入的新密码是否一致。


图5-16 用户帐户密码修改图

5.8.2  管理员修改登陆密码

图5-17 管理员修改登陆密码

5.9  帐号锁定

此功能是为了防止恶意猜测帐户密码的行为,当用户输入错误密码,登陆某个帐户不成功达到五次,此帐号便暂时锁定,用户必须申请管理员取消锁定。

图5-18 帐号锁定图

if (Convert.ToInt32(Session["loginoverflow"].ToString()) >= 5)

{

SQLstr = "INSERT INTO loginoverflow(lofucard,lofip) VALUES ('" + TBuname.Text + "','" + Page.Request.UserHostAddress+ "')";

myCmd = new SqlCommand(SQLstr, myConnection);

myCmd.Connection.Open();

try

{

myCmd.ExecuteNonQuery();

myCmd.Connection.Close();

}

catch

{

myCmd.Connection.Close();

return;

}

{

Response.Redirect("~/index.aspx");

Response.Write("<script language='javascript'>alert('登陆失败');</script>");

}

}

try

{

strConnection = ConfigurationManager.AppSettings.Get("strConnection");

//获取数据库连接字符串

//建立数据库连接

myConnection = new SqlConnection(strConnection);

SQLstr = "select lofucard as 锁定帐号,loftime as 锁定时间 from loginoverflow order by id desc";

myAdapter = new SqlDataAdapter(SQLstr, myConnection);

Dslw = new DataSet();

myAdapter.Fill(Dslw, "ip");

GridViewadmindellw.DataSource = Dslw.Tables["ip"];

GridViewadmindellw.DataBind();

}

catch

{ return;}

}

protected void GridViewadmindellw_SelectedIndexChanged(object sender, EventArgs e)

{

//删除黑名单中的记录

SQLstr = "delete loginoverflow where lofucard = '" + GridViewadmindellw.SelectedRow.Cells[1].Text + "' and lofip = '" +   GridViewadmindellw.SelectedRow.Cells[2].Text + "'";

myCmd = new SqlCommand(SQLstr, myConnection);

myCmd.Connection.Open();

try

{

myCmd.ExecuteNonQuery();

myCmd.Connection.Close();

}

catch

{

myCmd.Connection.Close();

return;

}

Response.Redirect("~/adminipkill.aspx");

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/700579.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

0510Goods的Maven项目

0510Goods的Maven项目包-CSDN博客 数据库字段 商品主页 修改页面 点击商品主页更改信息&#xff0c; 跳转到修改页面&#xff0c; 并保留初始信息。 商品类别最多选取三项&#xff0c;最少选取一项 添加界面 商品类别最多选取三项&#xff0c;最少选取一项

java 并发线程应用

java 并发线程相关 线程状态 新建(NEW): 创建后尚未启动。可运行(RUNABLE): 正在 Java 虚拟机中运行。但是在操作系统层面,它可能处于运行状态,也可能等待资源调度(例如处理器资源),资源调度完成就进入运行状态。所以该状态的可运行是指可以被运行,具体有没有运行要看底层…

刷题之找到字符串所有字母异位词

找到字符串所有字母异位词 滑动窗口。滑动窗口大小为待比较数组的大小。 class Solution { public:vector<int> findAnagrams(string s, string p) {//滑动窗口vector<int>result;if(s.size()<p.size())return result;vector<int>pnum(26,0);//记录p的字…

steam商店打不开、steam商店错误代码-118的解决方法

现在steam已经开始了&#xff0c;有很多好玩的游戏都在这段时间相继打折&#xff0c;虽然游戏众多&#xff0c;但是不是所有人都能把这些游戏都买下来&#xff0c;有一些小伙伴喜欢的游戏苦于没有足够的资本去购买&#xff0c;steam会以各种名义举办特惠活动吸引玩家们&#xf…

2024 年中国大学生程序设计竞赛全国邀请赛(郑州)暨第六届CCPC河南省大学生程序 设计竞赛Problem A. Once In My Life

//构造 #include<bits/stdc.h> using namespace std; #define int long long int a,b,c ; signed main() {ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);cin>>a;while(a--){cin>>b>>c;int mb,k0;while(m){m/10;k;}int v0;for(int i1;i<9;…

MySQL表的基本操作

表 创建表 comment是添加一个注释 语法&#xff1a; 说明&#xff1a; field 表示列名 datatype 表示列的类型 character set 字符集&#xff0c;如果没有指定字符集&#xff0c;则以所在数据库的字符集为准 collate 校验规则&#xff0c;如果没有指定校验规则&#xff0c;则…

景源畅信:抖音小店比较冷门的品类分享?

在抖音小店的世界里&#xff0c;热门品类总是吸引着众多商家和消费者的目光。然而&#xff0c;就像星空中的繁星&#xff0c;虽不那么耀眼却依然存在的冷门品类同样值得我们关注。它们或许不似服装、美妆那样日进斗金&#xff0c;但正是这些小众市场的存在&#xff0c;为平台带…

(四十二)第 6 章 树和二叉树(树的二叉链表(孩子-兄弟)存储)

1. 背景说明 2. 示例代码 1) errorRecord.h // 记录错误宏定义头文件#ifndef ERROR_RECORD_H #define ERROR_RECORD_H#include <stdio.h> #include <string.h> #include <stdint.h>// 从文件路径中提取文件名 #define FILE_NAME(X) strrchr(X, \\) ? strrch…

Keil编程不同驱动文件引用同一个常量的处理方法

基础不牢&#xff0c;地动山摇&#xff0c;最近单片机编程又遇到一个基础问题。 我在头文件中定义了一个常量同时给两个驱动文件使用&#xff0c;封装的时候编译没问题&#xff0c;但是在main函数中引用驱动函数的时候就出现了重定义的问题&#xff0c;如下如所示。 解决方法很…

汇聚荣科技:拼多多开店没有流量应该怎么办?

拼多多开店没有流量是一个常见的问题&#xff0c;许多新手商家都会遇到这样的困境。那么&#xff0c;如何解决这个问题呢?下面从四个方面进行详细阐述。 一、优化店铺和商品 首先&#xff0c;要确保店铺和商品的质量。店铺要有自己独特的风格和特色&#xff0c;商品要有高质量…

c++编程(11)——string类的模拟实现

欢迎来到博主的专栏——c编程 博主ID&#xff1a;代码小豪 文章目录 前言string类的模拟实现string的成员对象构造、赋值、析构访问成员对象的接口访问字符串中的元素迭代器对字符序列的插入、删除元素操作mystring类的相关操作 mystring类的所有模拟实现以及测试案例 前言 本…

2024.1.1 IntelliJ IDEA 使用记录

2024.1.1 IntelliJ IDEA 使用记录 下载设置文件编码maven 配置 插件可以中文语言包安装lombok 插件Smart Tomcat ( 根据需要安装)Smart Tomcat 配置 热部署&#xff08;非必须的&#xff09;解决Intellij IDEA运行报Command line is too long的问题 项目导入java 设置maven 配置…