纳税服务系统【用户模块之用户唯一性校验】

2023-11-06 21:50

本文主要是介绍纳税服务系统【用户模块之用户唯一性校验】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

前三篇博文已经基本完成了用户模块的功能了,本篇是对其进行补充…主要完成用户唯一性校验的问题

我们发现:在新增或编辑页面的时候用户的账号是可以重复的,这是不符合我们的逻辑的。
这里写图片描述

当用户新增账号的时候,如果该账号已经存在了,就应该告诉用户该账号重复,不能使用该账号。

分析

用户在填写完账户的时候,就应该去做校验了。【使用AJAX】

校验的工作是什么呢????其实就是去查找数据库有没有对应的账户记录,如果有,那么就告诉用户存在了。如果没有,就没问题了。

上面已经说了有两处需要校验用户唯一性的问题:

  • 新增页面
  • 修改页面

新增页面和修改页面是有不同的处理方案的,因为在修改页面时,如果用户不修改账户,该用户的账户本来就存在了。因此我们要排除该用户的当前账户相同的问题,其实也很简单。

  • 在修改页面时是需要id传递过去的,而新增用户是不需要的。在查询数据库的时候,看看有没有id,如果有id就多一个条件即可!

前台使用AJAX处理

为账户的输入框添加事件

当账户的输入框修改时,就去数据库查询有没有相同的账户名字。

值得注意的是:本来我是在控件上添加一个id,使用Jquery得到id所在的控件,然后绑定事件,但是用不了。

所以,我只能在控件上绑定一个静态方法了

<tr><td class="tdBg" width="200px">帐号:</td><td><s:textfield id="userAccount" name="user.account" onchange="doVerify()"/></td></tr>

把账号的值传递给服务器,接受服务器返回的值

function doVerify() {//得到输入的值var account = $("#userAccount").val();$.ajax({type: "post",url: "${basePath}user/user_doVerify.action",data:{"user.account" :account},success:function (backdata) {alert(backdata);}});}

编写Dao方法

我们使用的是Hibernate,编写的HQL语句是FROM 实体,并不是”SELECT * FROM….. “

//因为我们不是在查id,因此是不能保证只有一个User对象的,即使在AJAX已经做了检查。因此返回值是个List集合List<User> findAccount(String id, String account);
@Overridepublic List<User> findAccount(String id, String account) {String hql = "FROM User WHERE account = ? ";//判断有没有id,如果有id,多加个条件【本账户不算】if (StringUtils.isNotBlank(id)) {hql = hql + "  AND id!=?";}Query query = getSession().createQuery(hql);query.setParameter(0, account);if (StringUtils.isNotBlank(id)) {query.setParameter(1, id);}List list = query.list();return list;}

Service调用Dao

List<User> findAccount(String id, String account);
    @Overridepublic List<User> findAccount(String id, String account) {return userDaoImpl.findAccount(id, account);}

Action处理

由于经常要判断传递过来的数据时候为null,是否为”“,我们使用StringUtils来进行判断:

    /************账户一次性校验*************************/public void doVerify() {try {//默认不存在String exist = "false";//判断账户是否为空,已经用户输入的数据。【我们使用StringUtils这个类来判断】//isNotBlank封装了不为null和不为""if (user != null && StringUtils.isNotBlank(user.getAccount())) {List<User> list = userServiceImpl.findAccount(user.getId(), user.getAccount());//如果查询到数据,那么说明该账户已经存在了。if (list != null && list.size() > 0) {exist = "true";}}HttpServletResponse response = ServletActionContext.getResponse();response.setContentType("text/html");ServletOutputStream outputStream = response.getOutputStream();outputStream.write(exist.getBytes());outputStream.close();} catch (IOException e) {e.printStackTrace();}}

前台提示

<script type="text/javascript">function doVerify() {//得到输入的值var account = $("#userAccount").val();$.ajax({type: "post",url: "${basePath}user/user_doVerify.action",data:{"user.account" :account},success:function (backdata) {//当存在的时候,告诉用户该账户已经存在了。if(backdata=="true") {alert("该账户已经存在了!请用别的账户");//定焦$("#userAccount").focus();}else {}}});}</script>

效果:

这里写图片描述


完善

上面只是完成了校验用户名是否唯一的功能,但是如果用户不听我的劝告,照样去提交表单,还是可以完成的。

于是在提交表单的时候要判断是否合法才能让用户提交:

把submit按钮改成是button,提供单击事件

   <input type="button" class="btnB2" value="保存" onclick="doSubmit()" />
    <script type="text/javascript">var Vresult = true;function doVerify() {//得到输入的值var account = $("#userAccount").val();$.ajax({type: "post",url: "${basePath}user/user_doVerify.action",async:false,data:{"user.account" :account},success:function (backdata) {//当存在的时候,告诉用户该账户已经存在了。if(backdata=="true") {alert("该账户已经存在了!请用别的账户");//定焦$("#userAccount").focus();Vresult = false;}else {Vresult = true;}}});}function doSubmit() {//在提交之前执行验证,但是验证又是异步的,因此要把异步改成同步doVerify();//判断能否提交表单if(Vresult) {document.forms[0].submit();}}</script>

editUI

在editUI上唯一区别就是需要把id传递过去给服务器端。


data: {"user.account": account, "user.id": "${user.id}"},

效果:

这里写图片描述


这篇关于纳税服务系统【用户模块之用户唯一性校验】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Qt spdlog日志模块的使用详解

《Qtspdlog日志模块的使用详解》在Qt应用程序开发中,良好的日志系统至关重要,本文将介绍如何使用spdlog1.5.0创建满足以下要求的日志系统,感兴趣的朋友一起看看吧... 目录版本摘要例子logmanager.cpp文件main.cpp文件版本spdlog版本:1.5.0采用1.5.0版本主要

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

SpringBoot利用@Validated注解优雅实现参数校验

《SpringBoot利用@Validated注解优雅实现参数校验》在开发Web应用时,用户输入的合法性校验是保障系统稳定性的基础,​SpringBoot的@Validated注解提供了一种更优雅的解... 目录​一、为什么需要参数校验二、Validated 的核心用法​1. 基础校验2. php分组校验3

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Python使用date模块进行日期处理的终极指南

《Python使用date模块进行日期处理的终极指南》在处理与时间相关的数据时,Python的date模块是开发者最趁手的工具之一,本文将用通俗的语言,结合真实案例,带您掌握date模块的六大核心功能... 目录引言一、date模块的核心功能1.1 日期表示1.2 日期计算1.3 日期比较二、六大常用方法详