怎样区分用户输入的用户名和密码的大小写

时间:2022-07-08 00:59:14

 在做用户登录时,我想区分用户输入的大小写~  并把大小写的用户名和密码保存到数据库----;

   

19 个解决方案

#1


学习一下

#2


默认就是区分大小写的。

#3



 我已经测过来~ 我的用户名 X66 与 x66 都可以登录检证成功!

#4


在SQLServer中区分大小写的几种方法


第一种:(蟋蟀)
ALTER TABLE tb
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CI_AS
--不区分大小写
ALTER TABLE tb
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CS_AS
--区分大小写
alter database 数据库 COLLATE Chinese_PRC_CS_AS

第二种:(tree)
--创建如下用户自定义函数(UDF)

CREATE FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
--ALTER FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
RETURNS INTEGER
AS
BEGIN
  DECLARE @i INTEGER
  --DECLARE @Str1 VARCHAR(50)
  --DECLARE @Str2 VARCHAR(50)
  DECLARE @y INT
  --SET @Str1='a'
  --SET @Str2='A'
  SET  @i=0
  --SELECT ASCII(SUBSTRING(@Str1,@i+1,1))
  SET @y=1
  DECLARE @iLen INT
  SET @iLen = LEN(LTRIM(RTRIM(@Str1)))
  IF LEN(LTRIM(RTRIM(@Str1))) < LEN(LTRIM(RTRIM(@Str2))) --THEN
     SET @iLen = LEN(LTRIM(RTRIM(@Str2)))
  WHILE (@i < @iLen)
    BEGIN
      IF (ASCII(SUBSTRING(@Str1,@i+1,1))=ASCII(SUBSTRING(@Str2,@i+1,1))) --THEN
         SET @i = @i +1
      ELSE
         BEGIN
           SET @y=0
           BREAK
         END
      END
     RETURN @y
END

测试:
select *
from Table1
Where dbo.StrComp(Field1,'aAbB') =1

第三种:(Oliver)
SQL Server 数据库中的文本信息可以用大写字母、小写字母或二者的组合进行存储。例如,姓氏可以"SMITH"、"Smith"或"smith"等形式出现。

数据库是否区分大小写取决于 SQL Server 的安装方式。如果数据库区分大小写,当搜索文本数据时,必须用正确的大小写字母组合构造搜索条件。例如,如果搜索名字"Smith",则不能使用搜索条件"=smith"或"=SMITH"。

另外,如果服务器被安装成区分大小写,则必须用正确的大小写字母组合提供数据库、所有者、表和列的名称。如果提供的名称大小写不匹配,则 SQL Server 返回错误,报告"无效的对象名"。

当使用关系图窗格和网格窗格创建查询时,查询设计器始终正确地反映出服务器是否区分大小写。但是,如果在 SQL 窗格中输入查询,则必须注意使名称与服务器解释名称的方式相匹配。

如果服务器是用不区分大小写的选项安装的,则
提示   若要确定服务器是否区分大小写,请执行存储过程 sp_server_info,然后检查第 18 行的内容。如果服务器是用不区分大小写的设置安装的,则 sort_order 选项将设置为"不区分大小写"。可以从查询分析器运行存储过程。

第四种:(非云)
select * from servers where convert(varbinary, name)=convert(varbinary, N'RoCKEY')

第五种:()

ascii('a')再配合Substring()一起用

#5


ASCII码

#6


是通过排序规则区分的
不过如果单为了登陆这单一功能也可以通过简单的程序实现:
一般的做法是不区分用户名大小写的,主要用于密码:

string name = "X66";
string pwd = "Abc";
string sql = "select pwd from users where name='"+name+"'";
查出的密码为pwd2
if(pwd==pwd2)登陆成功

#7


  怎样区分密码大小写~ 在存储过程,还是在检证登陆时,写代码

#8



 个位高手!! 给我顶一下啊·  

#9


在用户名和密码验证的时候,默认就是区分的,不希望区分的话,在验证的时间加个忽略大小写的方法

,.net2.0里面自带的哦,我忘了具体是哪个。

#10


sql检索区分大小写如下

区分大小写:select * from table where col='semye' collate Chinese_PRC_CS_AI
不区分大小写:select * from table where col='semye' collate Chinese_PRC_CI_AI

#11


你是新手?

用户名一般不区分大小写
密码一般要加密后保存, A 和 a 加密后是完全不同的值,

登录不存在大小写问题

#12


学习学习

#13


引用 10 楼 llsen 的回复:
sql检索区分大小写如下

区分大小写:select * from table where col='semye' collate Chinese_PRC_CS_AI
不区分大小写:select * from table where col='semye' collate Chinese_PRC_CI_AI

就这个了

#14


写代码判断的时候,全部写成小写的进行判断

#15


看判断的代码了    楼上说的密码写在都是加密过的大小写几本上都没有问题的

#16


判断 用户是否按Caps Lock 键

#17


可以在比对前全部转成大写或者小写就好了!

#18


我是来学习的.一般不考虑大小写.

#19


 我想说的是~ 确实没有必要考虑用户输入的用户名是否大小写,在一个项目中,已经对用户密码加密
 大写A 与小写a 加密后的值是不一样的~  

  

#1


学习一下

#2


默认就是区分大小写的。

#3



 我已经测过来~ 我的用户名 X66 与 x66 都可以登录检证成功!

#4


在SQLServer中区分大小写的几种方法


第一种:(蟋蟀)
ALTER TABLE tb
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CI_AS
--不区分大小写
ALTER TABLE tb
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CS_AS
--区分大小写
alter database 数据库 COLLATE Chinese_PRC_CS_AS

第二种:(tree)
--创建如下用户自定义函数(UDF)

CREATE FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
--ALTER FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
RETURNS INTEGER
AS
BEGIN
  DECLARE @i INTEGER
  --DECLARE @Str1 VARCHAR(50)
  --DECLARE @Str2 VARCHAR(50)
  DECLARE @y INT
  --SET @Str1='a'
  --SET @Str2='A'
  SET  @i=0
  --SELECT ASCII(SUBSTRING(@Str1,@i+1,1))
  SET @y=1
  DECLARE @iLen INT
  SET @iLen = LEN(LTRIM(RTRIM(@Str1)))
  IF LEN(LTRIM(RTRIM(@Str1))) < LEN(LTRIM(RTRIM(@Str2))) --THEN
     SET @iLen = LEN(LTRIM(RTRIM(@Str2)))
  WHILE (@i < @iLen)
    BEGIN
      IF (ASCII(SUBSTRING(@Str1,@i+1,1))=ASCII(SUBSTRING(@Str2,@i+1,1))) --THEN
         SET @i = @i +1
      ELSE
         BEGIN
           SET @y=0
           BREAK
         END
      END
     RETURN @y
END

测试:
select *
from Table1
Where dbo.StrComp(Field1,'aAbB') =1

第三种:(Oliver)
SQL Server 数据库中的文本信息可以用大写字母、小写字母或二者的组合进行存储。例如,姓氏可以"SMITH"、"Smith"或"smith"等形式出现。

数据库是否区分大小写取决于 SQL Server 的安装方式。如果数据库区分大小写,当搜索文本数据时,必须用正确的大小写字母组合构造搜索条件。例如,如果搜索名字"Smith",则不能使用搜索条件"=smith"或"=SMITH"。

另外,如果服务器被安装成区分大小写,则必须用正确的大小写字母组合提供数据库、所有者、表和列的名称。如果提供的名称大小写不匹配,则 SQL Server 返回错误,报告"无效的对象名"。

当使用关系图窗格和网格窗格创建查询时,查询设计器始终正确地反映出服务器是否区分大小写。但是,如果在 SQL 窗格中输入查询,则必须注意使名称与服务器解释名称的方式相匹配。

如果服务器是用不区分大小写的选项安装的,则
提示   若要确定服务器是否区分大小写,请执行存储过程 sp_server_info,然后检查第 18 行的内容。如果服务器是用不区分大小写的设置安装的,则 sort_order 选项将设置为"不区分大小写"。可以从查询分析器运行存储过程。

第四种:(非云)
select * from servers where convert(varbinary, name)=convert(varbinary, N'RoCKEY')

第五种:()

ascii('a')再配合Substring()一起用

#5


ASCII码

#6


是通过排序规则区分的
不过如果单为了登陆这单一功能也可以通过简单的程序实现:
一般的做法是不区分用户名大小写的,主要用于密码:

string name = "X66";
string pwd = "Abc";
string sql = "select pwd from users where name='"+name+"'";
查出的密码为pwd2
if(pwd==pwd2)登陆成功

#7


  怎样区分密码大小写~ 在存储过程,还是在检证登陆时,写代码

#8



 个位高手!! 给我顶一下啊·  

#9


在用户名和密码验证的时候,默认就是区分的,不希望区分的话,在验证的时间加个忽略大小写的方法

,.net2.0里面自带的哦,我忘了具体是哪个。

#10


sql检索区分大小写如下

区分大小写:select * from table where col='semye' collate Chinese_PRC_CS_AI
不区分大小写:select * from table where col='semye' collate Chinese_PRC_CI_AI

#11


你是新手?

用户名一般不区分大小写
密码一般要加密后保存, A 和 a 加密后是完全不同的值,

登录不存在大小写问题

#12


学习学习

#13


引用 10 楼 llsen 的回复:
sql检索区分大小写如下

区分大小写:select * from table where col='semye' collate Chinese_PRC_CS_AI
不区分大小写:select * from table where col='semye' collate Chinese_PRC_CI_AI

就这个了

#14


写代码判断的时候,全部写成小写的进行判断

#15


看判断的代码了    楼上说的密码写在都是加密过的大小写几本上都没有问题的

#16


判断 用户是否按Caps Lock 键

#17


可以在比对前全部转成大写或者小写就好了!

#18


我是来学习的.一般不考虑大小写.

#19


 我想说的是~ 确实没有必要考虑用户输入的用户名是否大小写,在一个项目中,已经对用户密码加密
 大写A 与小写a 加密后的值是不一样的~  

  

#20