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

2024-05-14 23:04

本文主要是介绍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");

}

这篇关于ASP.NET银行大厅自助信息系统的开发与实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/990105

相关文章

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩