当前位置: 首页 > article >正文

springboot-网站开发-如何规避和拒绝用户输入的空字符串

springboot-网站开发-如何规避和拒绝用户输入的空字符串!在网站开发过程中,前端用户的输入内容,经常会遇到有人故意输入字符串。导致一些异常的发生。

下面分享一下,我的应对方法。仅供参考。


前端html模板页面内,我做了一下js的判定,但是我感觉没有发挥作用。不知道什么原因,如果有懂的朋友,可以留言给我,谢谢。


/*1.对用户名进行验证*/
    //当对象失去焦点触发验证流程
    uname.onblur = function(){
        if(this.validity.valueMissing){
            this.nextElementSibling.innerHTML = '用户名不能为空';
            this.nextElementSibling.className = 'msg-error';
            this.setCustomValidity('用户名不能为空');
        }else if(this.validity.tooShort){
            this.nextElementSibling.innerHTML = '用户名不能少于2位';
            this.nextElementSibling.className = 'msg-error';
            this.setCustomValidity('用户名不能少于2位');
        }else {
            this.nextElementSibling.innerHTML = '用户名格式正确';
            this.nextElementSibling.className = 'msg-success';
            this.setCustomValidity('');
            var data =$("#uname").val().replace(/\s+/g, '');
            if(!data || isOnlySpaces(data)){   //用户没有输入任何内容
                return;
            }
            /**发起异步GET请求,询问服务器用户名是否已经存在**/
            $.ajax({
                url:"../user/checkName",
                //let filteredValue = inputValue.replace(/\s+/g, '');
                data:"username="+$("#uname").val().replace(/\s+/g, ''),
                type:"get",
                dataType:"json",
                success:function(obj){
                    $("#namespan").html(obj.message);//显示服务器的响应信息
                    if(obj.state==0){
                        $("#namespan").attr("class","msg-error");
                    }else{
                        $("#namespan").attr("class","msg-success");
                    }
                }
            });

        }
    }

这个地方做了判断,没有什么效果,照样会进入后端接口的执行。


2:还好,我也在后端接口里面做了判定。增加了如下代码。

这个是做了用户名字的验证。是否可用。从数据库内查询是否存在,如果不存在,就返回可以使用。


3:在真正的注册接口内,还做了第三次验证。

现在执行代码后,等用户在前端页面点击提交注册按钮后,反馈了一个不允许输入空字符。

说明,我前面2步骤都米有发生行为。到了第三步才发生了行为。

不管怎么说,问题是解决了。


http://www.kler.cn/news/340844.html

相关文章:

  • 深入解析 Baichuan 模型:架构、训练与实际应用
  • 门窗对象检测系统源码分享[一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]
  • Spring Boot教学资源大全:开启你的Spring之旅
  • Git进行版本控制操作流程
  • ubuntu18.04系统中图形化界面
  • ClickHouse之更新表(ReplicatedReplacingMergeTree)
  • 【React】入门Day04 —— 项目搭建及登录与表单校验、token 管理、路由鉴权实现
  • 笔记本电脑重启输入密码后黑屏
  • 【hot100-java】二叉树中的最大路径和
  • 新赚米渠道,天工AI之天工宝典!
  • %pip和!pip的区别
  • JVM 内存模型与垃圾回收过程详解
  • Linux驱动开发(速记版)--热插拔
  • Blade 模板引擎中常用的指令和标签
  • 宠物咖啡馆互动平台:SpringBoot框架的设计与优化
  • 基于Arduino的超声波和舵机模块集成使用
  • 软件测试 —— 灰度测试及测试流程!
  • 什么是CIA三要素以及对于信息安全的重要性
  • 如何使用IntelliJ IDEA生成UML图
  • SQL性能优化指南:如何优化MySQL多表join场景