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

解决方法一:

登陆时的密码大小写判断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
登陆时的密码大小写判断

相关文章:

  • 2021-06-18
  • 2021-09-13
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-10-20
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-12-05
  • 2021-08-03
相关资源
相似解决方案