登陆时的密码大小写判断

当密码没有加密时,数据库一般默认是大小写不区分的,这时不管你输入的是大写的还是小写的都可以登陆,刚开始用第二种方法虽然也可以解决但是是比较麻烦的.

解决方法一:

Alter TABLE 表名 
Alter COLUMN 列名 varchar(
100 ) COLLATE Chinese_PRC_CS_AS

解决方法二:

对登陆的密码大小写进行逐一判断

ALTER FUNCTION [dbo].[StringUpperLowerValidate]
(
@strInput VARCHAR(
128 ),
@strExist VARCHAR(
128
)
RETURNS BIT
AS
BEGIN
DECLARE @position   INT 
DECLARE @Result   BIT
SET @position 
=   1

WHILE @position 
<=  DATALENGTH(@strExist)
    BEGIN
   IF( ASCII(SUBSTRING(@strExist, @position, 
1 )) =  ASCII(SUBSTRING(@strInput, @position,  1 )))
    BEGIN
     SET @position 
=  @position  +   1  
     SET @Result
= 1
    END
   ELSE
    BEGIN
     SET @Result
= 0
     
break
    END
    END
    
RETURN @Result

END

// 不区分大小写(作用于表中存储的数据)
Alter TABLE 表名
Alter COLUMN 列名 varchar(
100 ) COLLATE Chinese_PRC_CI_AS

// 区分大小写
Alter TABLE 表名
Alter COLUMN 列名 varchar(
100 ) COLLATE Chinese_PRC_CS_AS

// 区分大小写(作用于表名、字段名……)
alter database 数据库 collate chinese_prc_cs_as

// 不区分大小写
alter database 数据库 collate chinese_prc_ci_as

转载于:https://www.cnblogs.com/datong/archive/2008/03/21/1115992.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的实现: HTML代码: ``` <form> <label for="username">账号:</label> <input type="text" id="username" name="username" required minlength="6"><br> <label for="password">密码:</label> <input type="password" id="password" name="password" required minlength="8"><br> <button type="submit" id="submitBtn">登录</button> </form> ``` JavaScript代码: ``` const submitBtn = document.getElementById("submitBtn"); submitBtn.addEventListener("click", function(event) { event.preventDefault(); // 阻止表单默认提交行为 const username = document.getElementById("username").value; const password = document.getElementById("password").value; // 判断账号密码是否为空 if (username.trim() === "" || password.trim() === "") { alert("账号密码不能为空!"); return; } // 判断密码复杂度,至少包含三种属性:英文大小写、数字、符号 const regex = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*\W).{8,}$/; if (!regex.test(password)) { alert("密码复杂度不够,至少包含英文大小写、数字、符号中的三种属性,且密码长度不少于8位!"); return; } alert("登录成功!"); }); ``` 解释: 1. 首先获取表单中的账号和密码输入框的值。 2. 判断账号和密码是否为空,如果有空的情况则提示用户。 3. 判断密码的复杂度,使用正则表达式判断密码是否包含英文大小写、数字、符号中的三种属性,且长度不少于8位。 4. 如果以上两个条件都满足,则弹出登录成功的提示框。 注:这只是一个简单的实现,实际应用中还需要考虑更多的情况,例如如何防止 XSS 攻击、如何防止 CSRF 攻击等等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值