如何在登录表单中不区分用户名大小写? [英] How to do username case insensitive in login form?

查看:31
本文介绍了如何在登录表单中不区分用户名大小写?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用 Symfony 的登录表单,但如果输入的用户名是FOO"并且在数据库中存储的是foo",我将无法登录.我正在使用 Postgres.这意味着用户名字段区分大小写.我能做什么?

I'm using the login form from Symfony, but I can't login, if the entered username is 'FOO' and in the DB is stored 'foo'. I'm using Postgres. It means the username-field is case sensitive. What can I do?

推荐答案

这主要取决于您的数据库服务器.MySQL 不区分大小写,PostgreSQL 区分大小写.

This depends mainly on your Database-Server. MySQL is case insensitive, PostgreSQL is case sensitive.

但是你可以像这样写查询

But you can write query Like this

$this->createQueryBuilder('user')
            ->where('LOWER(user.username) = :username')
            ->setParameter('username', strtolower($username))
            ->getQuery()
            ->getResult()
            ;

这篇关于如何在登录表单中不区分用户名大小写?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆